mirror of
https://gitlab.com/bignutty/labscore.git
synced 2025-06-08 22:23:03 -04:00
tts commands
This commit is contained in:
parent
a6883967c3
commit
f451aed8fb
2 changed files with 45 additions and 2 deletions
43
commands/interaction/tts/texttospeech.js
Normal file
43
commands/interaction/tts/texttospeech.js
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
const { Constants } = require('detritus-client');
|
||||||
|
const { InteractionCallbackTypes, ApplicationCommandOptionTypes } = Constants;
|
||||||
|
|
||||||
|
const { imtranslator } = require('../../../labscore/api');
|
||||||
|
const { IMTRANSLATOR_VOICES } = require('../../../labscore/constants');
|
||||||
|
const { createEmbed } = require('../../../labscore/utils/embed');
|
||||||
|
const { icon, highlight } = require('../../../labscore/utils/markdown');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
description: 'Text to Speech',
|
||||||
|
name: 'texttospeech',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'voice',
|
||||||
|
description: 'TTS Voice to use',
|
||||||
|
choices: IMTRANSLATOR_VOICES,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'text',
|
||||||
|
description: 'Text',
|
||||||
|
type: ApplicationCommandOptionTypes.STRING,
|
||||||
|
required: true,
|
||||||
|
maxLength: 256
|
||||||
|
}
|
||||||
|
],
|
||||||
|
run: async (context, args) => {
|
||||||
|
try{
|
||||||
|
let s = Date.now()
|
||||||
|
await context.respond({data: {}, type: InteractionCallbackTypes.DEFERRED_CHANNEL_MESSAGE_WITH_SOURCE})
|
||||||
|
let audio = await imtranslator(context, args.text, args.voice)
|
||||||
|
let diff = (Date.now() - s)
|
||||||
|
await context.editOrRespond({
|
||||||
|
embeds: [createEmbed("default", context, { description: `${icon("audio")} Audio Generated in ${highlight(audio.timings + "s")}.` })],
|
||||||
|
file: { value: audio.response.body, filename: "tts.wav" }
|
||||||
|
})
|
||||||
|
}catch(e){
|
||||||
|
await context.editOrRespond({
|
||||||
|
embeds: [createEmbed("error", context, "Unable to generate audio file.")]
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
|
@ -5,7 +5,7 @@ const { tiktok } = require('../../../labscore/api');
|
||||||
const { TIKTOK_VOICES } = require('../../../labscore/constants');
|
const { TIKTOK_VOICES } = require('../../../labscore/constants');
|
||||||
|
|
||||||
const { createEmbed } = require('../../../labscore/utils/embed');
|
const { createEmbed } = require('../../../labscore/utils/embed');
|
||||||
const { icon } = require('../../../labscore/utils/markdown');
|
const { icon, highlight } = require('../../../labscore/utils/markdown');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
description: 'tiktok audio',
|
description: 'tiktok audio',
|
||||||
|
@ -32,7 +32,7 @@ module.exports = {
|
||||||
let audio = await tiktok(context, args.text, args.voice)
|
let audio = await tiktok(context, args.text, args.voice)
|
||||||
|
|
||||||
await context.editOrRespond({
|
await context.editOrRespond({
|
||||||
embeds: [createEmbed("default", context, { description: `${icon("audio")} Audio Generated in ${audio.timings}` })],
|
embeds: [createEmbed("default", context, { description: `${icon("audio")} Audio Generated in ${highlight(audio.timings + "s")}.` })],
|
||||||
file: { value: audio.response.body, filename: "tiktok.mp3" }
|
file: { value: audio.response.body, filename: "tiktok.mp3" }
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue