mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-26 22:32:52 +02:00
DECTalk is back!
This commit is contained in:
@@ -15,7 +15,7 @@ You can invite the bot to your server using
|
|||||||
Be sure to also join the [home server](https://discord.gg/sbMe32W) for
|
Be sure to also join the [home server](https://discord.gg/sbMe32W) for
|
||||||
information and support.
|
information and support.
|
||||||
|
|
||||||
## Commands (295)
|
## Commands (296)
|
||||||
### Utility:
|
### Utility:
|
||||||
|
|
||||||
* **prefix**: Shows or sets the command prefix.
|
* **prefix**: Shows or sets the command prefix.
|
||||||
@@ -220,6 +220,7 @@ information and support.
|
|||||||
|
|
||||||
### Voice Channel:
|
### Voice Channel:
|
||||||
|
|
||||||
|
* **dec-talk**: The world's best Text-to-Speech.
|
||||||
* **leave-voice-channel**: Leaves a voice channel, in case the bot gets stuck.
|
* **leave-voice-channel**: Leaves a voice channel, in case the bot gets stuck.
|
||||||
* **soundboard**: Plays a sound in your voice channel.
|
* **soundboard**: Plays a sound in your voice channel.
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,50 @@
|
|||||||
|
const Command = require('../../structures/Command');
|
||||||
|
const request = require('node-superfetch');
|
||||||
|
|
||||||
|
module.exports = class DECTalkCommand extends Command {
|
||||||
|
constructor(client) {
|
||||||
|
super(client, {
|
||||||
|
name: 'dec-talk',
|
||||||
|
aliases: ['moon-base-alpha', 'text-to-speech', 'tts'],
|
||||||
|
group: 'voice',
|
||||||
|
memberName: 'dec-talk',
|
||||||
|
description: 'The world\'s best Text-to-Speech.',
|
||||||
|
guildOnly: true,
|
||||||
|
throttling: {
|
||||||
|
usages: 1,
|
||||||
|
duration: 10
|
||||||
|
},
|
||||||
|
args: [
|
||||||
|
{
|
||||||
|
key: 'text',
|
||||||
|
prompt: 'What text do you want to say?',
|
||||||
|
type: 'string',
|
||||||
|
max: 1024
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async run(msg, { text }) {
|
||||||
|
const channel = msg.member.voiceChannel;
|
||||||
|
if (!channel) return msg.say('Please enter a voice channel first.');
|
||||||
|
if (!channel.permissionsFor(this.client.user).has(['CONNECT', 'SPEAK'])) {
|
||||||
|
return msg.say('Missing the "Connect" or "Speak" permission for the voice channel.');
|
||||||
|
}
|
||||||
|
if (!channel.joinable) return msg.say('Your voice channel is not joinable.');
|
||||||
|
if (this.client.voiceConnections.has(channel.guild.id)) return msg.say('I am already playing a sound.');
|
||||||
|
try {
|
||||||
|
const connection = await channel.join();
|
||||||
|
const { url } = await request
|
||||||
|
.get('http://tts.cyzon.us/tts')
|
||||||
|
.query({ text });
|
||||||
|
const dispatcher = connection.play(url);
|
||||||
|
dispatcher.once('finish', () => channel.leave());
|
||||||
|
dispatcher.once('error', () => channel.leave());
|
||||||
|
return null;
|
||||||
|
} catch (err) {
|
||||||
|
channel.leave();
|
||||||
|
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
+2
-2
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "xiao",
|
"name": "xiao",
|
||||||
"version": "84.5.0",
|
"version": "84.6.0",
|
||||||
"description": "Your personal server companion.",
|
"description": "Your personal server companion.",
|
||||||
"main": "Xiao.js",
|
"main": "Xiao.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
@@ -40,7 +40,7 @@
|
|||||||
"erlpack": "github:discordapp/erlpack",
|
"erlpack": "github:discordapp/erlpack",
|
||||||
"mathjs": "^5.0.2",
|
"mathjs": "^5.0.2",
|
||||||
"node-opus": "^0.3.0",
|
"node-opus": "^0.3.0",
|
||||||
"node-superfetch": "^0.1.2",
|
"node-superfetch": "^0.1.3",
|
||||||
"pg": "^6.4.2",
|
"pg": "^6.4.2",
|
||||||
"pg-hstore": "^2.3.2",
|
"pg-hstore": "^2.3.2",
|
||||||
"random-js": "^1.0.8",
|
"random-js": "^1.0.8",
|
||||||
|
|||||||
Reference in New Issue
Block a user