blob: b8349928b8d46d7d223145fde5f98919e4dd941c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
import { Snowflake } from 'discord.js';
import { DataTypes, Sequelize } from 'sequelize';
import { BaseModel } from './BaseModel';
export interface LevelModel {
id: Snowflake;
xp: number;
}
export interface LevelModelCreationAttributes {
id: Snowflake;
xp?: number;
}
export class Level extends BaseModel<LevelModel, LevelModelCreationAttributes> {
/**
* The user's id.
*/
public id: Snowflake;
/**
* The user's xp.
*/
public xp: number;
get level(): number {
return Level.convertXpToLevel(this.xp);
}
static initModel(sequelize: Sequelize): void {
Level.init(
{
id: {
type: DataTypes.STRING,
primaryKey: true,
allowNull: false
},
xp: {
type: DataTypes.INTEGER,
allowNull: false,
defaultValue: 0
}
},
{ sequelize: sequelize }
);
}
static convertXpToLevel(xp: number): number {
let i = 1;
let lvl: number;
// eslint-disable-next-line no-constant-condition
while (true) {
const neededXp = Level.convertLevelToXp(i);
if (neededXp > xp) {
lvl = i;
break;
} else {
i++;
}
}
return lvl - 1; // I have to do this don't question it ok
}
static convertLevelToXp(level: number): number {
let xp = 0;
for (let i = 0; i < level; i++) {
xp += 100 * i + 75;
}
return xp;
}
static genRandomizedXp(): number {
return Math.floor(Math.random() * (40 - 15 + 1)) + 15;
}
}
|