1
0
mirror of https://github.com/toast-ts/Daggerbot-TS.git synced 2024-11-18 00:31:00 -05:00

Compare commits

..

No commits in common. "a862564248edcd5f63107617b57e48da951aed8e" and "ab9e88c263849f6b0b1a46fd3a7e18f96c649951" have entirely different histories.

2 changed files with 43 additions and 30 deletions

View File

@ -131,7 +131,6 @@ export default class Developer {
client.users.cache.get(member.id).send(`${message}\n╰ ${interaction.member.displayName}`).then(()=>int.edit(`Successfully sent a DM to **${member.user.username}** with the following message:\n\`\`\`${message}\`\`\``)).catch((e:Error)=>int.edit(`\`${e.message}\``)) client.users.cache.get(member.id).send(`${message}\n╰ ${interaction.member.displayName}`).then(()=>int.edit(`Successfully sent a DM to **${member.user.username}** with the following message:\n\`\`\`${message}\`\`\``)).catch((e:Error)=>int.edit(`\`${e.message}\``))
}, },
modify_rank_msgs: async()=>{ modify_rank_msgs: async()=>{
if (interaction.guildId !== client.config.dcServer.id) return interaction.reply({content: 'This command is only available in the main server.', ephemeral: true});
const member = interaction.options.getMember('member'); const member = interaction.options.getMember('member');
const messages = interaction.options.getInteger('new-message-count'); const messages = interaction.options.getInteger('new-message-count');
const oldData = await client.userLevels.fetchUser(member.id); const oldData = await client.userLevels.fetchUser(member.id);
@ -142,6 +141,7 @@ export default class Developer {
`Successfully modified the message count of **${member.displayName}**`, `Successfully modified the message count of **${member.displayName}**`,
`╰ Old: **${oldData.dataValues.messages.toLocaleString('en-US')}**`, `╰ Old: **${oldData.dataValues.messages.toLocaleString('en-US')}**`,
`╰ New: **${newData.messages.toLocaleString('en-US')}**`, `╰ New: **${newData.messages.toLocaleString('en-US')}**`,
`╰ Difference: **${(newData.messages - oldData.dataValues.messages).toLocaleString('en-US')}**`,
'Although if you set the number too high or low, it will have a bigger impact on the leaderboard graph.' 'Although if you set the number too high or low, it will have a bigger impact on the leaderboard graph.'
)) ))
]}) ]})

View File

