mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-18 21:40:49 +02:00
Fix translate bug in resolving languages
This commit is contained in:
@@ -2,7 +2,7 @@ const Command = require('../../structures/Command');
|
|||||||
const { MessageEmbed } = require('discord.js');
|
const { MessageEmbed } = require('discord.js');
|
||||||
const translate = require('@vitalets/google-translate-api');
|
const translate = require('@vitalets/google-translate-api');
|
||||||
const { list } = require('../../util/Util');
|
const { list } = require('../../util/Util');
|
||||||
const codes = translate.languages;
|
const codes = Object.keys(translate.languages).filter(code => typeof translate.languages[code] !== 'function');
|
||||||
|
|
||||||
module.exports = class TranslateCommand extends Command {
|
module.exports = class TranslateCommand extends Command {
|
||||||
constructor(client) {
|
constructor(client) {
|
||||||
@@ -12,7 +12,7 @@ module.exports = class TranslateCommand extends Command {
|
|||||||
group: 'edit-text',
|
group: 'edit-text',
|
||||||
memberName: 'translate',
|
memberName: 'translate',
|
||||||
description: 'Translates text to a specific language.',
|
description: 'Translates text to a specific language.',
|
||||||
details: `**Codes:** ${Object.keys(codes).join(', ')}`,
|
details: `**Codes:** ${codes.join(', ')}`,
|
||||||
clientPermissions: ['EMBED_LINKS'],
|
clientPermissions: ['EMBED_LINKS'],
|
||||||
credit: [
|
credit: [
|
||||||
{
|
{
|
||||||
@@ -31,18 +31,13 @@ module.exports = class TranslateCommand extends Command {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
key: 'target',
|
key: 'target',
|
||||||
prompt: `Which language would you like to translate to? Either ${list(Object.keys(codes), 'or')}.`,
|
prompt: `Which language would you like to translate to? Either ${list(codes, 'or')}.`,
|
||||||
type: 'string',
|
type: 'string',
|
||||||
validate: target => {
|
validate: target => {
|
||||||
const value = target.toLowerCase();
|
if (translate.languages.isSupported(target)) return true;
|
||||||
if (codes[value] || Object.keys(codes).find(key => codes[key].toLowerCase() === value)) return true;
|
return `Invalid target, please enter either ${list(codes, 'or')}.`;
|
||||||
return `Invalid target, please enter either ${list(Object.keys(codes), 'or')}.`;
|
|
||||||
},
|
},
|
||||||
parse: target => {
|
parse: target => translate.languages.getCode(target)
|
||||||
const value = target.toLowerCase();
|
|
||||||
if (codes[value]) return value;
|
|
||||||
return Object.keys(codes).find(key => codes[key].toLowerCase() === value);
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
key: 'base',
|
key: 'base',
|
||||||
@@ -50,15 +45,10 @@ module.exports = class TranslateCommand extends Command {
|
|||||||
type: 'string',
|
type: 'string',
|
||||||
default: 'auto',
|
default: 'auto',
|
||||||
validate: base => {
|
validate: base => {
|
||||||
const value = base.toLowerCase();
|
if (translate.languages.isSupported(base)) return true;
|
||||||
if (codes[value] || Object.keys(codes).find(key => codes[key].toLowerCase() === value)) return true;
|
return `Invalid base, please enter either ${list(codes, 'or')}.`;
|
||||||
return `Invalid base, please enter either ${list(Object.keys(codes), 'or')}.`;
|
|
||||||
},
|
},
|
||||||
parse: base => {
|
parse: base => translate.languages.getCode(base)
|
||||||
const value = base.toLowerCase();
|
|
||||||
if (codes[value]) return value;
|
|
||||||
return Object.keys(codes).find(key => codes[key].toLowerCase() === value);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
@@ -70,8 +60,8 @@ module.exports = class TranslateCommand extends Command {
|
|||||||
const embed = new MessageEmbed()
|
const embed = new MessageEmbed()
|
||||||
.setColor(0x4285F4)
|
.setColor(0x4285F4)
|
||||||
.setFooter('Powered by Google Translate', 'https://i.imgur.com/h3RoHyp.png')
|
.setFooter('Powered by Google Translate', 'https://i.imgur.com/h3RoHyp.png')
|
||||||
.addField(`❯ From: ${codes[from.language.iso]}`, from.text.value || text)
|
.addField(`❯ From: ${translate.languages[from.language.iso]}`, from.text.value || text)
|
||||||
.addField(`❯ To: ${codes[target]}`, result);
|
.addField(`❯ To: ${translate.languages[target]}`, result);
|
||||||
return msg.embed(embed);
|
return msg.embed(embed);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||||
|
|||||||
+1
-1
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "xiao",
|
"name": "xiao",
|
||||||
"version": "116.34.3",
|
"version": "116.34.4",
|
||||||
"description": "Your personal server companion.",
|
"description": "Your personal server companion.",
|
||||||
"main": "Xiao.js",
|
"main": "Xiao.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|||||||
Reference in New Issue
Block a user