mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-10 02:45:22 +02:00
Try out eslint v9
This commit is contained in:
@@ -16,11 +16,11 @@ jobs:
|
|||||||
- name: Install NPM v6 (latest installs all packages)
|
- name: Install NPM v6 (latest installs all packages)
|
||||||
run: npm install -g npm@6
|
run: npm install -g npm@6
|
||||||
|
|
||||||
- name: Install ESLint v8
|
- name: Install ESLint v9
|
||||||
run: npm install -g eslint@8
|
run: npm install -g eslint@9
|
||||||
|
|
||||||
- name: Install ESLint Configs and Plugins
|
- name: Install ESLint Configs and Plugins
|
||||||
run: npm install eslint-config-amber eslint-plugin-json
|
run: npm install @eslint/js@9 eslint-config-amber eslint-plugin-jsonc
|
||||||
|
|
||||||
- name: Run ESLint
|
- name: Run ESLint
|
||||||
run: npm test
|
run: npm test
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ Just read `LICENSE.md`. Give credit if you use any part of this monster, thanks.
|
|||||||
22. Run `pm2 start Xiao.js --name xiao` to run the bot.
|
22. Run `pm2 start Xiao.js --name xiao` to run the bot.
|
||||||
|
|
||||||
## Commands
|
## Commands
|
||||||
Total: 512
|
Total: 510
|
||||||
|
|
||||||
### Utility:
|
### Utility:
|
||||||
|
|
||||||
@@ -232,6 +232,7 @@ Total: 512
|
|||||||
* **anime-staff:** Searches AniList for your query, getting staff results.
|
* **anime-staff:** Searches AniList for your query, getting staff results.
|
||||||
* **define:** Defines a word.
|
* **define:** Defines a word.
|
||||||
* **frinkiac:** Input a line from the Simpsons to get the episode/season.
|
* **frinkiac:** Input a line from the Simpsons to get the episode/season.
|
||||||
|
* **github:** Responds with information on a GitHub repository.
|
||||||
* **google-autofill:** Responds with a list of the Google Autofill results for a particular query.
|
* **google-autofill:** Responds with a list of the Google Autofill results for a particular query.
|
||||||
* **gravatar:** Responds with the Gravatar for an email.
|
* **gravatar:** Responds with the Gravatar for an email.
|
||||||
* **http-cat:** Responds with a cat for an HTTP status code.
|
* **http-cat:** Responds with a cat for an HTTP status code.
|
||||||
@@ -241,6 +242,7 @@ Total: 512
|
|||||||
* **nasa:** Searches NASA's image archive for your query.
|
* **nasa:** Searches NASA's image archive for your query.
|
||||||
* **neopet:** Responds with the image of a specific Neopet.
|
* **neopet:** Responds with the image of a specific Neopet.
|
||||||
* **neopets-item:** Responds with information on a specific Neopets item.
|
* **neopets-item:** Responds with information on a specific Neopets item.
|
||||||
|
* **npm:** Responds with information on an NPM package.
|
||||||
* **periodic-table:** Finds an element on the periodic table.
|
* **periodic-table:** Finds an element on the periodic table.
|
||||||
* **rule:** Responds with a rule of the internet.
|
* **rule:** Responds with a rule of the internet.
|
||||||
* **urban:** Defines a word, but with Urban Dictionary.
|
* **urban:** Defines a word, but with Urban Dictionary.
|
||||||
@@ -286,14 +288,6 @@ Total: 512
|
|||||||
* **valid-url:** Tests whether a URL is valid or not.
|
* **valid-url:** Tests whether a URL is valid or not.
|
||||||
* **zodiac-sign:** Responds with the Zodiac Sign for the given month/day.
|
* **zodiac-sign:** Responds with the Zodiac Sign for the given month/day.
|
||||||
|
|
||||||
### Programming:
|
|
||||||
|
|
||||||
* **beautify:** Beautifies code with js-beautify.
|
|
||||||
* **github:** Responds with information on a GitHub repository.
|
|
||||||
* **lint:** Lints code using ESLint.
|
|
||||||
* **lint-rule:** Responds with information on an ESLint rule.
|
|
||||||
* **npm:** Responds with information on an NPM package.
|
|
||||||
|
|
||||||
### Single-Player Games:
|
### Single-Player Games:
|
||||||
|
|
||||||
* **20-questions:** Think of something and 20Q will read your mind by asking a few simple questions.
|
* **20-questions:** Think of something and 20Q will read your mind by asking a few simple questions.
|
||||||
@@ -665,7 +659,6 @@ Total: 512
|
|||||||
* [discord.js](https://www.npmjs.com/package/discord.js)
|
* [discord.js](https://www.npmjs.com/package/discord.js)
|
||||||
* [dotenv](https://www.npmjs.com/package/dotenv)
|
* [dotenv](https://www.npmjs.com/package/dotenv)
|
||||||
* [emoji-regex](https://www.npmjs.com/package/emoji-regex)
|
* [emoji-regex](https://www.npmjs.com/package/emoji-regex)
|
||||||
* [eslint](https://www.npmjs.com/package/eslint)
|
|
||||||
* [fen-validator](https://www.npmjs.com/package/fen-validator)
|
* [fen-validator](https://www.npmjs.com/package/fen-validator)
|
||||||
* [font-finder](https://www.npmjs.com/package/font-finder)
|
* [font-finder](https://www.npmjs.com/package/font-finder)
|
||||||
* [gifencoder](https://www.npmjs.com/package/gifencoder)
|
* [gifencoder](https://www.npmjs.com/package/gifencoder)
|
||||||
@@ -673,7 +666,6 @@ Total: 512
|
|||||||
* [html-entities](https://www.npmjs.com/package/html-entities)
|
* [html-entities](https://www.npmjs.com/package/html-entities)
|
||||||
* [image-to-ascii](https://www.npmjs.com/package/image-to-ascii)
|
* [image-to-ascii](https://www.npmjs.com/package/image-to-ascii)
|
||||||
* [ioredis](https://www.npmjs.com/package/ioredis)
|
* [ioredis](https://www.npmjs.com/package/ioredis)
|
||||||
* [js-beautify](https://www.npmjs.com/package/js-beautify)
|
|
||||||
* [js-chess-engine](https://www.npmjs.com/package/js-chess-engine)
|
* [js-chess-engine](https://www.npmjs.com/package/js-chess-engine)
|
||||||
* [jszip](https://www.npmjs.com/package/jszip)
|
* [jszip](https://www.npmjs.com/package/jszip)
|
||||||
* [kuroshiro](https://www.npmjs.com/package/kuroshiro)
|
* [kuroshiro](https://www.npmjs.com/package/kuroshiro)
|
||||||
@@ -706,6 +698,7 @@ Total: 512
|
|||||||
* [ytdl-core](https://www.npmjs.com/package/ytdl-core)
|
* [ytdl-core](https://www.npmjs.com/package/ytdl-core)
|
||||||
* [zip-to-timezone](https://www.npmjs.com/package/zip-to-timezone)
|
* [zip-to-timezone](https://www.npmjs.com/package/zip-to-timezone)
|
||||||
* [zlib-sync](https://www.npmjs.com/package/zlib-sync)
|
* [zlib-sync](https://www.npmjs.com/package/zlib-sync)
|
||||||
|
|
||||||
### Other Credits
|
### Other Credits
|
||||||
* **changelog:**
|
* **changelog:**
|
||||||
- [GitHub](https://github.com/) (API)
|
- [GitHub](https://github.com/) (API)
|
||||||
@@ -865,6 +858,8 @@ Total: 512
|
|||||||
- [Merriam-Webster's Collegiate® Dictionary](https://www.merriam-webster.com/) (API)
|
- [Merriam-Webster's Collegiate® Dictionary](https://www.merriam-webster.com/) (API)
|
||||||
* **frinkiac:**
|
* **frinkiac:**
|
||||||
- [Frinkiac](https://frinkiac.com/) (API)
|
- [Frinkiac](https://frinkiac.com/) (API)
|
||||||
|
* **github:**
|
||||||
|
- [GitHub](https://github.com/) (API)
|
||||||
* **google-autofill:**
|
* **google-autofill:**
|
||||||
- [Google](https://www.google.com/) (Autofill API)
|
- [Google](https://www.google.com/) (Autofill API)
|
||||||
* **gravatar:**
|
* **gravatar:**
|
||||||
@@ -886,6 +881,8 @@ Total: 512
|
|||||||
* **neopets-item:**
|
* **neopets-item:**
|
||||||
- [Neopets](http://www.neopets.com/) (Original Game)
|
- [Neopets](http://www.neopets.com/) (Original Game)
|
||||||
- [JellyNeo Item Database](https://items.jellyneo.net/) (Item Data)
|
- [JellyNeo Item Database](https://items.jellyneo.net/) (Item Data)
|
||||||
|
* **npm:**
|
||||||
|
- [npm](https://www.npmjs.com/) (API)
|
||||||
* **periodic-table:**
|
* **periodic-table:**
|
||||||
- [Bowserinator](https://github.com/Bowserinator/) (Periodic Table Data)
|
- [Bowserinator](https://github.com/Bowserinator/) (Periodic Table Data)
|
||||||
- [Google](https://www.google.com/) (Noto Font)
|
- [Google](https://www.google.com/) (Noto Font)
|
||||||
@@ -961,10 +958,6 @@ Total: 512
|
|||||||
- [Hasbro](https://shop.hasbro.com/en-us) (Original "Scrabble" Game)
|
- [Hasbro](https://shop.hasbro.com/en-us) (Original "Scrabble" Game)
|
||||||
* **screenshot:**
|
* **screenshot:**
|
||||||
- [Thum.io](https://www.thum.io/) (API)
|
- [Thum.io](https://www.thum.io/) (API)
|
||||||
* **github:**
|
|
||||||
- [GitHub](https://github.com/) (API)
|
|
||||||
* **npm:**
|
|
||||||
- [npm](https://www.npmjs.com/) (API)
|
|
||||||
* **20-questions:**
|
* **20-questions:**
|
||||||
- [20Q.net](http://20q.net/) (API)
|
- [20Q.net](http://20q.net/) (API)
|
||||||
* **akinator:**
|
* **akinator:**
|
||||||
|
|||||||
@@ -47,7 +47,6 @@ client.registry
|
|||||||
['search', 'Search'],
|
['search', 'Search'],
|
||||||
['pokedex', 'Pokédex'],
|
['pokedex', 'Pokédex'],
|
||||||
['analyze', 'Analyzers'],
|
['analyze', 'Analyzers'],
|
||||||
['code', 'Programming'],
|
|
||||||
['games-sp', 'Single-Player Games'],
|
['games-sp', 'Single-Player Games'],
|
||||||
['games-mp', 'Multi-Player Games'],
|
['games-mp', 'Multi-Player Games'],
|
||||||
['edit-face', 'Face Manipulation'],
|
['edit-face', 'Face Manipulation'],
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
{
|
{
|
||||||
"github": "https://i.imgur.com/e4HunUm.png",
|
"github": "https://i.imgur.com/e4HunUm.png",
|
||||||
"eslint": "https://i.imgur.com/04GhEhU.png",
|
|
||||||
"npm": "https://i.imgur.com/ErKf5Y0.png",
|
"npm": "https://i.imgur.com/ErKf5Y0.png",
|
||||||
"googleTranslate": "https://i.imgur.com/h3RoHyp.png",
|
"googleTranslate": "https://i.imgur.com/h3RoHyp.png",
|
||||||
"nasa": "https://i.imgur.com/Wh8jY9c.png",
|
"nasa": "https://i.imgur.com/Wh8jY9c.png",
|
||||||
|
|||||||
@@ -1,26 +0,0 @@
|
|||||||
const Command = require('../../framework/Command');
|
|
||||||
const { js_beautify: beautify } = require('js-beautify');
|
|
||||||
|
|
||||||
module.exports = class BeautifyCommand extends Command {
|
|
||||||
constructor(client) {
|
|
||||||
super(client, {
|
|
||||||
name: 'beautify',
|
|
||||||
aliases: ['js-beautify'],
|
|
||||||
group: 'code',
|
|
||||||
memberName: 'beautify',
|
|
||||||
description: 'Beautifies code with js-beautify.',
|
|
||||||
clientPermissions: ['READ_MESSAGE_HISTORY'],
|
|
||||||
args: [
|
|
||||||
{
|
|
||||||
key: 'code',
|
|
||||||
type: 'code'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
run(msg, { code }) {
|
|
||||||
if (code.lang && code.lang !== 'js') return msg.reply('I can only beautify JavaScript.');
|
|
||||||
return msg.reply(`\`\`\`js\n${beautify(code.code)}\n\`\`\``);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
const Command = require('../../framework/Command');
|
|
||||||
const { MessageEmbed } = require('discord.js');
|
|
||||||
const logos = require('../../assets/json/logos');
|
|
||||||
const { Linter } = require('eslint');
|
|
||||||
const linter = new Linter();
|
|
||||||
const rules = linter.getRules();
|
|
||||||
|
|
||||||
module.exports = class LintRuleCommand extends Command {
|
|
||||||
constructor(client) {
|
|
||||||
super(client, {
|
|
||||||
name: 'lint-rule',
|
|
||||||
aliases: ['eslint-rule', 'linter-rule'],
|
|
||||||
group: 'code',
|
|
||||||
memberName: 'lint-rule',
|
|
||||||
description: 'Responds with information on an ESLint rule.',
|
|
||||||
clientPermissions: ['EMBED_LINKS'],
|
|
||||||
args: [
|
|
||||||
{
|
|
||||||
key: 'rule',
|
|
||||||
type: 'string',
|
|
||||||
parse: rule => rule.toLowerCase().replaceAll(' ', '-')
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
run(msg, { rule }) {
|
|
||||||
if (!rules.has(rule)) return msg.say('Could not find any results.');
|
|
||||||
const data = rules.get(rule).meta;
|
|
||||||
const embed = new MessageEmbed()
|
|
||||||
.setAuthor('ESLint', logos.eslint, 'https://eslint.org/')
|
|
||||||
.setColor(0x3A33D1)
|
|
||||||
.setTitle(rule)
|
|
||||||
.setURL(data.docs.url)
|
|
||||||
.setDescription(data.docs.description);
|
|
||||||
return msg.embed(embed);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
@@ -1,49 +0,0 @@
|
|||||||
const Command = require('../../framework/Command');
|
|
||||||
const { Linter } = require('eslint');
|
|
||||||
const linter = new Linter();
|
|
||||||
const { stripIndents } = require('common-tags');
|
|
||||||
const { trimArray } = require('../../util/Util');
|
|
||||||
const { goodMessages, badMessages, defaultConfig } = require('../../assets/json/lint');
|
|
||||||
|
|
||||||
module.exports = class LintCommand extends Command {
|
|
||||||
constructor(client) {
|
|
||||||
super(client, {
|
|
||||||
name: 'lint',
|
|
||||||
aliases: ['eslint', 'linter'],
|
|
||||||
group: 'code',
|
|
||||||
memberName: 'lint',
|
|
||||||
description: 'Lints code using ESLint.',
|
|
||||||
clientPermissions: ['READ_MESSAGE_HISTORY'],
|
|
||||||
args: [
|
|
||||||
{
|
|
||||||
key: 'code',
|
|
||||||
type: 'code'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
run(msg, { code }) {
|
|
||||||
if (!code.lang || ['js', 'javascript'].includes(code.lang)) {
|
|
||||||
const errors = linter.verify(code.code, defaultConfig);
|
|
||||||
if (!errors.length) return msg.reply(goodMessages[Math.floor(Math.random() * goodMessages.length)]);
|
|
||||||
const errorMap = trimArray(errors.map(err => `\`[${err.line}:${err.column}] ${err.message}\``));
|
|
||||||
return msg.reply(stripIndents`
|
|
||||||
${badMessages[Math.floor(Math.random() * badMessages.length)]}
|
|
||||||
${errorMap.join('\n')}
|
|
||||||
`);
|
|
||||||
}
|
|
||||||
if (code.lang === 'json') {
|
|
||||||
try {
|
|
||||||
JSON.parse(code.code);
|
|
||||||
return msg.reply(goodMessages[Math.floor(Math.random() * goodMessages.length)]);
|
|
||||||
} catch (err) {
|
|
||||||
return msg.reply(stripIndents`
|
|
||||||
${badMessages[Math.floor(Math.random() * badMessages.length)]}
|
|
||||||
\`${err.name}: ${err.message}\`
|
|
||||||
`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return msg.reply('I don\'t know how to lint that language.');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
@@ -11,7 +11,7 @@ module.exports = class GithubCommand extends Command {
|
|||||||
super(client, {
|
super(client, {
|
||||||
name: 'github',
|
name: 'github',
|
||||||
aliases: ['repo', 'gh', 'github-repo', 'gh-repo'],
|
aliases: ['repo', 'gh', 'github-repo', 'gh-repo'],
|
||||||
group: 'code',
|
group: 'search',
|
||||||
memberName: 'github',
|
memberName: 'github',
|
||||||
description: 'Responds with information on a GitHub repository.',
|
description: 'Responds with information on a GitHub repository.',
|
||||||
clientPermissions: ['EMBED_LINKS'],
|
clientPermissions: ['EMBED_LINKS'],
|
||||||
@@ -9,7 +9,7 @@ module.exports = class NPMCommand extends Command {
|
|||||||
constructor(client) {
|
constructor(client) {
|
||||||
super(client, {
|
super(client, {
|
||||||
name: 'npm',
|
name: 'npm',
|
||||||
group: 'code',
|
group: 'search',
|
||||||
memberName: 'npm',
|
memberName: 'npm',
|
||||||
description: 'Responds with information on an NPM package.',
|
description: 'Responds with information on an NPM package.',
|
||||||
clientPermissions: ['EMBED_LINKS'],
|
clientPermissions: ['EMBED_LINKS'],
|
||||||
@@ -32,7 +32,7 @@ module.exports = class GenerateCreditCommand extends Command {
|
|||||||
}).join('\n');
|
}).join('\n');
|
||||||
})
|
})
|
||||||
.filter(cmds => cmds);
|
.filter(cmds => cmds);
|
||||||
const file = Buffer.from(`## Credits\n### NPM Packages\n${npm}\n### Other Credits\n${list.join('\n')}`);
|
const file = Buffer.from(`## Credits\n### NPM Packages\n${npm}\n\n### Other Credits\n${list.join('\n')}`);
|
||||||
await msg.direct({ files: [{ attachment: file, name: 'credits.txt' }] });
|
await msg.direct({ files: [{ attachment: file, name: 'credits.txt' }] });
|
||||||
return msg.say('📬 Sent `credits.txt` to your DMs!');
|
return msg.say('📬 Sent `credits.txt` to your DMs!');
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,14 @@
|
|||||||
|
const { default: eslintPluginJsonc } = require('eslint-plugin-jsonc');
|
||||||
|
const { default: js } = require('@eslint/js');
|
||||||
|
const amber = require('eslint-config-amber');
|
||||||
|
|
||||||
|
module.exports = [
|
||||||
|
...eslintPluginJsonc.configs['flat/recommended-with-json'],
|
||||||
|
{
|
||||||
|
files: ['**/*.js'],
|
||||||
|
rules: {
|
||||||
|
...js.configs.recommended.rules,
|
||||||
|
...amber.rules
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
+4
-13
@@ -6,7 +6,7 @@
|
|||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "npm run lint",
|
"test": "npm run lint",
|
||||||
"lint": "eslint . --ext .js --ext .json",
|
"lint": "eslint .",
|
||||||
"start": "node Xiao.js"
|
"start": "node Xiao.js"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
@@ -50,7 +50,6 @@
|
|||||||
"discord.js": "^13.17.1",
|
"discord.js": "^13.17.1",
|
||||||
"dotenv": "^16.4.5",
|
"dotenv": "^16.4.5",
|
||||||
"emoji-regex": "^10.3.0",
|
"emoji-regex": "^10.3.0",
|
||||||
"eslint": "^8.57.0",
|
|
||||||
"fen-validator": "^2.0.1",
|
"fen-validator": "^2.0.1",
|
||||||
"font-finder": "^1.1.0",
|
"font-finder": "^1.1.0",
|
||||||
"gifencoder": "^2.0.1",
|
"gifencoder": "^2.0.1",
|
||||||
@@ -58,7 +57,6 @@
|
|||||||
"html-entities": "^2.5.2",
|
"html-entities": "^2.5.2",
|
||||||
"image-to-ascii": "^3.2.0",
|
"image-to-ascii": "^3.2.0",
|
||||||
"ioredis": "^5.3.2",
|
"ioredis": "^5.3.2",
|
||||||
"js-beautify": "^1.15.1",
|
|
||||||
"js-chess-engine": "^1.0.2",
|
"js-chess-engine": "^1.0.2",
|
||||||
"jszip": "^3.10.1",
|
"jszip": "^3.10.1",
|
||||||
"kuroshiro": "^1.2.0",
|
"kuroshiro": "^1.2.0",
|
||||||
@@ -96,16 +94,9 @@
|
|||||||
"zlib-sync": "^0.1.9"
|
"zlib-sync": "^0.1.9"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@eslint/js": "^9.0.0",
|
||||||
|
"eslint": "^9.0.0",
|
||||||
"eslint-config-amber": "^2.0.4",
|
"eslint-config-amber": "^2.0.4",
|
||||||
"eslint-plugin-json": "^3.1.0"
|
"eslint-plugin-jsonc": "^2.15.0"
|
||||||
},
|
|
||||||
"eslintConfig": {
|
|
||||||
"extends": [
|
|
||||||
"amber",
|
|
||||||
"plugin:json/recommended"
|
|
||||||
],
|
|
||||||
"plugins": [
|
|
||||||
"json"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user