pissbot-9000/commands/interaction/tts/texttospeech.js
2022-06-17 22:36:10 +02:00

44 lines
No EOL
1.4 KiB
JavaScript

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("defaultNoFooter", 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.")]
})
}
},
};