simply-xp 1.1.5-beta → 1.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/src/roleSetup.js CHANGED
@@ -1,124 +1,122 @@
1
- let Discord = require('discord.js')
2
- const lrole = require('../src/models/lvlrole.js')
3
-
4
- class roleSetup {
5
- /**
6
- * @param {Discord.Client} client
7
- * @param {string} guildID
8
- * @param {import('../index').lvladdOptions} options
9
- */
10
-
11
- static async add(client, guildID, options = []) {
12
- let rol = await lrole.findOne({
13
- gid: guildID,
14
- lvlrole: {
15
- lvl: options.level,
16
- role: options.role
17
- }
18
- })
19
-
20
- let g = client.guilds.cache.get(guildID)
21
-
22
- let roll = g.roles.cache.find((r) => r.id === options.role)
23
-
24
- if (roll) {
25
- if (rol) throw new Error('Level Already Exist. Use delete')
26
- else if (!rol) {
27
- let newrol = await lrole.findOne({
28
- gid: guildID
29
- })
30
-
31
- if (!newrol) {
32
- newrol = new lrole({
33
- gid: guildID,
34
- lvlrole: []
35
- })
36
-
37
- await newrol.save()
38
- }
39
-
40
- newrol.lvlrole.push({ lvl: options.level, role: options.role })
41
-
42
- await newrol
43
- .save()
44
- .catch((e) =>
45
- console.log(`[XP] Failed to add lvlrole to database | ${e}`)
46
- )
47
-
48
- return true
49
- }
50
- } else {
51
- throw new Error(
52
- 'Role ID is invalid. | ' +
53
- `Guild ID: ${guildID} | Role ID: ${options.role}`
54
- )
55
- }
56
- }
57
-
58
- /**
59
- * @param {Discord.Client} client
60
- * @param {string} guildID
61
- * @param {import('../index').lvlremoveOptions} options
62
- */
63
-
64
- static async remove(client, guildID, options = []) {
65
- let rol = await lrole.find({
66
- gid: guildID
67
- })
68
-
69
- if (!rol || rol.length === 0)
70
- throw new Error('Level role with this level does not exist')
71
- rol = rol[0].lvlrole.find((item) => item.lvl === options.level) || undefined
72
-
73
- if (rol) {
74
- let newrol = await lrole.findOneAndUpdate(
75
- {
76
- gid: guildID
77
- },
78
- {
79
- $pull: { lvlrole: { lvl: options.level } }
80
- }
81
- )
82
-
83
- return true
84
- } else throw new Error('Level role with this level does not exist')
85
- }
86
-
87
- /**
88
- * @param {Discord.Client} client
89
- * @param {string} guildID
90
- */
91
-
92
- static async fetch(client, guildID) {
93
- let rol = await lrole.find({
94
- gid: guildID
95
- })
96
-
97
- if (!rol || rol.length === 0)
98
- throw new Error('There is no levelRole in this guild')
99
-
100
- return rol[0].lvlrole
101
- }
102
-
103
- /**
104
- * @param {Discord.Client} client
105
- * @param {string} guildID
106
- * @param {string} level
107
- */
108
-
109
- static async find(client, guildID, level) {
110
- let rol = await lrole.find({
111
- gid: guildID
112
- })
113
-
114
- if (!rol || rol.length === 0)
115
- throw new Error('There is no levelRole in this guild')
116
- rol = rol[0].lvlrole.find((item) => item.lvl === level) || undefined
117
-
118
- if (rol) {
119
- return rol
120
- }
121
- }
122
- }
123
-
124
- module.exports = roleSetup
1
+ let Discord = require('discord.js')
2
+ const lrole = require('../src/models/lvlrole.js')
3
+
4
+ class roleSetup {
5
+ /**
6
+ * @param {Discord.Client} client
7
+ * @param {string} guildID
8
+ * @param {import('../index').lvladdOptions} options
9
+ */
10
+
11
+ static async add(client, guildID, options = []) {
12
+ let rol = await lrole.findOne({
13
+ gid: guildID,
14
+ lvlrole: {
15
+ lvl: options.level,
16
+ role: options.role
17
+ }
18
+ })
19
+
20
+ let g = client.guilds.cache.get(guildID)
21
+
22
+ let roll = g.roles.cache.find((r) => r.id === options.role)
23
+
24
+ if (roll) {
25
+ if (rol) throw new Error('Level Already Exist. Use delete')
26
+ else if (!rol) {
27
+ let newrol = await lrole.findOne({
28
+ gid: guildID
29
+ })
30
+
31
+ if (!newrol) {
32
+ newrol = new lrole({
33
+ gid: guildID,
34
+ lvlrole: []
35
+ })
36
+
37
+ await newrol.save()
38
+ }
39
+
40
+ newrol.lvlrole.push({ lvl: options.level, role: options.role })
41
+
42
+ await newrol
43
+ .save()
44
+ .catch((e) =>
45
+ console.log(`[XP] Failed to add lvlrole to database | ${e}`)
46
+ )
47
+
48
+ return true
49
+ }
50
+ } else {
51
+ throw new Error(
52
+ 'Role ID is invalid. | ' +
53
+ `Guild ID: ${guildID} | Role ID: ${options.role}`
54
+ )
55
+ }
56
+ }
57
+
58
+ /**
59
+ * @param {Discord.Client} client
60
+ * @param {string} guildID
61
+ * @param {import('../index').lvlremoveOptions} options
62
+ */
63
+
64
+ static async remove(client, guildID, options = []) {
65
+ let rol = await lrole.find({
66
+ gid: guildID
67
+ })
68
+
69
+ if (!rol || rol.length === 0)
70
+ throw new Error('Level role with this level does not exist')
71
+ rol = rol[0].lvlrole.find((item) => item.lvl === options.level) || undefined
72
+
73
+ if (rol) {
74
+ let newrol = await lrole.findOneAndUpdate(
75
+ {
76
+ gid: guildID
77
+ },
78
+ {
79
+ $pull: { lvlrole: { lvl: options.level } }
80
+ }
81
+ )
82
+
83
+ return true
84
+ } else throw new Error('Level role with this level does not exist')
85
+ }
86
+
87
+ /**
88
+ * @param {Discord.Client} client
89
+ * @param {string} guildID
90
+ */
91
+
92
+ static async fetch(client, guildID) {
93
+ let rol = await lrole.find({
94
+ gid: guildID
95
+ })
96
+
97
+ if (!rol || rol.length === 0) return
98
+
99
+ return rol[0].lvlrole
100
+ }
101
+
102
+ /**
103
+ * @param {Discord.Client} client
104
+ * @param {string} guildID
105
+ * @param {string} level
106
+ */
107
+
108
+ static async find(client, guildID, level) {
109
+ let rol = await lrole.find({
110
+ gid: guildID
111
+ })
112
+
113
+ if (!rol || rol.length === 0) return
114
+ rol = rol[0].lvlrole.find((item) => item.lvl === level) || undefined
115
+
116
+ if (rol) {
117
+ return rol
118
+ }
119
+ }
120
+ }
121
+
122
+ module.exports = roleSetup
package/src/setLevel.js CHANGED
@@ -1,71 +1,71 @@
1
- let Discord = require('discord.js')
2
- const levels = require('../src/models/level.js')
3
- let { roleSetup } = require('../simplyxp')
4
-
5
- /**
6
- * @param {Discord.Message} message
7
- * @param {string} userID
8
- * @param {string} guildID
9
- * @param {string} level
10
- */
11
- async function setLevel(message, userID, guildID, level) {
12
- if (!userID) throw new Error('[XP] User ID was not provided.')
13
-
14
- if (!guildID) throw new Error('[XP] Guild ID was not provided.')
15
-
16
- if (!level) throw new Error('[XP] Level amount is not provided.')
17
-
18
- let { client } = message
19
-
20
- const user = await levels.findOne({ user: userID, guild: guildID })
21
-
22
- if (!user) {
23
- const newUser = new levels({
24
- user: userID,
25
- guild: guildID,
26
- xp: 0,
27
- level: 0
28
- })
29
-
30
- await newUser
31
- .save()
32
- .catch((e) => console.log(`[XP] Failed to save new user to database`))
33
-
34
- let xp = (level * 10) ** 2
35
-
36
- return {
37
- level: level,
38
- exp: xp
39
- }
40
- }
41
- let level1 = user.level
42
-
43
- user.xp = (level * 10) ** 2
44
- user.level = Math.floor(0.1 * Math.sqrt(user.xp))
45
-
46
- await user
47
- .save()
48
- .catch((e) =>
49
- console.log(`[XP] Failed to set Level | User: ${userID} | Err: ${e}`)
50
- )
51
-
52
- if (level1 !== level) {
53
- let data = {
54
- xp: user.xp,
55
- level: user.level,
56
- userID,
57
- guildID
58
- }
59
-
60
- let role = await roleSetup.find(client, guildID, level)
61
-
62
- client.emit('levelUp', message, data, role)
63
- }
64
-
65
- return {
66
- level: user.level,
67
- xp: user.xp
68
- }
69
- }
70
-
71
- module.exports = setLevel
1
+ let Discord = require('discord.js')
2
+ const levels = require('../src/models/level.js')
3
+ let { roleSetup } = require('../simplyxp')
4
+
5
+ /**
6
+ * @param {Discord.Message} message
7
+ * @param {string} userID
8
+ * @param {string} guildID
9
+ * @param {string} level
10
+ */
11
+ async function setLevel(message, userID, guildID, level) {
12
+ if (!userID) throw new Error('[XP] User ID was not provided.')
13
+
14
+ if (!guildID) throw new Error('[XP] Guild ID was not provided.')
15
+
16
+ if (!level) throw new Error('[XP] Level amount is not provided.')
17
+
18
+ let { client } = message
19
+
20
+ const user = await levels.findOne({ user: userID, guild: guildID })
21
+
22
+ if (!user) {
23
+ const newUser = new levels({
24
+ user: userID,
25
+ guild: guildID,
26
+ xp: 0,
27
+ level: 0
28
+ })
29
+
30
+ await newUser
31
+ .save()
32
+ .catch((e) => console.log(`[XP] Failed to save new user to database`))
33
+
34
+ let xp = (level * 10) ** 2
35
+
36
+ return {
37
+ level: level,
38
+ exp: xp
39
+ }
40
+ }
41
+ let level1 = user.level
42
+
43
+ user.xp = (level * 10) ** 2
44
+ user.level = Math.floor(0.1 * Math.sqrt(user.xp))
45
+
46
+ await user
47
+ .save()
48
+ .catch((e) =>
49
+ console.log(`[XP] Failed to set Level | User: ${userID} | Err: ${e}`)
50
+ )
51
+
52
+ if (level1 !== level) {
53
+ let data = {
54
+ xp: user.xp,
55
+ level: user.level,
56
+ userID,
57
+ guildID
58
+ }
59
+
60
+ let role = await roleSetup.find(client, guildID, level)
61
+
62
+ client.emit('levelUp', message, data, role)
63
+ }
64
+
65
+ return {
66
+ level: user.level,
67
+ xp: user.xp
68
+ }
69
+ }
70
+
71
+ module.exports = setLevel
package/src/setXP.js CHANGED
@@ -1,51 +1,51 @@
1
- const levels = require('../src/models/level.js')
2
-
3
- /**
4
- * @param {string} userID
5
- * @param {string} guildID
6
- * @param {string} xp
7
- */
8
-
9
- async function setXP(userID, guildID, xp) {
10
- if (!userID) throw new Error('[XP] User ID was not provided.')
11
-
12
- if (!guildID) throw new Error('[XP] Guild ID was not provided.')
13
-
14
- if (!xp) throw new Error('[XP] XP amount is not provided.')
15
-
16
- if (Number(xp).toString() === 'NaN')
17
- throw new Error('[XP] XP amount is not a number.')
18
-
19
- const user = await levels.findOne({ user: userID, guild: guildID })
20
-
21
- let lvl = Math.floor(0.1 * Math.sqrt(xp))
22
-
23
- if (!user) {
24
- const newUser = new levels({
25
- user: userID,
26
- guild: guildID,
27
- xp: xp,
28
- level: lvl
29
- })
30
-
31
- await newUser
32
- .save()
33
- .catch((e) => console.log(`[XP] Failed to save new use to database`))
34
-
35
- return {
36
- xp: 0
37
- }
38
- }
39
- user.xp = xp
40
- user.level = Math.floor(0.1 * Math.sqrt(user.xp))
41
-
42
- await user
43
- .save()
44
- .catch((e) =>
45
- console.log(`[XP] Failed to set XP | User: ${userID} | Err: ${e}`)
46
- )
47
-
48
- return { xp }
49
- }
50
-
51
- module.exports = setXP
1
+ const levels = require('../src/models/level.js')
2
+
3
+ /**
4
+ * @param {string} userID
5
+ * @param {string} guildID
6
+ * @param {string} xp
7
+ */
8
+
9
+ async function setXP(userID, guildID, xp) {
10
+ if (!userID) throw new Error('[XP] User ID was not provided.')
11
+
12
+ if (!guildID) throw new Error('[XP] Guild ID was not provided.')
13
+
14
+ if (!xp) throw new Error('[XP] XP amount is not provided.')
15
+
16
+ if (Number(xp).toString() === 'NaN')
17
+ throw new Error('[XP] XP amount is not a number.')
18
+
19
+ const user = await levels.findOne({ user: userID, guild: guildID })
20
+
21
+ let lvl = Math.floor(0.1 * Math.sqrt(xp))
22
+
23
+ if (!user) {
24
+ const newUser = new levels({
25
+ user: userID,
26
+ guild: guildID,
27
+ xp: xp,
28
+ level: lvl
29
+ })
30
+
31
+ await newUser
32
+ .save()
33
+ .catch((e) => console.log(`[XP] Failed to save new use to database`))
34
+
35
+ return {
36
+ xp: 0
37
+ }
38
+ }
39
+ user.xp = xp
40
+ user.level = Math.floor(0.1 * Math.sqrt(user.xp))
41
+
42
+ await user
43
+ .save()
44
+ .catch((e) =>
45
+ console.log(`[XP] Failed to set XP | User: ${userID} | Err: ${e}`)
46
+ )
47
+
48
+ return { xp }
49
+ }
50
+
51
+ module.exports = setXP
Binary file
Binary file