@jubbio/core 1.1.20 → 1.3.2
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/dist/Client.js +13 -14
- package/dist/cjs/Client.d.ts +157 -0
- package/dist/cjs/Client.js +640 -0
- package/dist/cjs/builders/ActionRowBuilder.d.ts +53 -0
- package/dist/cjs/builders/ActionRowBuilder.js +68 -0
- package/dist/cjs/builders/ButtonBuilder.d.ts +77 -0
- package/dist/cjs/builders/ButtonBuilder.js +96 -0
- package/dist/cjs/builders/EmbedBuilder.d.ts +157 -0
- package/dist/cjs/builders/EmbedBuilder.js +208 -0
- package/dist/cjs/builders/ModalBuilder.d.ts +122 -0
- package/dist/cjs/builders/ModalBuilder.js +162 -0
- package/dist/cjs/builders/SelectMenuBuilder.d.ts +123 -0
- package/dist/cjs/builders/SelectMenuBuilder.js +165 -0
- package/dist/cjs/builders/SlashCommandBuilder.d.ts +197 -0
- package/dist/cjs/builders/SlashCommandBuilder.js +324 -0
- package/dist/cjs/builders/index.d.ts +9 -0
- package/dist/cjs/builders/index.js +26 -0
- package/dist/cjs/enums.d.ts +191 -0
- package/dist/cjs/enums.js +211 -0
- package/dist/cjs/index.d.ts +25 -0
- package/dist/cjs/index.js +130 -0
- package/dist/cjs/managers/BaseManager.d.ts +69 -0
- package/dist/cjs/managers/BaseManager.js +106 -0
- package/dist/cjs/managers/ChannelManager.d.ts +95 -0
- package/dist/cjs/managers/ChannelManager.js +205 -0
- package/dist/cjs/managers/GuildMemberManager.d.ts +74 -0
- package/dist/cjs/managers/GuildMemberManager.js +157 -0
- package/dist/cjs/managers/RoleManager.d.ts +84 -0
- package/dist/cjs/managers/RoleManager.js +207 -0
- package/dist/cjs/managers/index.d.ts +7 -0
- package/dist/cjs/managers/index.js +24 -0
- package/dist/cjs/rest/REST.d.ts +527 -0
- package/dist/cjs/rest/REST.js +904 -0
- package/dist/cjs/rest/index.d.ts +1 -0
- package/dist/cjs/rest/index.js +18 -0
- package/dist/cjs/sharding/ShardingManager.d.ts +179 -0
- package/dist/cjs/sharding/ShardingManager.js +375 -0
- package/dist/cjs/sharding/index.d.ts +4 -0
- package/dist/cjs/sharding/index.js +21 -0
- package/dist/cjs/structures/Channel.d.ts +122 -0
- package/dist/cjs/structures/Channel.js +240 -0
- package/dist/cjs/structures/Collection.d.ts +53 -0
- package/dist/cjs/structures/Collection.js +115 -0
- package/dist/cjs/structures/Guild.d.ts +59 -0
- package/dist/cjs/structures/Guild.js +94 -0
- package/dist/cjs/structures/GuildMember.d.ts +174 -0
- package/dist/cjs/structures/GuildMember.js +311 -0
- package/dist/cjs/structures/Interaction.d.ts +245 -0
- package/dist/cjs/structures/Interaction.js +450 -0
- package/dist/cjs/structures/Message.d.ts +98 -0
- package/dist/cjs/structures/Message.js +195 -0
- package/dist/cjs/structures/User.d.ts +37 -0
- package/dist/cjs/structures/User.js +65 -0
- package/dist/cjs/structures/index.d.ts +7 -0
- package/dist/cjs/structures/index.js +25 -0
- package/dist/cjs/structures.d.ts +1 -0
- package/dist/cjs/structures.js +19 -0
- package/dist/cjs/types.d.ts +255 -0
- package/dist/cjs/types.js +3 -0
- package/dist/cjs/utils/BitField.d.ts +66 -0
- package/dist/cjs/utils/BitField.js +138 -0
- package/dist/cjs/utils/Collection.d.ts +116 -0
- package/dist/cjs/utils/Collection.js +265 -0
- package/dist/cjs/utils/Collector.d.ts +152 -0
- package/dist/cjs/utils/Collector.js +314 -0
- package/dist/cjs/utils/DataResolver.d.ts +61 -0
- package/dist/cjs/utils/DataResolver.js +146 -0
- package/dist/cjs/utils/Formatters.d.ts +145 -0
- package/dist/cjs/utils/Formatters.js +213 -0
- package/dist/cjs/utils/IntentsBitField.d.ts +85 -0
- package/dist/cjs/utils/IntentsBitField.js +99 -0
- package/dist/cjs/utils/Partials.d.ts +104 -0
- package/dist/cjs/utils/Partials.js +148 -0
- package/dist/cjs/utils/PermissionsBitField.d.ts +118 -0
- package/dist/cjs/utils/PermissionsBitField.js +145 -0
- package/dist/cjs/utils/SnowflakeUtil.d.ts +63 -0
- package/dist/cjs/utils/SnowflakeUtil.js +93 -0
- package/dist/cjs/utils/Sweepers.d.ts +119 -0
- package/dist/cjs/utils/Sweepers.js +249 -0
- package/dist/cjs/utils/index.d.ts +13 -0
- package/dist/cjs/utils/index.js +30 -0
- package/dist/esm/Client.js +634 -0
- package/dist/esm/builders/ActionRowBuilder.js +64 -0
- package/dist/esm/builders/ButtonBuilder.js +92 -0
- package/dist/esm/builders/EmbedBuilder.js +204 -0
- package/dist/esm/builders/ModalBuilder.js +157 -0
- package/dist/esm/builders/SelectMenuBuilder.js +161 -0
- package/dist/esm/builders/SlashCommandBuilder.js +311 -0
- package/dist/esm/builders/index.js +10 -0
- package/dist/esm/enums.js +208 -0
- package/dist/esm/index.js +34 -0
- package/dist/esm/managers/BaseManager.js +100 -0
- package/dist/esm/managers/ChannelManager.js +200 -0
- package/dist/esm/managers/GuildMemberManager.js +153 -0
- package/dist/esm/managers/RoleManager.js +203 -0
- package/dist/esm/managers/index.js +8 -0
- package/dist/esm/rest/REST.js +900 -0
- package/dist/esm/rest/index.js +2 -0
- package/dist/esm/sharding/ShardingManager.js +366 -0
- package/dist/esm/sharding/index.js +5 -0
- package/dist/esm/structures/Channel.js +232 -0
- package/dist/esm/structures/Collection.js +111 -0
- package/dist/esm/structures/Guild.js +90 -0
- package/dist/esm/structures/GuildMember.js +306 -0
- package/dist/esm/structures/Interaction.js +438 -0
- package/dist/esm/structures/Message.js +191 -0
- package/dist/esm/structures/User.js +61 -0
- package/dist/esm/structures/index.js +9 -0
- package/dist/esm/structures.js +3 -0
- package/dist/esm/types.js +2 -0
- package/dist/esm/utils/BitField.js +134 -0
- package/dist/esm/utils/Collection.js +261 -0
- package/dist/esm/utils/Collector.js +305 -0
- package/dist/esm/utils/DataResolver.js +142 -0
- package/dist/esm/utils/Formatters.js +191 -0
- package/dist/esm/utils/IntentsBitField.js +93 -0
- package/dist/esm/utils/Partials.js +137 -0
- package/dist/esm/utils/PermissionsBitField.js +141 -0
- package/dist/esm/utils/SnowflakeUtil.js +89 -0
- package/dist/esm/utils/Sweepers.js +245 -0
- package/dist/esm/utils/index.js +14 -0
- package/dist/rest/REST.js +8 -1
- package/dist/structures/Interaction.js +3 -5
- package/dist/structures/Message.js +56 -2
- package/package.json +14 -4
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generic BitField class
|
|
3
|
+
* API compatible with Discord.js BitField
|
|
4
|
+
*/
|
|
5
|
+
export type BitFieldResolvable<S extends string, N extends bigint | number> = N | N[] | S | S[] | BitField<S, N>;
|
|
6
|
+
/**
|
|
7
|
+
* Data structure for bit fields
|
|
8
|
+
*/
|
|
9
|
+
export declare class BitField<S extends string = string, N extends bigint | number = bigint> {
|
|
10
|
+
/** The raw bits */
|
|
11
|
+
bitfield: N;
|
|
12
|
+
/** Flags for this bitfield (override in subclass) */
|
|
13
|
+
static Flags: Record<string, bigint | number>;
|
|
14
|
+
/** Default bit value */
|
|
15
|
+
static DefaultBit: bigint | number;
|
|
16
|
+
constructor(bits?: BitFieldResolvable<S, N>);
|
|
17
|
+
/**
|
|
18
|
+
* Check if this bitfield has a bit
|
|
19
|
+
*/
|
|
20
|
+
has(bit: BitFieldResolvable<S, N>): boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Check if this bitfield has any of the bits
|
|
23
|
+
*/
|
|
24
|
+
any(bits: BitFieldResolvable<S, N>): boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Add bits to this bitfield
|
|
27
|
+
*/
|
|
28
|
+
add(...bits: BitFieldResolvable<S, N>[]): this;
|
|
29
|
+
/**
|
|
30
|
+
* Remove bits from this bitfield
|
|
31
|
+
*/
|
|
32
|
+
remove(...bits: BitFieldResolvable<S, N>[]): this;
|
|
33
|
+
/**
|
|
34
|
+
* Serialize to array of flag names
|
|
35
|
+
*/
|
|
36
|
+
toArray(): S[];
|
|
37
|
+
/**
|
|
38
|
+
* Serialize to JSON
|
|
39
|
+
*/
|
|
40
|
+
toJSON(): string | number;
|
|
41
|
+
/**
|
|
42
|
+
* Get string representation
|
|
43
|
+
*/
|
|
44
|
+
toString(): string;
|
|
45
|
+
/**
|
|
46
|
+
* Get iterator
|
|
47
|
+
*/
|
|
48
|
+
[Symbol.iterator](): IterableIterator<S>;
|
|
49
|
+
/**
|
|
50
|
+
* Freeze this bitfield
|
|
51
|
+
*/
|
|
52
|
+
freeze(): Readonly<this>;
|
|
53
|
+
/**
|
|
54
|
+
* Check equality
|
|
55
|
+
*/
|
|
56
|
+
equals(other: BitFieldResolvable<S, N>): boolean;
|
|
57
|
+
/**
|
|
58
|
+
* Clone this bitfield
|
|
59
|
+
*/
|
|
60
|
+
clone(): BitField<S, N>;
|
|
61
|
+
/**
|
|
62
|
+
* Resolve a bit to the numeric type
|
|
63
|
+
*/
|
|
64
|
+
static resolve<S extends string, N extends bigint | number>(bit: BitFieldResolvable<S, N>): N;
|
|
65
|
+
}
|
|
66
|
+
export default BitField;
|
|
@@ -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":["/**\n * Generic BitField class\n * API compatible with Discord.js BitField\n */\n\nexport type BitFieldResolvable<S extends string, N extends bigint | number> = \n  | N \n  | N[] \n  | S \n  | S[] \n  | BitField<S, N>;\n\n/**\n * Data structure for bit fields\n */\nexport class BitField<S extends string = string, N extends bigint | number = bigint> {\n  /** The raw bits */\n  public bitfield: N;\n\n  /** Flags for this bitfield (override in subclass) */\n  static Flags: Record<string, bigint | number> = {};\n\n  /** Default bit value */\n  static DefaultBit: bigint | number = 0n;\n\n  constructor(bits: BitFieldResolvable<S, N> = BitField.DefaultBit as N) {\n    this.bitfield = (this.constructor as typeof BitField).resolve<S, N>(bits);\n  }\n\n  /**\n   * Check if this bitfield has a bit\n   */\n  has(bit: BitFieldResolvable<S, N>): boolean {\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bit);\n    return ((this.bitfield as bigint) & (resolved as bigint)) === (resolved as bigint);\n  }\n\n  /**\n   * Check if this bitfield has any of the bits\n   */\n  any(bits: BitFieldResolvable<S, N>): boolean {\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bits);\n    return ((this.bitfield as bigint) & (resolved as bigint)) !== 0n;\n  }\n\n  /**\n   * Add bits to this bitfield\n   */\n  add(...bits: BitFieldResolvable<S, N>[]): this {\n    let total = 0n;\n    for (const bit of bits) {\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\n    }\n    (this.bitfield as bigint) |= total;\n    return this;\n  }\n\n  /**\n   * Remove bits from this bitfield\n   */\n  remove(...bits: BitFieldResolvable<S, N>[]): this {\n    let total = 0n;\n    for (const bit of bits) {\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\n    }\n    (this.bitfield as bigint) &= ~total;\n    return this;\n  }\n\n  /**\n   * Serialize to array of flag names\n   */\n  toArray(): S[] {\n    const flags = (this.constructor as typeof BitField).Flags;\n    const result: S[] = [];\n    \n    for (const [name, bit] of Object.entries(flags)) {\n      if ((this.bitfield as bigint) & (bit as bigint)) {\n        result.push(name as S);\n      }\n    }\n    \n    return result;\n  }\n\n  /**\n   * Serialize to JSON\n   */\n  toJSON(): string | number {\n    return typeof this.bitfield === 'bigint' \n      ? this.bitfield.toString() \n      : this.bitfield;\n  }\n\n  /**\n   * Get string representation\n   */\n  toString(): string {\n    return this.bitfield.toString();\n  }\n\n  /**\n   * Get iterator\n   */\n  *[Symbol.iterator](): IterableIterator<S> {\n    yield* this.toArray();\n  }\n\n  /**\n   * Freeze this bitfield\n   */\n  freeze(): Readonly<this> {\n    return Object.freeze(this);\n  }\n\n  /**\n   * Check equality\n   */\n  equals(other: BitFieldResolvable<S, N>): boolean {\n    return this.bitfield === (this.constructor as typeof BitField).resolve<S, N>(other);\n  }\n\n  /**\n   * Clone this bitfield\n   */\n  clone(): BitField<S, N> {\n    return new (this.constructor as new (bits: N) => BitField<S, N>)(this.bitfield);\n  }\n\n  /**\n   * Resolve a bit to the numeric type\n   */\n  static resolve<S extends string, N extends bigint | number>(bit: BitFieldResolvable<S, N>): N {\n    if (typeof bit === 'bigint' || typeof bit === 'number') {\n      return bit as N;\n    }\n\n    if (bit instanceof BitField) {\n      return bit.bitfield as N;\n    }\n\n    if (typeof bit === 'string') {\n      const resolved = this.Flags[bit];\n      if (resolved === undefined) {\n        throw new Error(`Unknown bit: ${bit}`);\n      }\n      return resolved as N;\n    }\n\n    if (Array.isArray(bit)) {\n      let result = this.DefaultBit as bigint;\n      for (const b of bit) {\n        const resolved = this.resolve<S, N>(b);\n        result |= resolved as bigint;\n      }\n      return result as N;\n    }\n\n    throw new Error(`Invalid bit: ${bit}`);\n  }\n}\n\nexport default BitField;\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":["/**\n * A Map with additional utility methods\n */\nexport class Collection<K, V> extends Map<K, V> {\n  /**\n   * Identical to Map.get()\n   * Ensures the value exists\n   */\n  ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\n    if (this.has(key)) return this.get(key)!;\n    const defaultValue = defaultValueGenerator(key, this);\n    this.set(key, defaultValue);\n    return defaultValue;\n  }\n\n  /**\n   * Checks if all items pass a test\n   */\n  every(fn: (value: V, key: K, collection: this) => boolean): boolean {\n    for (const [key, val] of this) {\n      if (!fn(val, key, this)) return false;\n    }\n    return true;\n  }\n\n  /**\n   * Checks if any item passes a test\n   */\n  some(fn: (value: V, key: K, collection: this) => boolean): boolean {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return true;\n    }\n    return false;\n  }\n\n  /**\n   * Identical to Array.filter(), but returns a Collection\n   */\n  filter(fn: (value: V, key: K, collection: this) => boolean): Collection<K, V> {\n    const results = new Collection<K, V>();\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) results.set(key, val);\n    }\n    return results;\n  }\n\n  /**\n   * Partitions the collection into two collections\n   */\n  partition(fn: (value: V, key: K, collection: this) => boolean): [Collection<K, V>, Collection<K, V>] {\n    const results: [Collection<K, V>, Collection<K, V>] = [new Collection<K, V>(), new Collection<K, V>()];\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) {\n        results[0].set(key, val);\n      } else {\n        results[1].set(key, val);\n      }\n    }\n    return results;\n  }\n\n  /**\n   * Maps each item to another value\n   */\n  map<T>(fn: (value: V, key: K, collection: this) => T): T[] {\n    const results: T[] = [];\n    for (const [key, val] of this) {\n      results.push(fn(val, key, this));\n    }\n    return results;\n  }\n\n  /**\n   * Maps each item to another value into a Collection\n   */\n  mapValues<T>(fn: (value: V, key: K, collection: this) => T): Collection<K, T> {\n    const results = new Collection<K, T>();\n    for (const [key, val] of this) {\n      results.set(key, fn(val, key, this));\n    }\n    return results;\n  }\n\n  /**\n   * Searches for a single item\n   */\n  find(fn: (value: V, key: K, collection: this) => boolean): V | undefined {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return val;\n    }\n    return undefined;\n  }\n\n  /**\n   * Searches for the key of a single item\n   */\n  findKey(fn: (value: V, key: K, collection: this) => boolean): K | undefined {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return key;\n    }\n    return undefined;\n  }\n\n  /**\n   * Removes items that satisfy the provided filter function\n   */\n  sweep(fn: (value: V, key: K, collection: this) => boolean): number {\n    const previousSize = this.size;\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) this.delete(key);\n    }\n    return previousSize - this.size;\n  }\n\n  /**\n   * Reduces the collection to a single value\n   */\n  reduce<T>(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue: T): T {\n    let accumulator = initialValue;\n    for (const [key, val] of this) {\n      accumulator = fn(accumulator, val, key, this);\n    }\n    return accumulator;\n  }\n\n  /**\n   * Identical to Array.forEach()\n   */\n  each(fn: (value: V, key: K, collection: this) => void): this {\n    for (const [key, val] of this) {\n      fn(val, key, this);\n    }\n    return this;\n  }\n\n  /**\n   * Returns the first item(s) in the collection\n   */\n  first(): V | undefined;\n  first(amount: number): V[];\n  first(amount?: number): V | V[] | undefined {\n    if (amount === undefined) return this.values().next().value;\n    if (amount < 0) return this.last(amount * -1);\n    amount = Math.min(this.size, amount);\n    const iter = this.values();\n    return Array.from({ length: amount }, () => iter.next().value);\n  }\n\n  /**\n   * Returns the first key(s) in the collection\n   */\n  firstKey(): K | undefined;\n  firstKey(amount: number): K[];\n  firstKey(amount?: number): K | K[] | undefined {\n    if (amount === undefined) return this.keys().next().value;\n    if (amount < 0) return this.lastKey(amount * -1);\n    amount = Math.min(this.size, amount);\n    const iter = this.keys();\n    return Array.from({ length: amount }, () => iter.next().value);\n  }\n\n  /**\n   * Returns the last item(s) in the collection\n   */\n  last(): V | undefined;\n  last(amount: number): V[];\n  last(amount?: number): V | V[] | undefined {\n    const arr = [...this.values()];\n    if (amount === undefined) return arr[arr.length - 1];\n    if (amount < 0) return this.first(amount * -1);\n    if (!amount) return [];\n    return arr.slice(-amount);\n  }\n\n  /**\n   * Returns the last key(s) in the collection\n   */\n  lastKey(): K | undefined;\n  lastKey(amount: number): K[];\n  lastKey(amount?: number): K | K[] | undefined {\n    const arr = [...this.keys()];\n    if (amount === undefined) return arr[arr.length - 1];\n    if (amount < 0) return this.firstKey(amount * -1);\n    if (!amount) return [];\n    return arr.slice(-amount);\n  }\n\n  /**\n   * Returns a random item from the collection\n   */\n  random(): V | undefined;\n  random(amount: number): V[];\n  random(amount?: number): V | V[] | undefined {\n    const arr = [...this.values()];\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n    if (!arr.length || !amount) return [];\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\n  }\n\n  /**\n   * Returns a random key from the collection\n   */\n  randomKey(): K | undefined;\n  randomKey(amount: number): K[];\n  randomKey(amount?: number): K | K[] | undefined {\n    const arr = [...this.keys()];\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n    if (!arr.length || !amount) return [];\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\n  }\n\n  /**\n   * Combines this collection with others\n   */\n  concat(...collections: Collection<K, V>[]): Collection<K, V> {\n    const newColl = this.clone();\n    for (const coll of collections) {\n      for (const [key, val] of coll) newColl.set(key, val);\n    }\n    return newColl;\n  }\n\n  /**\n   * Checks if this collection shares identical items with another\n   */\n  equals(collection: Collection<K, V>): boolean {\n    if (this === collection) return true;\n    if (this.size !== collection.size) return false;\n    for (const [key, value] of this) {\n      if (!collection.has(key) || value !== collection.get(key)) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Creates an identical shallow copy of this collection\n   */\n  clone(): Collection<K, V> {\n    return new Collection(this);\n  }\n\n  /**\n   * Sorts the collection and returns it\n   */\n  sort(compareFunction: (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number = Collection.defaultSort): this {\n    const entries = [...this.entries()];\n    entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0]));\n    this.clear();\n    for (const [k, v] of entries) {\n      this.set(k, v);\n    }\n    return this;\n  }\n\n  /**\n   * Sorts the collection by keys and returns it\n   */\n  sortByKey(compareFunction: (firstKey: K, secondKey: K, firstValue: V, secondValue: V) => number = Collection.defaultSort): this {\n    const entries = [...this.entries()];\n    entries.sort((a, b) => compareFunction(a[0], b[0], a[1], b[1]));\n    this.clear();\n    for (const [k, v] of entries) {\n      this.set(k, v);\n    }\n    return this;\n  }\n\n  /**\n   * Returns an array of items\n   */\n  toJSON(): V[] {\n    return [...this.values()];\n  }\n\n  /**\n   * Default sort function\n   */\n  private static defaultSort<V>(firstValue: V, secondValue: V): number {\n    return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n  }\n\n  /**\n   * Creates a Collection from an array\n   */\n  static from<K, V>(entries: Iterable<readonly [K, V]>): Collection<K, V> {\n    return new Collection(entries);\n  }\n}\n"]}
|