@fallencodes/seyfert-utils 1.3.5 → 1.4.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.
- package/build/options.d.ts +2 -1
- package/build/options.d.ts.map +1 -1
- package/build/options.js +22 -1
- package/build/utilities.d.ts +2 -1
- package/build/utilities.d.ts.map +1 -1
- package/build/utilities.js +13 -0
- package/package.json +1 -1
package/build/options.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { OKFunction, GuildRole, StopFunction, AllGuildChannels, CommandContext } from 'seyfert';
|
|
1
|
+
import { OKFunction, GuildRole, StopFunction, AllGuildChannels, CommandContext, User } from 'seyfert';
|
|
2
2
|
interface StringOption {
|
|
3
3
|
value: string;
|
|
4
4
|
context: CommandContext;
|
|
@@ -9,5 +9,6 @@ export declare function dateOptionValue({ value }: StringOption, ok: OKFunction<
|
|
|
9
9
|
export declare function relativeTimeOptionValue({ value }: StringOption, ok: OKFunction<number>, fail: StopFunction): void;
|
|
10
10
|
export declare function rolesOptionValue({ value: values, context }: StringOption, ok: OKFunction<[GuildRole, ...GuildRole[]]>, fail: StopFunction): Promise<void>;
|
|
11
11
|
export declare function channelsOptionValue({ value: values, context }: StringOption, ok: OKFunction<[AllGuildChannels, ...AllGuildChannels[]]>, fail: StopFunction): Promise<void>;
|
|
12
|
+
export declare function usersOptionValue({ value: values, context }: StringOption, ok: OKFunction<[User, ...User[]]>, fail: StopFunction): Promise<void>;
|
|
12
13
|
export {};
|
|
13
14
|
//# sourceMappingURL=options.d.ts.map
|
package/build/options.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,gBAAgB,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAOtG,UAAU,YAAY;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,cAAc,CAAC;CAC3B;AAGD,eAAO,MAAM,oBAAoB,GAAI,WAAW,YAAY,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,YAAY,SAGvG,CAAC;AAGF,eAAO,MAAM,mBAAmB,GAAI,WAAW,YAAY,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,YAAY,SAStG,CAAC;AAGF,wBAAgB,eAAe,CAAC,EAAE,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,QAIhG;AAGD,wBAAgB,uBAAuB,CAAC,EAAE,KAAK,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,UAAU,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,YAAY,QAI1G;AAGD,wBAAsB,gBAAgB,CAClC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,YAAY,EACxC,EAAE,EAAE,UAAU,CAAC,CAAC,SAAS,EAAE,GAAG,SAAS,EAAE,CAAC,CAAC,EAC3C,IAAI,EAAE,YAAY,iBA4BrB;AAGD,wBAAsB,mBAAmB,CACrC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,YAAY,EACxC,EAAE,EAAE,UAAU,CAAC,CAAC,gBAAgB,EAAE,GAAG,gBAAgB,EAAE,CAAC,CAAC,EACzD,IAAI,EAAE,YAAY,iBA8BrB;AAED,wBAAsB,gBAAgB,CAClC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,YAAY,EACxC,EAAE,EAAE,UAAU,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,EACjC,IAAI,EAAE,YAAY,iBAkBrB"}
|
package/build/options.js
CHANGED
|
@@ -2,7 +2,7 @@ import { isValidSnowflake } from './utilities.js';
|
|
|
2
2
|
import dayjs from 'dayjs';
|
|
3
3
|
import ms from 'ms';
|
|
4
4
|
import fuzzy from 'fuzzysort';
|
|
5
|
-
import { channelMentionRegex, hexRegex, roleMentionRegex } from './variables.js';
|
|
5
|
+
import { channelMentionRegex, hexRegex, roleMentionRegex, userMentionRegex } from './variables.js';
|
|
6
6
|
/* Returns a valid string snowflake value. */
|
|
7
7
|
export const snowflakeOptionValue = ({ value }, ok, fail) => {
|
|
8
8
|
if (isValidSnowflake(value))
|
|
@@ -106,3 +106,24 @@ export async function channelsOptionValue({ value: values, context }, ok, fail)
|
|
|
106
106
|
ok(resolvedChannels);
|
|
107
107
|
}
|
|
108
108
|
;
|
|
109
|
+
export async function usersOptionValue({ value: values, context }, ok, fail) {
|
|
110
|
+
const resolvedUsers = [];
|
|
111
|
+
for await (const value of values.split(',').map((value) => value.trim())) {
|
|
112
|
+
let user;
|
|
113
|
+
const mentionMatch = userMentionRegex.exec(value)?.[1];
|
|
114
|
+
if (mentionMatch)
|
|
115
|
+
user = await context.client.users.fetch(mentionMatch).catch(() => undefined);
|
|
116
|
+
if (!user && isValidSnowflake(value))
|
|
117
|
+
user = await context.client.users.fetch(value).catch(() => undefined);
|
|
118
|
+
if (user)
|
|
119
|
+
resolvedUsers.push(user);
|
|
120
|
+
else
|
|
121
|
+
return fail(`Hold up! | The specified user "${user}" wasn't found.`);
|
|
122
|
+
}
|
|
123
|
+
;
|
|
124
|
+
if (resolvedUsers.length < 1)
|
|
125
|
+
return fail(`Hold up! | You didn't specify any valid users.`);
|
|
126
|
+
// @ts-expect-error
|
|
127
|
+
ok(resolvedUsers);
|
|
128
|
+
}
|
|
129
|
+
;
|
package/build/utilities.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { User, GuildMember, InteractionGuildMember } from 'seyfert';
|
|
1
|
+
import { User, GuildMember, InteractionGuildMember, AnyContext } from 'seyfert';
|
|
2
2
|
import { APIRoleColors } from 'seyfert/lib/types/index.js';
|
|
3
3
|
import { ObjectToLower } from 'seyfert/lib/common/index.js';
|
|
4
4
|
export declare function s(content: string): string;
|
|
@@ -14,5 +14,6 @@ export declare function numberToHex(color: number): string;
|
|
|
14
14
|
export declare function apiRoleColorsToArray(apiColors: APIRoleColors | ObjectToLower<APIRoleColors>): number[];
|
|
15
15
|
export declare function getValueFromPath<T extends Record<string, any>>(object: T, path: string): unknown | undefined;
|
|
16
16
|
export declare function truncateStringArray(array: string[], maxLength?: number, separator?: string): string[];
|
|
17
|
+
export declare function isInstalled(context: AnyContext): boolean;
|
|
17
18
|
export {};
|
|
18
19
|
//# sourceMappingURL=utilities.d.ts.map
|
package/build/utilities.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utilities.d.ts","sourceRoot":"","sources":["../src/utilities.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"utilities.d.ts","sourceRoot":"","sources":["../src/utilities.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAG5D,wBAAgB,CAAC,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAEzC;AAGD,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAE/C;AAGD,wBAAgB,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAEnD;AAGD,wBAAgB,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAI3D;AAGD,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,GAAE,MAAY,GAAG,MAAM,CAI9E;AAED,KAAK,QAAQ,GACX,SAAS,GACT,WAAW,GACX,kBAAkB,GAClB,oBAAoB,GACpB,aAAa,GACb,eAAe,CAAA;AAGjB,wBAAgB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,sBAAsB,EAAE,IAAI,GAAE,QAAoB,GAAG,MAAM,CAW1G;AAGD,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,OAG/C;AAGD,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,OAIhD;AAGD,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,UAExC;AAGD,wBAAgB,oBAAoB,CAAC,SAAS,EAAE,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC,GAAG,MAAM,EAAE,CAUtG;AAID,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,CAE5G;AAGD,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,SAAS,GAAE,MAAa,EAAE,SAAS,GAAE,MAAa,YActG;AAGD,wBAAgB,WAAW,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CASxD"}
|
package/build/utilities.js
CHANGED
|
@@ -105,3 +105,16 @@ export function truncateStringArray(array, maxLength = 1000, separator = ', ') {
|
|
|
105
105
|
return newArray;
|
|
106
106
|
}
|
|
107
107
|
;
|
|
108
|
+
/* Checks if a command or interaction is from an installed guild. */
|
|
109
|
+
export function isInstalled(context) {
|
|
110
|
+
// @ts-expect-error
|
|
111
|
+
if ('message' in context && context.message?.guildId)
|
|
112
|
+
return true;
|
|
113
|
+
if (context.interaction.context !== 0)
|
|
114
|
+
return false;
|
|
115
|
+
const guildId = context.interaction.authorizingIntegrationOwners['0'];
|
|
116
|
+
if (guildId && guildId !== '0')
|
|
117
|
+
return true;
|
|
118
|
+
return false;
|
|
119
|
+
}
|
|
120
|
+
;
|
package/package.json
CHANGED