@jubbio/core 1.0.0

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.
Files changed (83) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +166 -0
  3. package/dist/Client.d.ts +147 -0
  4. package/dist/Client.js +471 -0
  5. package/dist/builders/ActionRowBuilder.d.ts +53 -0
  6. package/dist/builders/ActionRowBuilder.js +68 -0
  7. package/dist/builders/ButtonBuilder.d.ts +77 -0
  8. package/dist/builders/ButtonBuilder.js +96 -0
  9. package/dist/builders/EmbedBuilder.d.ts +157 -0
  10. package/dist/builders/EmbedBuilder.js +199 -0
  11. package/dist/builders/ModalBuilder.d.ts +122 -0
  12. package/dist/builders/ModalBuilder.js +162 -0
  13. package/dist/builders/SelectMenuBuilder.d.ts +123 -0
  14. package/dist/builders/SelectMenuBuilder.js +165 -0
  15. package/dist/builders/SlashCommandBuilder.d.ts +197 -0
  16. package/dist/builders/SlashCommandBuilder.js +324 -0
  17. package/dist/builders/index.d.ts +9 -0
  18. package/dist/builders/index.js +26 -0
  19. package/dist/enums.d.ts +196 -0
  20. package/dist/enums.js +216 -0
  21. package/dist/index.d.ts +25 -0
  22. package/dist/index.js +128 -0
  23. package/dist/managers/BaseManager.d.ts +69 -0
  24. package/dist/managers/BaseManager.js +106 -0
  25. package/dist/managers/ChannelManager.d.ts +98 -0
  26. package/dist/managers/ChannelManager.js +209 -0
  27. package/dist/managers/GuildMemberManager.d.ts +74 -0
  28. package/dist/managers/GuildMemberManager.js +156 -0
  29. package/dist/managers/RoleManager.d.ts +84 -0
  30. package/dist/managers/RoleManager.js +207 -0
  31. package/dist/managers/index.d.ts +7 -0
  32. package/dist/managers/index.js +24 -0
  33. package/dist/rest/REST.d.ts +483 -0
  34. package/dist/rest/REST.js +805 -0
  35. package/dist/rest/index.d.ts +1 -0
  36. package/dist/rest/index.js +18 -0
  37. package/dist/sharding/ShardingManager.d.ts +179 -0
  38. package/dist/sharding/ShardingManager.js +375 -0
  39. package/dist/sharding/index.d.ts +4 -0
  40. package/dist/sharding/index.js +21 -0
  41. package/dist/structures/Channel.d.ts +120 -0
  42. package/dist/structures/Channel.js +224 -0
  43. package/dist/structures/Collection.d.ts +53 -0
  44. package/dist/structures/Collection.js +115 -0
  45. package/dist/structures/Guild.d.ts +59 -0
  46. package/dist/structures/Guild.js +90 -0
  47. package/dist/structures/GuildMember.d.ts +130 -0
  48. package/dist/structures/GuildMember.js +208 -0
  49. package/dist/structures/Interaction.d.ts +224 -0
  50. package/dist/structures/Interaction.js +404 -0
  51. package/dist/structures/Message.d.ts +93 -0
  52. package/dist/structures/Message.js +145 -0
  53. package/dist/structures/User.d.ts +37 -0
  54. package/dist/structures/User.js +65 -0
  55. package/dist/structures/index.d.ts +7 -0
  56. package/dist/structures/index.js +25 -0
  57. package/dist/structures.d.ts +1 -0
  58. package/dist/structures.js +19 -0
  59. package/dist/types.d.ts +255 -0
  60. package/dist/types.js +3 -0
  61. package/dist/utils/BitField.d.ts +66 -0
  62. package/dist/utils/BitField.js +138 -0
  63. package/dist/utils/Collection.d.ts +116 -0
  64. package/dist/utils/Collection.js +265 -0
  65. package/dist/utils/Collector.d.ts +152 -0
  66. package/dist/utils/Collector.js +314 -0
  67. package/dist/utils/DataResolver.d.ts +61 -0
  68. package/dist/utils/DataResolver.js +146 -0
  69. package/dist/utils/Formatters.d.ts +145 -0
  70. package/dist/utils/Formatters.js +213 -0
  71. package/dist/utils/IntentsBitField.d.ts +85 -0
  72. package/dist/utils/IntentsBitField.js +99 -0
  73. package/dist/utils/Partials.d.ts +105 -0
  74. package/dist/utils/Partials.js +149 -0
  75. package/dist/utils/PermissionsBitField.d.ts +118 -0
  76. package/dist/utils/PermissionsBitField.js +145 -0
  77. package/dist/utils/SnowflakeUtil.d.ts +63 -0
  78. package/dist/utils/SnowflakeUtil.js +93 -0
  79. package/dist/utils/Sweepers.d.ts +127 -0
  80. package/dist/utils/Sweepers.js +270 -0
  81. package/dist/utils/index.d.ts +13 -0
  82. package/dist/utils/index.js +30 -0
  83. package/package.json +37 -0
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+ /**
3
+ * Generic BitField class
4
+ * API compatible with Discord.js BitField
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.BitField = void 0;
8
+ /**
9
+ * Data structure for bit fields
10
+ */
11
+ class BitField {
12
+ /** The raw bits */
13
+ bitfield;
14
+ /** Flags for this bitfield (override in subclass) */
15
+ static Flags = {};
16
+ /** Default bit value */
17
+ static DefaultBit = 0n;
18
+ constructor(bits = BitField.DefaultBit) {
19
+ this.bitfield = this.constructor.resolve(bits);
20
+ }
21
+ /**
22
+ * Check if this bitfield has a bit
23
+ */
24
+ has(bit) {
25
+ const resolved = this.constructor.resolve(bit);
26
+ return (this.bitfield & resolved) === resolved;
27
+ }
28
+ /**
29
+ * Check if this bitfield has any of the bits
30
+ */
31
+ any(bits) {
32
+ const resolved = this.constructor.resolve(bits);
33
+ return (this.bitfield & resolved) !== 0n;
34
+ }
35
+ /**
36
+ * Add bits to this bitfield
37
+ */
38
+ add(...bits) {
39
+ let total = 0n;
40
+ for (const bit of bits) {
41
+ total |= this.constructor.resolve(bit);
42
+ }
43
+ this.bitfield |= total;
44
+ return this;
45
+ }
46
+ /**
47
+ * Remove bits from this bitfield
48
+ */
49
+ remove(...bits) {
50
+ let total = 0n;
51
+ for (const bit of bits) {
52
+ total |= this.constructor.resolve(bit);
53
+ }
54
+ this.bitfield &= ~total;
55
+ return this;
56
+ }
57
+ /**
58
+ * Serialize to array of flag names
59
+ */
60
+ toArray() {
61
+ const flags = this.constructor.Flags;
62
+ const result = [];
63
+ for (const [name, bit] of Object.entries(flags)) {
64
+ if (this.bitfield & bit) {
65
+ result.push(name);
66
+ }
67
+ }
68
+ return result;
69
+ }
70
+ /**
71
+ * Serialize to JSON
72
+ */
73
+ toJSON() {
74
+ return typeof this.bitfield === 'bigint'
75
+ ? this.bitfield.toString()
76
+ : this.bitfield;
77
+ }
78
+ /**
79
+ * Get string representation
80
+ */
81
+ toString() {
82
+ return this.bitfield.toString();
83
+ }
84
+ /**
85
+ * Get iterator
86
+ */
87
+ *[Symbol.iterator]() {
88
+ yield* this.toArray();
89
+ }
90
+ /**
91
+ * Freeze this bitfield
92
+ */
93
+ freeze() {
94
+ return Object.freeze(this);
95
+ }
96
+ /**
97
+ * Check equality
98
+ */
99
+ equals(other) {
100
+ return this.bitfield === this.constructor.resolve(other);
101
+ }
102
+ /**
103
+ * Clone this bitfield
104
+ */
105
+ clone() {
106
+ return new this.constructor(this.bitfield);
107
+ }
108
+ /**
109
+ * Resolve a bit to the numeric type
110
+ */
111
+ static resolve(bit) {
112
+ if (typeof bit === 'bigint' || typeof bit === 'number') {
113
+ return bit;
114
+ }
115
+ if (bit instanceof BitField) {
116
+ return bit.bitfield;
117
+ }
118
+ if (typeof bit === 'string') {
119
+ const resolved = this.Flags[bit];
120
+ if (resolved === undefined) {
121
+ throw new Error(`Unknown bit: ${bit}`);
122
+ }
123
+ return resolved;
124
+ }
125
+ if (Array.isArray(bit)) {
126
+ let result = this.DefaultBit;
127
+ for (const b of bit) {
128
+ const resolved = this.resolve(b);
129
+ result |= resolved;
130
+ }
131
+ return result;
132
+ }
133
+ throw new Error(`Invalid bit: ${bit}`);
134
+ }
135
+ }
136
+ exports.BitField = BitField;
137
+ exports.default = BitField;
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BitField.js","sourceRoot":"","sources":["../../src/utils/BitField.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Generic BitField class\r\n * API compatible with Discord.js BitField\r\n */\r\n\r\nexport type BitFieldResolvable<S extends string, N extends bigint | number> = \r\n  | N \r\n  | N[] \r\n  | S \r\n  | S[] \r\n  | BitField<S, N>;\r\n\r\n/**\r\n * Data structure for bit fields\r\n */\r\nexport class BitField<S extends string = string, N extends bigint | number = bigint> {\r\n  /** The raw bits */\r\n  public bitfield: N;\r\n\r\n  /** Flags for this bitfield (override in subclass) */\r\n  static Flags: Record<string, bigint | number> = {};\r\n\r\n  /** Default bit value */\r\n  static DefaultBit: bigint | number = 0n;\r\n\r\n  constructor(bits: BitFieldResolvable<S, N> = BitField.DefaultBit as N) {\r\n    this.bitfield = (this.constructor as typeof BitField).resolve<S, N>(bits);\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has a bit\r\n   */\r\n  has(bit: BitFieldResolvable<S, N>): boolean {\r\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bit);\r\n    return ((this.bitfield as bigint) & (resolved as bigint)) === (resolved as bigint);\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has any of the bits\r\n   */\r\n  any(bits: BitFieldResolvable<S, N>): boolean {\r\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bits);\r\n    return ((this.bitfield as bigint) & (resolved as bigint)) !== 0n;\r\n  }\r\n\r\n  /**\r\n   * Add bits to this bitfield\r\n   */\r\n  add(...bits: BitFieldResolvable<S, N>[]): this {\r\n    let total = 0n;\r\n    for (const bit of bits) {\r\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\r\n    }\r\n    (this.bitfield as bigint) |= total;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Remove bits from this bitfield\r\n   */\r\n  remove(...bits: BitFieldResolvable<S, N>[]): this {\r\n    let total = 0n;\r\n    for (const bit of bits) {\r\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\r\n    }\r\n    (this.bitfield as bigint) &= ~total;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Serialize to array of flag names\r\n   */\r\n  toArray(): S[] {\r\n    const flags = (this.constructor as typeof BitField).Flags;\r\n    const result: S[] = [];\r\n    \r\n    for (const [name, bit] of Object.entries(flags)) {\r\n      if ((this.bitfield as bigint) & (bit as bigint)) {\r\n        result.push(name as S);\r\n      }\r\n    }\r\n    \r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Serialize to JSON\r\n   */\r\n  toJSON(): string | number {\r\n    return typeof this.bitfield === 'bigint' \r\n      ? this.bitfield.toString() \r\n      : this.bitfield;\r\n  }\r\n\r\n  /**\r\n   * Get string representation\r\n   */\r\n  toString(): string {\r\n    return this.bitfield.toString();\r\n  }\r\n\r\n  /**\r\n   * Get iterator\r\n   */\r\n  *[Symbol.iterator](): IterableIterator<S> {\r\n    yield* this.toArray();\r\n  }\r\n\r\n  /**\r\n   * Freeze this bitfield\r\n   */\r\n  freeze(): Readonly<this> {\r\n    return Object.freeze(this);\r\n  }\r\n\r\n  /**\r\n   * Check equality\r\n   */\r\n  equals(other: BitFieldResolvable<S, N>): boolean {\r\n    return this.bitfield === (this.constructor as typeof BitField).resolve<S, N>(other);\r\n  }\r\n\r\n  /**\r\n   * Clone this bitfield\r\n   */\r\n  clone(): BitField<S, N> {\r\n    return new (this.constructor as new (bits: N) => BitField<S, N>)(this.bitfield);\r\n  }\r\n\r\n  /**\r\n   * Resolve a bit to the numeric type\r\n   */\r\n  static resolve<S extends string, N extends bigint | number>(bit: BitFieldResolvable<S, N>): N {\r\n    if (typeof bit === 'bigint' || typeof bit === 'number') {\r\n      return bit as N;\r\n    }\r\n\r\n    if (bit instanceof BitField) {\r\n      return bit.bitfield as N;\r\n    }\r\n\r\n    if (typeof bit === 'string') {\r\n      const resolved = this.Flags[bit];\r\n      if (resolved === undefined) {\r\n        throw new Error(`Unknown bit: ${bit}`);\r\n      }\r\n      return resolved as N;\r\n    }\r\n\r\n    if (Array.isArray(bit)) {\r\n      let result = this.DefaultBit as bigint;\r\n      for (const b of bit) {\r\n        const resolved = this.resolve<S, N>(b);\r\n        result |= resolved as bigint;\r\n      }\r\n      return result as N;\r\n    }\r\n\r\n    throw new Error(`Invalid bit: ${bit}`);\r\n  }\r\n}\r\n\r\nexport default BitField;\r\n"]}
@@ -0,0 +1,116 @@
1
+ /**
2
+ * A Map with additional utility methods
3
+ */
4
+ export declare class Collection<K, V> extends Map<K, V> {
5
+ /**
6
+ * Identical to Map.get()
7
+ * Ensures the value exists
8
+ */
9
+ ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V;
10
+ /**
11
+ * Checks if all items pass a test
12
+ */
13
+ every(fn: (value: V, key: K, collection: this) => boolean): boolean;
14
+ /**
15
+ * Checks if any item passes a test
16
+ */
17
+ some(fn: (value: V, key: K, collection: this) => boolean): boolean;
18
+ /**
19
+ * Identical to Array.filter(), but returns a Collection
20
+ */
21
+ filter(fn: (value: V, key: K, collection: this) => boolean): Collection<K, V>;
22
+ /**
23
+ * Partitions the collection into two collections
24
+ */
25
+ partition(fn: (value: V, key: K, collection: this) => boolean): [Collection<K, V>, Collection<K, V>];
26
+ /**
27
+ * Maps each item to another value
28
+ */
29
+ map<T>(fn: (value: V, key: K, collection: this) => T): T[];
30
+ /**
31
+ * Maps each item to another value into a Collection
32
+ */
33
+ mapValues<T>(fn: (value: V, key: K, collection: this) => T): Collection<K, T>;
34
+ /**
35
+ * Searches for a single item
36
+ */
37
+ find(fn: (value: V, key: K, collection: this) => boolean): V | undefined;
38
+ /**
39
+ * Searches for the key of a single item
40
+ */
41
+ findKey(fn: (value: V, key: K, collection: this) => boolean): K | undefined;
42
+ /**
43
+ * Removes items that satisfy the provided filter function
44
+ */
45
+ sweep(fn: (value: V, key: K, collection: this) => boolean): number;
46
+ /**
47
+ * Reduces the collection to a single value
48
+ */
49
+ reduce<T>(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue: T): T;
50
+ /**
51
+ * Identical to Array.forEach()
52
+ */
53
+ each(fn: (value: V, key: K, collection: this) => void): this;
54
+ /**
55
+ * Returns the first item(s) in the collection
56
+ */
57
+ first(): V | undefined;
58
+ first(amount: number): V[];
59
+ /**
60
+ * Returns the first key(s) in the collection
61
+ */
62
+ firstKey(): K | undefined;
63
+ firstKey(amount: number): K[];
64
+ /**
65
+ * Returns the last item(s) in the collection
66
+ */
67
+ last(): V | undefined;
68
+ last(amount: number): V[];
69
+ /**
70
+ * Returns the last key(s) in the collection
71
+ */
72
+ lastKey(): K | undefined;
73
+ lastKey(amount: number): K[];
74
+ /**
75
+ * Returns a random item from the collection
76
+ */
77
+ random(): V | undefined;
78
+ random(amount: number): V[];
79
+ /**
80
+ * Returns a random key from the collection
81
+ */
82
+ randomKey(): K | undefined;
83
+ randomKey(amount: number): K[];
84
+ /**
85
+ * Combines this collection with others
86
+ */
87
+ concat(...collections: Collection<K, V>[]): Collection<K, V>;
88
+ /**
89
+ * Checks if this collection shares identical items with another
90
+ */
91
+ equals(collection: Collection<K, V>): boolean;
92
+ /**
93
+ * Creates an identical shallow copy of this collection
94
+ */
95
+ clone(): Collection<K, V>;
96
+ /**
97
+ * Sorts the collection and returns it
98
+ */
99
+ sort(compareFunction?: (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number): this;
100
+ /**
101
+ * Sorts the collection by keys and returns it
102
+ */
103
+ sortByKey(compareFunction?: (firstKey: K, secondKey: K, firstValue: V, secondValue: V) => number): this;
104
+ /**
105
+ * Returns an array of items
106
+ */
107
+ toJSON(): V[];
108
+ /**
109
+ * Default sort function
110
+ */
111
+ private static defaultSort;
112
+ /**
113
+ * Creates a Collection from an array
114
+ */
115
+ static from<K, V>(entries: Iterable<readonly [K, V]>): Collection<K, V>;
116
+ }
@@ -0,0 +1,265 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Collection = void 0;
4
+ /**
5
+ * A Map with additional utility methods
6
+ */
7
+ class Collection extends Map {
8
+ /**
9
+ * Identical to Map.get()
10
+ * Ensures the value exists
11
+ */
12
+ ensure(key, defaultValueGenerator) {
13
+ if (this.has(key))
14
+ return this.get(key);
15
+ const defaultValue = defaultValueGenerator(key, this);
16
+ this.set(key, defaultValue);
17
+ return defaultValue;
18
+ }
19
+ /**
20
+ * Checks if all items pass a test
21
+ */
22
+ every(fn) {
23
+ for (const [key, val] of this) {
24
+ if (!fn(val, key, this))
25
+ return false;
26
+ }
27
+ return true;
28
+ }
29
+ /**
30
+ * Checks if any item passes a test
31
+ */
32
+ some(fn) {
33
+ for (const [key, val] of this) {
34
+ if (fn(val, key, this))
35
+ return true;
36
+ }
37
+ return false;
38
+ }
39
+ /**
40
+ * Identical to Array.filter(), but returns a Collection
41
+ */
42
+ filter(fn) {
43
+ const results = new Collection();
44
+ for (const [key, val] of this) {
45
+ if (fn(val, key, this))
46
+ results.set(key, val);
47
+ }
48
+ return results;
49
+ }
50
+ /**
51
+ * Partitions the collection into two collections
52
+ */
53
+ partition(fn) {
54
+ const results = [new Collection(), new Collection()];
55
+ for (const [key, val] of this) {
56
+ if (fn(val, key, this)) {
57
+ results[0].set(key, val);
58
+ }
59
+ else {
60
+ results[1].set(key, val);
61
+ }
62
+ }
63
+ return results;
64
+ }
65
+ /**
66
+ * Maps each item to another value
67
+ */
68
+ map(fn) {
69
+ const results = [];
70
+ for (const [key, val] of this) {
71
+ results.push(fn(val, key, this));
72
+ }
73
+ return results;
74
+ }
75
+ /**
76
+ * Maps each item to another value into a Collection
77
+ */
78
+ mapValues(fn) {
79
+ const results = new Collection();
80
+ for (const [key, val] of this) {
81
+ results.set(key, fn(val, key, this));
82
+ }
83
+ return results;
84
+ }
85
+ /**
86
+ * Searches for a single item
87
+ */
88
+ find(fn) {
89
+ for (const [key, val] of this) {
90
+ if (fn(val, key, this))
91
+ return val;
92
+ }
93
+ return undefined;
94
+ }
95
+ /**
96
+ * Searches for the key of a single item
97
+ */
98
+ findKey(fn) {
99
+ for (const [key, val] of this) {
100
+ if (fn(val, key, this))
101
+ return key;
102
+ }
103
+ return undefined;
104
+ }
105
+ /**
106
+ * Removes items that satisfy the provided filter function
107
+ */
108
+ sweep(fn) {
109
+ const previousSize = this.size;
110
+ for (const [key, val] of this) {
111
+ if (fn(val, key, this))
112
+ this.delete(key);
113
+ }
114
+ return previousSize - this.size;
115
+ }
116
+ /**
117
+ * Reduces the collection to a single value
118
+ */
119
+ reduce(fn, initialValue) {
120
+ let accumulator = initialValue;
121
+ for (const [key, val] of this) {
122
+ accumulator = fn(accumulator, val, key, this);
123
+ }
124
+ return accumulator;
125
+ }
126
+ /**
127
+ * Identical to Array.forEach()
128
+ */
129
+ each(fn) {
130
+ for (const [key, val] of this) {
131
+ fn(val, key, this);
132
+ }
133
+ return this;
134
+ }
135
+ first(amount) {
136
+ if (amount === undefined)
137
+ return this.values().next().value;
138
+ if (amount < 0)
139
+ return this.last(amount * -1);
140
+ amount = Math.min(this.size, amount);
141
+ const iter = this.values();
142
+ return Array.from({ length: amount }, () => iter.next().value);
143
+ }
144
+ firstKey(amount) {
145
+ if (amount === undefined)
146
+ return this.keys().next().value;
147
+ if (amount < 0)
148
+ return this.lastKey(amount * -1);
149
+ amount = Math.min(this.size, amount);
150
+ const iter = this.keys();
151
+ return Array.from({ length: amount }, () => iter.next().value);
152
+ }
153
+ last(amount) {
154
+ const arr = [...this.values()];
155
+ if (amount === undefined)
156
+ return arr[arr.length - 1];
157
+ if (amount < 0)
158
+ return this.first(amount * -1);
159
+ if (!amount)
160
+ return [];
161
+ return arr.slice(-amount);
162
+ }
163
+ lastKey(amount) {
164
+ const arr = [...this.keys()];
165
+ if (amount === undefined)
166
+ return arr[arr.length - 1];
167
+ if (amount < 0)
168
+ return this.firstKey(amount * -1);
169
+ if (!amount)
170
+ return [];
171
+ return arr.slice(-amount);
172
+ }
173
+ random(amount) {
174
+ const arr = [...this.values()];
175
+ if (amount === undefined)
176
+ return arr[Math.floor(Math.random() * arr.length)];
177
+ if (!arr.length || !amount)
178
+ return [];
179
+ return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);
180
+ }
181
+ randomKey(amount) {
182
+ const arr = [...this.keys()];
183
+ if (amount === undefined)
184
+ return arr[Math.floor(Math.random() * arr.length)];
185
+ if (!arr.length || !amount)
186
+ return [];
187
+ return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);
188
+ }
189
+ /**
190
+ * Combines this collection with others
191
+ */
192
+ concat(...collections) {
193
+ const newColl = this.clone();
194
+ for (const coll of collections) {
195
+ for (const [key, val] of coll)
196
+ newColl.set(key, val);
197
+ }
198
+ return newColl;
199
+ }
200
+ /**
201
+ * Checks if this collection shares identical items with another
202
+ */
203
+ equals(collection) {
204
+ if (this === collection)
205
+ return true;
206
+ if (this.size !== collection.size)
207
+ return false;
208
+ for (const [key, value] of this) {
209
+ if (!collection.has(key) || value !== collection.get(key)) {
210
+ return false;
211
+ }
212
+ }
213
+ return true;
214
+ }
215
+ /**
216
+ * Creates an identical shallow copy of this collection
217
+ */
218
+ clone() {
219
+ return new Collection(this);
220
+ }
221
+ /**
222
+ * Sorts the collection and returns it
223
+ */
224
+ sort(compareFunction = Collection.defaultSort) {
225
+ const entries = [...this.entries()];
226
+ entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0]));
227
+ this.clear();
228
+ for (const [k, v] of entries) {
229
+ this.set(k, v);
230
+ }
231
+ return this;
232
+ }
233
+ /**
234
+ * Sorts the collection by keys and returns it
235
+ */
236
+ sortByKey(compareFunction = Collection.defaultSort) {
237
+ const entries = [...this.entries()];
238
+ entries.sort((a, b) => compareFunction(a[0], b[0], a[1], b[1]));
239
+ this.clear();
240
+ for (const [k, v] of entries) {
241
+ this.set(k, v);
242
+ }
243
+ return this;
244
+ }
245
+ /**
246
+ * Returns an array of items
247
+ */
248
+ toJSON() {
249
+ return [...this.values()];
250
+ }
251
+ /**
252
+ * Default sort function
253
+ */
254
+ static defaultSort(firstValue, secondValue) {
255
+ return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;
256
+ }
257
+ /**
258
+ * Creates a Collection from an array
259
+ */
260
+ static from(entries) {
261
+ return new Collection(entries);
262
+ }
263
+ }
264
+ exports.Collection = Collection;
265
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Collection.js","sourceRoot":"","sources":["../../src/utils/Collection.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * A Map with additional utility methods\r\n */\r\nexport class Collection<K, V> extends Map<K, V> {\r\n  /**\r\n   * Identical to Map.get()\r\n   * Ensures the value exists\r\n   */\r\n  ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\r\n    if (this.has(key)) return this.get(key)!;\r\n    const defaultValue = defaultValueGenerator(key, this);\r\n    this.set(key, defaultValue);\r\n    return defaultValue;\r\n  }\r\n\r\n  /**\r\n   * Checks if all items pass a test\r\n   */\r\n  every(fn: (value: V, key: K, collection: this) => boolean): boolean {\r\n    for (const [key, val] of this) {\r\n      if (!fn(val, key, this)) return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Checks if any item passes a test\r\n   */\r\n  some(fn: (value: V, key: K, collection: this) => boolean): boolean {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Identical to Array.filter(), but returns a Collection\r\n   */\r\n  filter(fn: (value: V, key: K, collection: this) => boolean): Collection<K, V> {\r\n    const results = new Collection<K, V>();\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) results.set(key, val);\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Partitions the collection into two collections\r\n   */\r\n  partition(fn: (value: V, key: K, collection: this) => boolean): [Collection<K, V>, Collection<K, V>] {\r\n    const results: [Collection<K, V>, Collection<K, V>] = [new Collection<K, V>(), new Collection<K, V>()];\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) {\r\n        results[0].set(key, val);\r\n      } else {\r\n        results[1].set(key, val);\r\n      }\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Maps each item to another value\r\n   */\r\n  map<T>(fn: (value: V, key: K, collection: this) => T): T[] {\r\n    const results: T[] = [];\r\n    for (const [key, val] of this) {\r\n      results.push(fn(val, key, this));\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Maps each item to another value into a Collection\r\n   */\r\n  mapValues<T>(fn: (value: V, key: K, collection: this) => T): Collection<K, T> {\r\n    const results = new Collection<K, T>();\r\n    for (const [key, val] of this) {\r\n      results.set(key, fn(val, key, this));\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Searches for a single item\r\n   */\r\n  find(fn: (value: V, key: K, collection: this) => boolean): V | undefined {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return val;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Searches for the key of a single item\r\n   */\r\n  findKey(fn: (value: V, key: K, collection: this) => boolean): K | undefined {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return key;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Removes items that satisfy the provided filter function\r\n   */\r\n  sweep(fn: (value: V, key: K, collection: this) => boolean): number {\r\n    const previousSize = this.size;\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) this.delete(key);\r\n    }\r\n    return previousSize - this.size;\r\n  }\r\n\r\n  /**\r\n   * Reduces the collection to a single value\r\n   */\r\n  reduce<T>(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue: T): T {\r\n    let accumulator = initialValue;\r\n    for (const [key, val] of this) {\r\n      accumulator = fn(accumulator, val, key, this);\r\n    }\r\n    return accumulator;\r\n  }\r\n\r\n  /**\r\n   * Identical to Array.forEach()\r\n   */\r\n  each(fn: (value: V, key: K, collection: this) => void): this {\r\n    for (const [key, val] of this) {\r\n      fn(val, key, this);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the first item(s) in the collection\r\n   */\r\n  first(): V | undefined;\r\n  first(amount: number): V[];\r\n  first(amount?: number): V | V[] | undefined {\r\n    if (amount === undefined) return this.values().next().value;\r\n    if (amount < 0) return this.last(amount * -1);\r\n    amount = Math.min(this.size, amount);\r\n    const iter = this.values();\r\n    return Array.from({ length: amount }, () => iter.next().value);\r\n  }\r\n\r\n  /**\r\n   * Returns the first key(s) in the collection\r\n   */\r\n  firstKey(): K | undefined;\r\n  firstKey(amount: number): K[];\r\n  firstKey(amount?: number): K | K[] | undefined {\r\n    if (amount === undefined) return this.keys().next().value;\r\n    if (amount < 0) return this.lastKey(amount * -1);\r\n    amount = Math.min(this.size, amount);\r\n    const iter = this.keys();\r\n    return Array.from({ length: amount }, () => iter.next().value);\r\n  }\r\n\r\n  /**\r\n   * Returns the last item(s) in the collection\r\n   */\r\n  last(): V | undefined;\r\n  last(amount: number): V[];\r\n  last(amount?: number): V | V[] | undefined {\r\n    const arr = [...this.values()];\r\n    if (amount === undefined) return arr[arr.length - 1];\r\n    if (amount < 0) return this.first(amount * -1);\r\n    if (!amount) return [];\r\n    return arr.slice(-amount);\r\n  }\r\n\r\n  /**\r\n   * Returns the last key(s) in the collection\r\n   */\r\n  lastKey(): K | undefined;\r\n  lastKey(amount: number): K[];\r\n  lastKey(amount?: number): K | K[] | undefined {\r\n    const arr = [...this.keys()];\r\n    if (amount === undefined) return arr[arr.length - 1];\r\n    if (amount < 0) return this.firstKey(amount * -1);\r\n    if (!amount) return [];\r\n    return arr.slice(-amount);\r\n  }\r\n\r\n  /**\r\n   * Returns a random item from the collection\r\n   */\r\n  random(): V | undefined;\r\n  random(amount: number): V[];\r\n  random(amount?: number): V | V[] | undefined {\r\n    const arr = [...this.values()];\r\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\r\n    if (!arr.length || !amount) return [];\r\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\r\n  }\r\n\r\n  /**\r\n   * Returns a random key from the collection\r\n   */\r\n  randomKey(): K | undefined;\r\n  randomKey(amount: number): K[];\r\n  randomKey(amount?: number): K | K[] | undefined {\r\n    const arr = [...this.keys()];\r\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\r\n    if (!arr.length || !amount) return [];\r\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\r\n  }\r\n\r\n  /**\r\n   * Combines this collection with others\r\n   */\r\n  concat(...collections: Collection<K, V>[]): Collection<K, V> {\r\n    const newColl = this.clone();\r\n    for (const coll of collections) {\r\n      for (const [key, val] of coll) newColl.set(key, val);\r\n    }\r\n    return newColl;\r\n  }\r\n\r\n  /**\r\n   * Checks if this collection shares identical items with another\r\n   */\r\n  equals(collection: Collection<K, V>): boolean {\r\n    if (this === collection) return true;\r\n    if (this.size !== collection.size) return false;\r\n    for (const [key, value] of this) {\r\n      if (!collection.has(key) || value !== collection.get(key)) {\r\n        return false;\r\n      }\r\n    }\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Creates an identical shallow copy of this collection\r\n   */\r\n  clone(): Collection<K, V> {\r\n    return new Collection(this);\r\n  }\r\n\r\n  /**\r\n   * Sorts the collection and returns it\r\n   */\r\n  sort(compareFunction: (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number = Collection.defaultSort): this {\r\n    const entries = [...this.entries()];\r\n    entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0]));\r\n    this.clear();\r\n    for (const [k, v] of entries) {\r\n      this.set(k, v);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sorts the collection by keys and returns it\r\n   */\r\n  sortByKey(compareFunction: (firstKey: K, secondKey: K, firstValue: V, secondValue: V) => number = Collection.defaultSort): this {\r\n    const entries = [...this.entries()];\r\n    entries.sort((a, b) => compareFunction(a[0], b[0], a[1], b[1]));\r\n    this.clear();\r\n    for (const [k, v] of entries) {\r\n      this.set(k, v);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns an array of items\r\n   */\r\n  toJSON(): V[] {\r\n    return [...this.values()];\r\n  }\r\n\r\n  /**\r\n   * Default sort function\r\n   */\r\n  private static defaultSort<V>(firstValue: V, secondValue: V): number {\r\n    return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\r\n  }\r\n\r\n  /**\r\n   * Creates a Collection from an array\r\n   */\r\n  static from<K, V>(entries: Iterable<readonly [K, V]>): Collection<K, V> {\r\n    return new Collection(entries);\r\n  }\r\n}\r\n"]}