Phone Info Command

This commit is contained in:
Dragon Fire
2020-07-07 11:02:35 -04:00
parent 9b62b1f20d
commit 095e69c619
6 changed files with 45 additions and 5 deletions
+2 -1
View File
@@ -243,7 +243,7 @@ in the appropriate channel's topic to use it.
## Commands
Total: 529
Total: 530
### Utility:
@@ -801,6 +801,7 @@ Total: 529
* **admin-phone:** Starts an admin phone call with a server. (Owner-Only)
* **hang-up:** Hangs up the current phone call.
* **phone-book:** Looks up phone-enabled servers.
* **phone-info:** Gives information on the current phone call.
* **phone:** Starts a phone call with a random server.
### Other:
+1 -1
View File
@@ -29,7 +29,7 @@ module.exports = class AdminPhoneCommand extends Command {
if (!channel || !channel.guild) return msg.reply('This channel does not exist.');
try {
const id = `${msg.channel.id}:${channel.id}`;
this.client.phone.set(id, new PhoneCall(this.client, msg.channel, channel, true));
this.client.phone.set(id, new PhoneCall(this.client, msg.author, msg.channel, channel, true));
await this.client.phone.get(id).start();
return null;
} catch {
+36
View File
@@ -0,0 +1,36 @@
const Command = require('../../structures/Command');
const { MessageEmbed } = require('discord.js');
const moment = require('moment');
require('moment-duration-format');
module.exports = class PhoneInfoCommand extends Command {
constructor(client) {
super(client, {
name: 'phone-info',
aliases: ['call-info', 'phone-call-info'],
group: 'phone',
memberName: 'phone-info',
description: 'Gives information on the current phone call.',
guildOnly: true
});
}
async run(msg) {
const origin = this.client.phone.find(call => call.origin.id === msg.channel.id);
const recipient = this.client.phone.find(call => call.recipient.id === msg.channel.id);
if (!origin && !recipient) return msg.reply('☎️ This channel is not in a phone call.');
const call = origin || recipient;
if (!call.active) return msg.reply('☎️ This call is not currently active.');
const otherChannel = msg.channel.id === call.origin.id ? call.recipient : call.origin;
const embed = new MessageEmbed()
.setColor(0x00AE86)
.setThumbnail(otherChannel.guild.iconURL({ format: 'png' }))
.addField(' Recipient Channel', `#${otherChannel.name}`, true)
.addField(' Recipient Server', otherChannel.guild.name, true)
.addField(' Recipient ID', otherChannel.id, true)
.addField(' Call Duration', moment.duration(Date.now() - call.timeStarted).format('d:hh:mm:ss'), true)
.addField(' Admin Call?', call.ownerOrigin ? 'Yes' : 'No', true)
.addField(' Started By', call.startUser.tag, true);
return msg.embed(embed);
}
};
+1 -1
View File
@@ -64,7 +64,7 @@ module.exports = class PhoneCommand extends Command {
}
try {
const id = `${msg.channel.id}:${channel.id}`;
this.client.phone.set(id, new PhoneCall(this.client, msg.channel, channel));
this.client.phone.set(id, new PhoneCall(this.client, msg.author, msg.channel, channel));
await this.client.phone.get(id).start();
return null;
} catch {
+1 -1
View File
@@ -1,6 +1,6 @@
{
"name": "xiao",
"version": "119.10.2",
"version": "119.11.0",
"description": "Your personal server companion.",
"main": "Xiao.js",
"scripts": {
+4 -1
View File
@@ -2,17 +2,19 @@ const { stripIndents } = require('common-tags');
const { shorten, stripInvites, verify } = require('../../util/Util');
module.exports = class PhoneCall {
constructor(client, origin, recipient, ownerOrigin) {
constructor(client, startUser, origin, recipient, ownerOrigin) {
Object.defineProperty(this, 'client', { value: client });
this.id = `${origin.id}:${recipient.id}`;
this.origin = origin;
this.recipient = recipient;
this.startUser = startUser;
this.active = false;
this.timeout = null;
this.ownerOrigin = ownerOrigin || false;
this.cooldown = new Set();
this.ratelimitMeters = new Map();
this.timeStarted = null;
}
async start() {
@@ -34,6 +36,7 @@ module.exports = class PhoneCall {
async accept() {
this.active = true;
this.timeStarted = new Date();
this.setTimeout();
if (this.ownerOrigin) return this;
await this.origin.send(`☎️ **${this.recipient.guild.name}** picked up! Type \`hang up\` to hang up.`);