@ -2,19 +2,9 @@ import {createCanvas, Canvas, CanvasRenderingContext2D} from 'canvas';
import {Config} from 'src/interfaces'; import {Config} from 'src/interfaces';
import ConfigHelper from '../helpers/ConfigHelper.js'; import ConfigHelper from '../helpers/ConfigHelper.js';
export default class CanvasBuilder { export default class CanvasBuilder {
private readonly canvas: Canvas; private canvas: Canvas;
private readonly ctx: CanvasRenderingContext2D; private ctx: CanvasRenderingContext2D;
private readonly config: Config; private config: Config;
private readonly palette = {
// Color palette for the graph -- The variables are named exactly what it shows in graph to make it easier to be referenced to.
oddHorizontal: '#555B63',
evenHorizontal: '#3E4245',
background: '#111111',
textColor: '#FFFFFF',
redLine: '#E62C3B',
yellowLine: '#FFEA00',
greenLine: '#57F287'
};
constructor() { constructor() {
this.canvas = createCanvas(1500, 750); this.canvas = createCanvas(1500, 750);
@ -23,11 +13,20 @@ export default class CanvasBuilder {
} }
public async generateGraph(data:number[], type:'players'|'leaderboard'):Promise<Canvas> { public async generateGraph(data:number[], type:'players'|'leaderboard'):Promise<Canvas> {
// Handle negative // Color layout for the graph -- The variables are named exactly what it shows in graph to make it easier to be referenced to.
for (const [i, change] of data.entries()) if (change < 0) data[i] = data[i - 1] || data[i + 1] || 0; let oddHorizontal = '#555B63';
let evenHorizontal = '#3E4245';
let background = '#111111';
let textColor = '#FFFFFF';
let redLine = '#E62C3B';
let yellowLine = '#FFEA00';
let greenLine = '#57F287';
const LBdataFirst = Math.ceil(Math.max(...data) * 10 ** (-Math.max(...data).toString().split('').length + 2)) * 10 ** (Math.max(...data).toString().split('').length - 2) // Handle negative
const LBdataSecond = Math.ceil(Math.max(...data) * 10 ** (-Math.max(...data).toString().split('').length + 3)) * 10 ** (Math.max(...data).toString().split('').length - 3) for (const [i, change] of data.entries()) if (change as number < 0) data[i] = data[i - 1] || data[i + 1] || 0;
const LBdataFirst = Math.ceil(Math.max(...data) * 10 ** (-Math.max(...data).toString().split('').length + 1)) * 10 ** (Math.max(...data).toString().split('').length - 1)
const LBdataSecond = Math.ceil(Math.max(...data) * 10 ** (-Math.max(...data).toString().split('').length + 2)) * 10 ** (Math.max(...data).toString().split('').length - 2)
const firstTop = type === 'leaderboard' ? LBdataFirst : 16; const firstTop = type === 'leaderboard' ? LBdataFirst : 16;
const secondTop = type === 'leaderboard' ? LBdataSecond : 16; const secondTop = type === 'leaderboard' ? LBdataSecond : 16;
@ -35,7 +34,7 @@ export default class CanvasBuilder {
const origin = [15, 65]; const origin = [15, 65];
const size = [1300, 630]; const size = [1300, 630];
const nodeWidth = size[0] / (data.length - 1); const nodeWidth = size[0] / (data.length - 1);
this.ctx.fillStyle = this.palette.background; this.ctx.fillStyle = background;
this.ctx.fillRect(0, 0, this.canvas.width, this.canvas.height); this.ctx.fillRect(0, 0, this.canvas.width, this.canvas.height);
// Grey horizontal lines // Grey horizontal lines
@ -48,20 +47,33 @@ export default class CanvasBuilder {
} }
const chosenInterval = intervalCandidates.sort((a,b)=>b[2]-a[2])[0]; const chosenInterval = intervalCandidates.sort((a,b)=>b[2]-a[2])[0];
let prevY:number[] = []; let prevY:number[] = [];
this.ctx.strokeStyle = this.palette.oddHorizontal; this.ctx.strokeStyle = oddHorizontal;
for (let i = 0; i <= chosenInterval[1]; i++) { if (type === 'leaderboard') for (let i = 0; i <= chosenInterval[1]; i++) {
const y = origin[1] + size[1] - (i * (chosenInterval[0] / secondTop) * size[1]); const y = origin[1] + size[1] - (i * (chosenInterval[0] / secondTop) * size[1]);
if (y < origin[1]) continue; if (y < origin[1]) continue;
const even = ((i + 1) % 2) === 0; const even = ((i + 1) % 2) === 0;
if (even) this.ctx.strokeStyle = this.palette.evenHorizontal; if (even) this.ctx.strokeStyle = evenHorizontal;
this.ctx.beginPath(); this.ctx.beginPath();
this.ctx.lineTo(origin[0], y); this.ctx.lineTo(origin[0], y);
this.ctx.lineTo(origin[0] + size[0], y); this.ctx.lineTo(origin[0] + size[0], y);
this.ctx.stroke(); this.ctx.stroke();
this.ctx.closePath(); this.ctx.closePath();
if (even) this.ctx.strokeStyle = this.palette.oddHorizontal; if (even) this.ctx.strokeStyle = oddHorizontal;
prevY.push(y, i * chosenInterval[0]); // It didn't seem to take effect when I tested on leaderboard, so using push instead for both players and leaderboard. prevY = [y, i * chosenInterval[0]];
}
else for (let i = 0; i < data.length; i++) {
const y = origin[1] + size[1] - (i * (chosenInterval[0] / secondTop) * size[1]);
if (y < origin[1]) continue;
const even = ((i + 1) % 2) === 0;
if (even) this.ctx.strokeStyle = evenHorizontal;
this.ctx.beginPath();
this.ctx.lineTo(origin[0], y);
this.ctx.lineTo(origin[0] + size[0], y);
this.ctx.stroke();
this.ctx.closePath();
if (even) this.ctx.strokeStyle = oddHorizontal;
prevY.push(y, i * chosenInterval[0]);
} }
// 30 day/minute mark // 30 day/minute mark
@ -75,14 +87,15 @@ export default class CanvasBuilder {
this.ctx.setLineDash([]); this.ctx.setLineDash([]);
// Draw points // Draw points
this.ctx.strokeStyle = type === 'leaderboard' ? this.config.embedColor as string : null; const isLeaderboard =()=>type === 'leaderboard' ? this.config.embedColor as string : null;
this.ctx.fillStyle = type === 'leaderboard' ? this.config.embedColor as string : null; this.ctx.strokeStyle = isLeaderboard();
this.ctx.fillStyle = isLeaderboard();
this.ctx.lineWidth = 5; this.ctx.lineWidth = 5;
const gradient = this.ctx.createLinearGradient(0, origin[1], 0, origin[1] + size[1]); const gradient = this.ctx.createLinearGradient(0, origin[1], 0, origin[1] + size[1]);
gradient.addColorStop(1 / 16, this.palette.redLine); gradient.addColorStop(1 / 16, redLine);
gradient.addColorStop(5 / 16, this.palette.yellowLine); gradient.addColorStop(5 / 16, yellowLine);
gradient.addColorStop(12 / 16, this.palette.greenLine); gradient.addColorStop(12 / 16, greenLine);
let lastCoordinates:number[] = []; let lastCoordinates:number[] = [];
for (let [i, currentValue] of data.entries()) { for (let [i, currentValue] of data.entries()) {
@ -120,7 +133,7 @@ export default class CanvasBuilder {
// Draw text // Draw text
this.ctx.font = '400 ' + textSize + 'px sans-serif'; this.ctx.font = '400 ' + textSize + 'px sans-serif';
this.ctx.fillStyle = this.palette.textColor; this.ctx.fillStyle = textColor;
// Highest value // Highest value
this.ctx.fillText(type === 'leaderboard' this.ctx.fillText(type === 'leaderboard'