mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-27 14:18:36 +02:00
Periodic Table download
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -1,7 +1,20 @@
|
|||||||
const Command = require('../../framework/Command');
|
const Command = require('../../framework/Command');
|
||||||
|
const request = require('node-superfetch');
|
||||||
const { createCanvas, loadImage } = require('canvas');
|
const { createCanvas, loadImage } = require('canvas');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const { elements, colors } = require('../../assets/json/periodic-table');
|
const colors = {
|
||||||
|
Solid: 'black',
|
||||||
|
Liquid: 'blue',
|
||||||
|
Gas: 'green'
|
||||||
|
};
|
||||||
|
const batman = {
|
||||||
|
name: 'Batman',
|
||||||
|
mass: 5.736e+28,
|
||||||
|
number: 0,
|
||||||
|
period: 'Gotham City',
|
||||||
|
phase: 'Solid',
|
||||||
|
symbol: '🦇'
|
||||||
|
};
|
||||||
|
|
||||||
module.exports = class PeriodicTableCommand extends Command {
|
module.exports = class PeriodicTableCommand extends Command {
|
||||||
constructor(client) {
|
constructor(client) {
|
||||||
@@ -36,23 +49,26 @@ module.exports = class PeriodicTableCommand extends Command {
|
|||||||
type: 'string',
|
type: 'string',
|
||||||
validate: element => {
|
validate: element => {
|
||||||
const num = Number.parseInt(element, 10);
|
const num = Number.parseInt(element, 10);
|
||||||
if (!Number.isNaN(num) && num >= 0 && num <= elements.length - 1) return true;
|
if (!Number.isNaN(num) && num >= 0 && num <= this.table.length - 1) return true;
|
||||||
const search = element.toString().toLowerCase();
|
const search = element.toString().toLowerCase();
|
||||||
if (elements.find(e => e.name.toLowerCase() === search || e.symbol.toLowerCase() === search)) return true;
|
if (this.table.find(e => e.name.toLowerCase() === search || e.symbol.toLowerCase() === search)) return true;
|
||||||
return 'Invalid element, please enter a valid element symbol, name, or atomic number.';
|
return 'Invalid element, please enter a valid element symbol, name, or atomic number.';
|
||||||
},
|
},
|
||||||
parse: element => {
|
parse: element => {
|
||||||
const num = Number.parseInt(element, 10);
|
const num = Number.parseInt(element, 10);
|
||||||
if (!Number.isNaN(num)) return elements[num];
|
if (!Number.isNaN(num)) return this.table[num];
|
||||||
const search = element.toLowerCase();
|
const search = element.toLowerCase();
|
||||||
return elements.find(e => e.name.toLowerCase() === search || e.symbol.toLowerCase() === search);
|
return this.table.find(e => e.name.toLowerCase() === search || e.symbol.toLowerCase() === search);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.table = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
async run(msg, { element }) {
|
async run(msg, { element }) {
|
||||||
|
if (!this.table) await this.fetchTable();
|
||||||
const canvas = createCanvas(500, 500);
|
const canvas = createCanvas(500, 500);
|
||||||
const ctx = canvas.getContext('2d');
|
const ctx = canvas.getContext('2d');
|
||||||
ctx.fillStyle = 'black';
|
ctx.fillStyle = 'black';
|
||||||
@@ -61,8 +77,8 @@ module.exports = class PeriodicTableCommand extends Command {
|
|||||||
ctx.fillRect(10, 10, canvas.width - 20, canvas.height - 20);
|
ctx.fillRect(10, 10, canvas.width - 20, canvas.height - 20);
|
||||||
ctx.textAlign = 'center';
|
ctx.textAlign = 'center';
|
||||||
if (element.number === 0) {
|
if (element.number === 0) {
|
||||||
const batman = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'batman.png'));
|
const batmanImg = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'batman.png'));
|
||||||
ctx.drawImage(batman, 100, 166);
|
ctx.drawImage(batmanImg, 100, 166);
|
||||||
} else {
|
} else {
|
||||||
ctx.font = this.client.fonts.get('Noto-Regular.ttf').toCanvasString(210);
|
ctx.font = this.client.fonts.get('Noto-Regular.ttf').toCanvasString(210);
|
||||||
ctx.fillStyle = colors[element.phase] || 'gray';
|
ctx.fillStyle = colors[element.phase] || 'gray';
|
||||||
@@ -81,4 +97,13 @@ module.exports = class PeriodicTableCommand extends Command {
|
|||||||
{ files: [{ attachment: canvas.toBuffer(), name: `${element.name}.png` }] }
|
{ files: [{ attachment: canvas.toBuffer(), name: `${element.name}.png` }] }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fetchTable() {
|
||||||
|
if (this.table) return this.table;
|
||||||
|
const { text } = await request
|
||||||
|
.get('https://raw.githubusercontent.com/Bowserinator/Periodic-Table-JSON/master/PeriodicTableJSON.json');
|
||||||
|
this.table = JSON.parse(text).elements;
|
||||||
|
this.table.elements.unshift(batman);
|
||||||
|
return this.table;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user