From d7c3ea5c7d62e66f813ee2570a4b8c2829c70343 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jens=20Bech-S=C3=B8rensen?= Date: Sat, 3 May 2025 11:46:44 +0200 Subject: [PATCH] migrate --- .devcontainer/devcontainer.json | 22 + Dockerfile | 32 + Makefile | 22 + node_modules/.modules.yaml | 70 + node_modules/.pnpm-workspace-state.json | 25 + .../node_modules/@discordjs/builders/LICENSE | 191 + .../@discordjs/builders/README.md | 72 + .../@discordjs/builders/dist/index.d.mts | 2043 ++ .../@discordjs/builders/dist/index.d.ts | 2043 ++ .../@discordjs/builders/dist/index.js | 2916 +++ .../@discordjs/builders/dist/index.js.map | 1 + .../@discordjs/builders/dist/index.mjs | 2859 +++ .../@discordjs/builders/dist/index.mjs.map | 1 + .../@discordjs/builders/package.json | 99 + .../node_modules/@discordjs/formatters | 1 + .../node_modules/@discordjs/util | 1 + .../node_modules/@sapphire/shapeshift | 1 + .../node_modules/discord-api-types | 1 + .../node_modules/fast-deep-equal | 1 + .../node_modules/ts-mixer | 1 + .../node_modules/tslib | 1 + .../@discordjs/collection/CHANGELOG.md | 190 + .../@discordjs/collection/LICENSE | 191 + .../@discordjs/collection/README.md | 67 + .../@discordjs/collection/dist/index.d.mts | 457 + .../@discordjs/collection/dist/index.d.ts | 457 + .../@discordjs/collection/dist/index.js | 543 + .../@discordjs/collection/dist/index.js.map | 1 + .../@discordjs/collection/dist/index.mjs | 517 + .../@discordjs/collection/dist/index.mjs.map | 1 + .../@discordjs/collection/package.json | 76 + .../@discordjs/collection/LICENSE | 191 + .../@discordjs/collection/README.md | 67 + .../@discordjs/collection/dist/index.d.mts | 537 + .../@discordjs/collection/dist/index.d.ts | 537 + .../@discordjs/collection/dist/index.js | 567 + .../@discordjs/collection/dist/index.js.map | 1 + .../@discordjs/collection/dist/index.mjs | 541 + .../@discordjs/collection/dist/index.mjs.map | 1 + .../@discordjs/collection/package.json | 86 + .../@discordjs/formatters/LICENSE | 191 + .../@discordjs/formatters/README.md | 82 + .../@discordjs/formatters/dist/index.d.mts | 673 + .../@discordjs/formatters/dist/index.d.ts | 673 + .../@discordjs/formatters/dist/index.js | 452 + .../@discordjs/formatters/dist/index.js.map | 1 + .../@discordjs/formatters/dist/index.mjs | 385 + .../@discordjs/formatters/dist/index.mjs.map | 1 + .../@discordjs/formatters/package.json | 83 + .../node_modules/discord-api-types | 1 + .../node_modules/@discordjs/collection | 1 + .../node_modules/@discordjs/rest/LICENSE | 192 + .../node_modules/@discordjs/rest/README.md | 138 + .../@discordjs/rest/dist/index.d.mts | 926 + .../@discordjs/rest/dist/index.d.ts | 926 + .../@discordjs/rest/dist/index.js | 1480 ++ .../@discordjs/rest/dist/index.js.map | 1 + .../@discordjs/rest/dist/index.mjs | 1438 ++ .../@discordjs/rest/dist/index.mjs.map | 1 + .../rest/dist/strategies/undiciRequest.d.mts | 13 + .../rest/dist/strategies/undiciRequest.d.ts | 13 + .../rest/dist/strategies/undiciRequest.js | 94 + .../rest/dist/strategies/undiciRequest.js.map | 1 + .../rest/dist/strategies/undiciRequest.mjs | 70 + .../dist/strategies/undiciRequest.mjs.map | 1 + .../@discordjs/rest/dist/web.d.mts | 926 + .../@discordjs/rest/dist/web.d.ts | 926 + .../node_modules/@discordjs/rest/dist/web.js | 1412 ++ .../@discordjs/rest/dist/web.js.map | 1 + .../node_modules/@discordjs/rest/dist/web.mjs | 1368 ++ .../@discordjs/rest/dist/web.mjs.map | 1 + .../node_modules/@discordjs/rest/package.json | 119 + .../node_modules/@discordjs/util | 1 + .../node_modules/@sapphire/async-queue | 1 + .../node_modules/@sapphire/snowflake | 1 + .../@vladfrangu/async_event_emitter | 1 + .../node_modules/discord-api-types | 1 + .../node_modules/magic-bytes.js | 1 + .../@discordjs+rest@2.4.3/node_modules/tslib | 1 + .../@discordjs+rest@2.4.3/node_modules/undici | 1 + .../node_modules/@discordjs/util/LICENSE | 190 + .../node_modules/@discordjs/util/README.md | 65 + .../@discordjs/util/dist/index.d.mts | 132 + .../@discordjs/util/dist/index.d.ts | 132 + .../@discordjs/util/dist/index.js | 144 + .../@discordjs/util/dist/index.js.map | 1 + .../@discordjs/util/dist/index.mjs | 111 + .../@discordjs/util/dist/index.mjs.map | 1 + .../node_modules/@discordjs/util/package.json | 91 + .../node_modules/@discordjs/collection | 1 + .../node_modules/@discordjs/rest | 1 + .../node_modules/@discordjs/util | 1 + .../node_modules/@discordjs/ws/LICENSE | 191 + .../node_modules/@discordjs/ws/README.md | 204 + .../@discordjs/ws/dist/defaultWorker.d.mts | 2 + .../@discordjs/ws/dist/defaultWorker.d.ts | 2 + .../@discordjs/ws/dist/defaultWorker.js | 1057 + .../@discordjs/ws/dist/defaultWorker.js.map | 1 + .../@discordjs/ws/dist/defaultWorker.mjs | 1039 + .../@discordjs/ws/dist/defaultWorker.mjs.map | 1 + .../@discordjs/ws/dist/index.d.mts | 705 + .../@discordjs/ws/dist/index.d.ts | 705 + .../node_modules/@discordjs/ws/dist/index.js | 1506 ++ .../@discordjs/ws/dist/index.js.map | 1 + .../node_modules/@discordjs/ws/dist/index.mjs | 1468 ++ .../@discordjs/ws/dist/index.mjs.map | 1 + .../node_modules/@discordjs/ws/package.json | 113 + .../node_modules/@sapphire/async-queue | 1 + .../node_modules/@types/ws | 1 + .../@vladfrangu/async_event_emitter | 1 + .../node_modules/discord-api-types | 1 + .../@discordjs+ws@1.2.1/node_modules/tslib | 1 + .../.pnpm/@discordjs+ws@1.2.1/node_modules/ws | 1 + .../@sapphire/async-queue/CHANGELOG.md | 211 + .../@sapphire/async-queue/README.md | 96 + .../@sapphire/async-queue/dist/cjs/index.cjs | 137 + .../async-queue/dist/cjs/index.cjs.map | 1 + .../async-queue/dist/cjs/index.d.cts | 55 + .../async-queue/dist/esm/index.d.mts | 55 + .../@sapphire/async-queue/dist/esm/index.mjs | 135 + .../async-queue/dist/esm/index.mjs.map | 1 + .../async-queue/dist/iife/index.global.js | 142 + .../async-queue/dist/iife/index.global.js.map | 1 + .../@sapphire/async-queue/package.json | 74 + .../@sapphire/shapeshift/CHANGELOG.md | 464 + .../@sapphire/shapeshift/LICENSE.md | 24 + .../@sapphire/shapeshift/README.md | 934 + .../@sapphire/shapeshift/UPGRADING-v3-v4.md | 211 + .../@sapphire/shapeshift/dist/cjs/index.cjs | 3210 +++ .../shapeshift/dist/cjs/index.cjs.map | 1 + .../@sapphire/shapeshift/dist/cjs/index.d.cts | 722 + .../@sapphire/shapeshift/dist/esm/index.d.mts | 722 + .../@sapphire/shapeshift/dist/esm/index.mjs | 3187 +++ .../shapeshift/dist/esm/index.mjs.map | 1 + .../shapeshift/dist/iife/index.global.js | 4417 ++++ .../shapeshift/dist/iife/index.global.js.map | 1 + .../@sapphire/shapeshift/package.json | 125 + .../node_modules/fast-deep-equal | 1 + .../node_modules/lodash | 1 + .../@sapphire/snowflake/CHANGELOG.md | 312 + .../@sapphire/snowflake/README.md | 170 + .../@sapphire/snowflake/dist/cjs/index.cjs | 194 + .../snowflake/dist/cjs/index.cjs.map | 1 + .../@sapphire/snowflake/dist/cjs/index.d.cts | 202 + .../@sapphire/snowflake/dist/esm/index.d.mts | 202 + .../@sapphire/snowflake/dist/esm/index.mjs | 187 + .../snowflake/dist/esm/index.mjs.map | 1 + .../snowflake/dist/iife/index.global.js | 199 + .../snowflake/dist/iife/index.global.js.map | 1 + .../@sapphire/snowflake/package.json | 72 + .../typebox/build/cjs/compiler/compiler.d.ts | 55 + .../typebox/build/cjs/compiler/compiler.js | 669 + .../typebox/build/cjs/compiler/index.d.ts | 2 + .../typebox/build/cjs/compiler/index.js | 22 + .../typebox/build/cjs/errors/errors.d.ts | 91 + .../typebox/build/cjs/errors/errors.js | 599 + .../typebox/build/cjs/errors/function.d.ts | 21 + .../typebox/build/cjs/errors/function.js | 153 + .../typebox/build/cjs/errors/index.d.ts | 2 + .../typebox/build/cjs/errors/index.js | 19 + .../@sinclair/typebox/build/cjs/index.d.ts | 71 + .../@sinclair/typebox/build/cjs/index.js | 97 + .../typebox/build/cjs/parser/index.d.ts | 2 + .../typebox/build/cjs/parser/index.js | 6 + .../build/cjs/parser/runtime/guard.d.ts | 23 + .../typebox/build/cjs/parser/runtime/guard.js | 86 + .../build/cjs/parser/runtime/index.d.ts | 5 + .../typebox/build/cjs/parser/runtime/index.js | 23 + .../build/cjs/parser/runtime/module.d.ts | 9 + .../build/cjs/parser/runtime/module.js | 22 + .../build/cjs/parser/runtime/parse.d.ts | 9 + .../typebox/build/cjs/parser/runtime/parse.js | 127 + .../build/cjs/parser/runtime/token.d.ts | 8 + .../typebox/build/cjs/parser/runtime/token.js | 230 + .../build/cjs/parser/runtime/types.d.ts | 98 + .../typebox/build/cjs/parser/runtime/types.js | 71 + .../build/cjs/parser/static/index.d.ts | 3 + .../typebox/build/cjs/parser/static/index.js | 21 + .../build/cjs/parser/static/parse.d.ts | 20 + .../typebox/build/cjs/parser/static/parse.js | 3 + .../build/cjs/parser/static/token.d.ts | 108 + .../typebox/build/cjs/parser/static/token.js | 3 + .../build/cjs/parser/static/types.d.ts | 69 + .../typebox/build/cjs/parser/static/types.js | 3 + .../typebox/build/cjs/syntax/index.d.ts | 1 + .../typebox/build/cjs/syntax/index.js | 18 + .../typebox/build/cjs/syntax/mapping.d.ts | 167 + .../typebox/build/cjs/syntax/mapping.js | 458 + .../typebox/build/cjs/syntax/parser.d.ts | 162 + .../typebox/build/cjs/syntax/parser.js | 158 + .../typebox/build/cjs/syntax/syntax.d.ts | 12 + .../typebox/build/cjs/syntax/syntax.js | 21 + .../typebox/build/cjs/system/index.d.ts | 2 + .../typebox/build/cjs/system/index.js | 19 + .../typebox/build/cjs/system/policy.d.ts | 29 + .../typebox/build/cjs/system/policy.js | 58 + .../typebox/build/cjs/system/system.d.ts | 16 + .../typebox/build/cjs/system/system.js | 43 + .../typebox/build/cjs/type/any/any.d.ts | 8 + .../typebox/build/cjs/type/any/any.js | 10 + .../typebox/build/cjs/type/any/index.d.ts | 1 + .../typebox/build/cjs/type/any/index.js | 18 + .../build/cjs/type/argument/argument.d.ts | 9 + .../build/cjs/type/argument/argument.js | 10 + .../build/cjs/type/argument/index.d.ts | 1 + .../typebox/build/cjs/type/argument/index.js | 18 + .../typebox/build/cjs/type/array/array.d.ts | 28 + .../typebox/build/cjs/type/array/array.js | 10 + .../typebox/build/cjs/type/array/index.d.ts | 1 + .../typebox/build/cjs/type/array/index.js | 18 + .../type/async-iterator/async-iterator.d.ts | 11 + .../cjs/type/async-iterator/async-iterator.js | 10 + .../build/cjs/type/async-iterator/index.d.ts | 1 + .../build/cjs/type/async-iterator/index.js | 18 + .../build/cjs/type/awaited/awaited.d.ts | 14 + .../typebox/build/cjs/type/awaited/awaited.js | 41 + .../typebox/build/cjs/type/awaited/index.d.ts | 1 + .../typebox/build/cjs/type/awaited/index.js | 18 + .../typebox/build/cjs/type/bigint/bigint.d.ts | 16 + .../typebox/build/cjs/type/bigint/bigint.js | 10 + .../typebox/build/cjs/type/bigint/index.d.ts | 1 + .../typebox/build/cjs/type/bigint/index.js | 18 + .../build/cjs/type/boolean/boolean.d.ts | 9 + .../typebox/build/cjs/type/boolean/boolean.js | 10 + .../typebox/build/cjs/type/boolean/index.d.ts | 1 + .../typebox/build/cjs/type/boolean/index.js | 18 + .../typebox/build/cjs/type/clone/index.d.ts | 2 + .../typebox/build/cjs/type/clone/index.js | 19 + .../typebox/build/cjs/type/clone/type.d.ts | 5 + .../typebox/build/cjs/type/clone/type.js | 14 + .../typebox/build/cjs/type/clone/value.d.ts | 2 + .../typebox/build/cjs/type/clone/value.js | 40 + .../build/cjs/type/composite/composite.d.ts | 18 + .../build/cjs/type/composite/composite.js | 46 + .../build/cjs/type/composite/index.d.ts | 1 + .../typebox/build/cjs/type/composite/index.js | 18 + .../build/cjs/type/computed/computed.d.ts | 9 + .../build/cjs/type/computed/computed.js | 10 + .../build/cjs/type/computed/index.d.ts | 1 + .../typebox/build/cjs/type/computed/index.js | 18 + .../typebox/build/cjs/type/const/const.d.ts | 27 + .../typebox/build/cjs/type/const/const.js | 58 + .../typebox/build/cjs/type/const/index.d.ts | 1 + .../typebox/build/cjs/type/const/index.js | 18 + .../constructor-parameters.d.ts | 7 + .../constructor-parameters.js | 11 + .../type/constructor-parameters/index.d.ts | 1 + .../cjs/type/constructor-parameters/index.js | 18 + .../cjs/type/constructor/constructor.d.ts | 23 + .../build/cjs/type/constructor/constructor.js | 10 + .../build/cjs/type/constructor/index.d.ts | 1 + .../build/cjs/type/constructor/index.js | 18 + .../build/cjs/type/create/immutable.d.ts | 2 + .../build/cjs/type/create/immutable.js | 37 + .../typebox/build/cjs/type/create/index.d.ts | 1 + .../typebox/build/cjs/type/create/index.js | 18 + .../typebox/build/cjs/type/create/type.d.ts | 3 + .../typebox/build/cjs/type/create/type.js | 19 + .../typebox/build/cjs/type/date/date.d.ts | 21 + .../typebox/build/cjs/type/date/date.js | 10 + .../typebox/build/cjs/type/date/index.d.ts | 1 + .../typebox/build/cjs/type/date/index.js | 18 + .../build/cjs/type/discard/discard.d.ts | 2 + .../typebox/build/cjs/type/discard/discard.js | 12 + .../typebox/build/cjs/type/discard/index.d.ts | 1 + .../typebox/build/cjs/type/discard/index.js | 18 + .../typebox/build/cjs/type/enum/enum.d.ts | 14 + .../typebox/build/cjs/type/enum/enum.js | 22 + .../typebox/build/cjs/type/enum/index.d.ts | 1 + .../typebox/build/cjs/type/enum/index.js | 18 + .../typebox/build/cjs/type/error/error.d.ts | 4 + .../typebox/build/cjs/type/error/error.js | 11 + .../typebox/build/cjs/type/error/index.d.ts | 1 + .../typebox/build/cjs/type/error/index.js | 18 + .../exclude/exclude-from-mapped-result.d.ts | 11 + .../exclude/exclude-from-mapped-result.js | 22 + .../exclude-from-template-literal.d.ts | 5 + .../exclude/exclude-from-template-literal.js | 9 + .../build/cjs/type/exclude/exclude.d.ts | 21 + .../typebox/build/cjs/type/exclude/exclude.js | 29 + .../typebox/build/cjs/type/exclude/index.d.ts | 3 + .../typebox/build/cjs/type/exclude/index.js | 20 + .../build/cjs/type/extends/extends-check.d.ts | 10 + .../build/cjs/type/extends/extends-check.js | 641 + .../type/extends/extends-from-mapped-key.d.ts | 14 + .../type/extends/extends-from-mapped-key.js | 29 + .../extends/extends-from-mapped-result.d.ts | 11 + .../extends/extends-from-mapped-result.js | 23 + .../cjs/type/extends/extends-undefined.d.ts | 3 + .../cjs/type/extends/extends-undefined.js | 24 + .../build/cjs/type/extends/extends.d.ts | 16 + .../typebox/build/cjs/type/extends/extends.js | 27 + .../typebox/build/cjs/type/extends/index.d.ts | 5 + .../typebox/build/cjs/type/extends/index.js | 22 + .../extract/extract-from-mapped-result.d.ts | 11 + .../extract/extract-from-mapped-result.js | 22 + .../extract-from-template-literal.d.ts | 5 + .../extract/extract-from-template-literal.js | 9 + .../build/cjs/type/extract/extract.d.ts | 21 + .../typebox/build/cjs/type/extract/extract.js | 29 + .../typebox/build/cjs/type/extract/index.d.ts | 3 + .../typebox/build/cjs/type/extract/index.js | 20 + .../build/cjs/type/function/function.d.ts | 23 + .../build/cjs/type/function/function.js | 10 + .../build/cjs/type/function/index.d.ts | 1 + .../typebox/build/cjs/type/function/index.js | 18 + .../typebox/build/cjs/type/guard/index.d.ts | 3 + .../typebox/build/cjs/type/guard/index.js | 7 + .../typebox/build/cjs/type/guard/kind.d.ts | 147 + .../typebox/build/cjs/type/guard/kind.js | 287 + .../typebox/build/cjs/type/guard/type.d.ts | 152 + .../typebox/build/cjs/type/guard/type.js | 564 + .../typebox/build/cjs/type/guard/value.d.ts | 34 + .../typebox/build/cjs/type/guard/value.js | 89 + .../build/cjs/type/helpers/helpers.d.ts | 42 + .../typebox/build/cjs/type/helpers/helpers.js | 8 + .../typebox/build/cjs/type/helpers/index.d.ts | 1 + .../typebox/build/cjs/type/helpers/index.js | 18 + .../typebox/build/cjs/type/index.d.ts | 71 + .../@sinclair/typebox/build/cjs/type/index.js | 88 + .../typebox/build/cjs/type/indexed/index.d.ts | 4 + .../typebox/build/cjs/type/indexed/index.js | 21 + .../type/indexed/indexed-from-mapped-key.d.ts | 13 + .../type/indexed/indexed-from-mapped-key.js | 26 + .../indexed/indexed-from-mapped-result.d.ts | 12 + .../indexed/indexed-from-mapped-result.js | 24 + .../type/indexed/indexed-property-keys.d.ts | 14 + .../cjs/type/indexed/indexed-property-keys.js | 36 + .../build/cjs/type/indexed/indexed.d.ts | 52 + .../typebox/build/cjs/type/indexed/indexed.js | 98 + .../build/cjs/type/instance-type/index.d.ts | 1 + .../build/cjs/type/instance-type/index.js | 18 + .../cjs/type/instance-type/instance-type.d.ts | 6 + .../cjs/type/instance-type/instance-type.js | 11 + .../build/cjs/type/instantiate/index.d.ts | 1 + .../build/cjs/type/instantiate/index.js | 18 + .../cjs/type/instantiate/instantiate.d.ts | 50 + .../build/cjs/type/instantiate/instantiate.js | 120 + .../typebox/build/cjs/type/integer/index.d.ts | 1 + .../typebox/build/cjs/type/integer/index.js | 18 + .../build/cjs/type/integer/integer.d.ts | 16 + .../typebox/build/cjs/type/integer/integer.js | 10 + .../build/cjs/type/intersect/index.d.ts | 3 + .../typebox/build/cjs/type/intersect/index.js | 20 + .../cjs/type/intersect/intersect-create.d.ts | 3 + .../cjs/type/intersect/intersect-create.js | 23 + .../type/intersect/intersect-evaluated.d.ts | 13 + .../cjs/type/intersect/intersect-evaluated.js | 42 + .../cjs/type/intersect/intersect-type.d.ts | 15 + .../cjs/type/intersect/intersect-type.js | 4 + .../build/cjs/type/intersect/intersect.d.ts | 6 + .../build/cjs/type/intersect/intersect.js | 21 + .../build/cjs/type/intrinsic/capitalize.d.ts | 5 + .../build/cjs/type/intrinsic/capitalize.js | 9 + .../build/cjs/type/intrinsic/index.d.ts | 6 + .../typebox/build/cjs/type/intrinsic/index.js | 23 + .../intrinsic/intrinsic-from-mapped-key.d.ts | 14 + .../intrinsic/intrinsic-from-mapped-key.js | 30 + .../build/cjs/type/intrinsic/intrinsic.d.ts | 16 + .../build/cjs/type/intrinsic/intrinsic.js | 68 + .../build/cjs/type/intrinsic/lowercase.d.ts | 5 + .../build/cjs/type/intrinsic/lowercase.js | 9 + .../cjs/type/intrinsic/uncapitalize.d.ts | 5 + .../build/cjs/type/intrinsic/uncapitalize.js | 9 + .../build/cjs/type/intrinsic/uppercase.d.ts | 5 + .../build/cjs/type/intrinsic/uppercase.js | 9 + .../build/cjs/type/iterator/index.d.ts | 1 + .../typebox/build/cjs/type/iterator/index.js | 18 + .../build/cjs/type/iterator/iterator.d.ts | 11 + .../build/cjs/type/iterator/iterator.js | 10 + .../typebox/build/cjs/type/keyof/index.d.ts | 4 + .../typebox/build/cjs/type/keyof/index.js | 21 + .../type/keyof/keyof-from-mapped-result.d.ts | 12 + .../type/keyof/keyof-from-mapped-result.js | 23 + .../type/keyof/keyof-property-entries.d.ts | 7 + .../cjs/type/keyof/keyof-property-entries.js | 16 + .../cjs/type/keyof/keyof-property-keys.d.ts | 24 + .../cjs/type/keyof/keyof-property-keys.js | 78 + .../typebox/build/cjs/type/keyof/keyof.d.ts | 21 + .../typebox/build/cjs/type/keyof/keyof.js | 40 + .../typebox/build/cjs/type/literal/index.d.ts | 1 + .../typebox/build/cjs/type/literal/index.js | 18 + .../build/cjs/type/literal/literal.d.ts | 10 + .../typebox/build/cjs/type/literal/literal.js | 14 + .../typebox/build/cjs/type/mapped/index.d.ts | 3 + .../typebox/build/cjs/type/mapped/index.js | 20 + .../build/cjs/type/mapped/mapped-key.d.ts | 8 + .../build/cjs/type/mapped/mapped-key.js | 13 + .../build/cjs/type/mapped/mapped-result.d.ts | 9 + .../build/cjs/type/mapped/mapped-result.js | 13 + .../typebox/build/cjs/type/mapped/mapped.d.ts | 47 + .../typebox/build/cjs/type/mapped/mapped.js | 107 + .../build/cjs/type/module/compute.d.ts | 59 + .../typebox/build/cjs/type/module/compute.js | 172 + .../typebox/build/cjs/type/module/index.d.ts | 1 + .../typebox/build/cjs/type/module/index.js | 18 + .../typebox/build/cjs/type/module/infer.d.ts | 48 + .../typebox/build/cjs/type/module/infer.js | 3 + .../typebox/build/cjs/type/module/module.d.ts | 27 + .../typebox/build/cjs/type/module/module.js | 38 + .../typebox/build/cjs/type/never/index.d.ts | 1 + .../typebox/build/cjs/type/never/index.js | 18 + .../typebox/build/cjs/type/never/never.d.ts | 9 + .../typebox/build/cjs/type/never/never.js | 10 + .../typebox/build/cjs/type/not/index.d.ts | 1 + .../typebox/build/cjs/type/not/index.js | 18 + .../typebox/build/cjs/type/not/not.d.ts | 10 + .../typebox/build/cjs/type/not/not.js | 10 + .../typebox/build/cjs/type/null/index.d.ts | 1 + .../typebox/build/cjs/type/null/index.js | 18 + .../typebox/build/cjs/type/null/null.d.ts | 9 + .../typebox/build/cjs/type/null/null.js | 10 + .../typebox/build/cjs/type/number/index.d.ts | 1 + .../typebox/build/cjs/type/number/index.js | 18 + .../typebox/build/cjs/type/number/number.d.ts | 16 + .../typebox/build/cjs/type/number/number.js | 10 + .../typebox/build/cjs/type/object/index.d.ts | 1 + .../typebox/build/cjs/type/object/index.js | 18 + .../typebox/build/cjs/type/object/object.d.ts | 44 + .../typebox/build/cjs/type/object/object.js | 26 + .../typebox/build/cjs/type/omit/index.d.ts | 3 + .../typebox/build/cjs/type/omit/index.js | 20 + .../cjs/type/omit/omit-from-mapped-key.d.ts | 12 + .../cjs/type/omit/omit-from-mapped-key.js | 26 + .../type/omit/omit-from-mapped-result.d.ts | 12 + .../cjs/type/omit/omit-from-mapped-result.js | 23 + .../typebox/build/cjs/type/omit/omit.d.ts | 36 + .../typebox/build/cjs/type/omit/omit.js | 75 + .../build/cjs/type/optional/index.d.ts | 2 + .../typebox/build/cjs/type/optional/index.js | 19 + .../optional/optional-from-mapped-result.d.ts | 10 + .../optional/optional-from-mapped-result.js | 22 + .../build/cjs/type/optional/optional.d.ts | 20 + .../build/cjs/type/optional/optional.js | 26 + .../build/cjs/type/parameters/index.d.ts | 1 + .../build/cjs/type/parameters/index.js | 18 + .../build/cjs/type/parameters/parameters.d.ts | 7 + .../build/cjs/type/parameters/parameters.js | 11 + .../typebox/build/cjs/type/partial/index.d.ts | 2 + .../typebox/build/cjs/type/partial/index.js | 19 + .../partial/partial-from-mapped-result.d.ts | 12 + .../partial/partial-from-mapped-result.js | 23 + .../build/cjs/type/partial/partial.d.ts | 35 + .../typebox/build/cjs/type/partial/partial.js | 78 + .../build/cjs/type/patterns/index.d.ts | 1 + .../typebox/build/cjs/type/patterns/index.js | 18 + .../build/cjs/type/patterns/patterns.d.ts | 8 + .../build/cjs/type/patterns/patterns.js | 12 + .../typebox/build/cjs/type/pick/index.d.ts | 3 + .../typebox/build/cjs/type/pick/index.js | 20 + .../cjs/type/pick/pick-from-mapped-key.d.ts | 12 + .../cjs/type/pick/pick-from-mapped-key.js | 28 + .../type/pick/pick-from-mapped-result.d.ts | 12 + .../cjs/type/pick/pick-from-mapped-result.js | 23 + .../typebox/build/cjs/type/pick/pick.d.ts | 36 + .../typebox/build/cjs/type/pick/pick.js | 70 + .../typebox/build/cjs/type/promise/index.d.ts | 1 + .../typebox/build/cjs/type/promise/index.js | 18 + .../build/cjs/type/promise/promise.d.ts | 11 + .../typebox/build/cjs/type/promise/promise.js | 10 + .../cjs/type/readonly-optional/index.d.ts | 1 + .../build/cjs/type/readonly-optional/index.js | 18 + .../readonly-optional/readonly-optional.d.ts | 6 + .../readonly-optional/readonly-optional.js | 10 + .../build/cjs/type/readonly/index.d.ts | 2 + .../typebox/build/cjs/type/readonly/index.js | 19 + .../readonly/readonly-from-mapped-result.d.ts | 10 + .../readonly/readonly-from-mapped-result.js | 22 + .../build/cjs/type/readonly/readonly.d.ts | 20 + .../build/cjs/type/readonly/readonly.js | 26 + .../typebox/build/cjs/type/record/index.d.ts | 1 + .../typebox/build/cjs/type/record/index.js | 18 + .../typebox/build/cjs/type/record/record.d.ts | 71 + .../typebox/build/cjs/type/record/record.js | 123 + .../build/cjs/type/recursive/index.d.ts | 1 + .../typebox/build/cjs/type/recursive/index.js | 18 + .../build/cjs/type/recursive/recursive.d.ts | 16 + .../build/cjs/type/recursive/recursive.js | 19 + .../typebox/build/cjs/type/ref/index.d.ts | 1 + .../typebox/build/cjs/type/ref/index.js | 18 + .../typebox/build/cjs/type/ref/ref.d.ts | 41 + .../typebox/build/cjs/type/ref/ref.js | 14 + .../typebox/build/cjs/type/regexp/index.d.ts | 1 + .../typebox/build/cjs/type/regexp/index.js | 18 + .../typebox/build/cjs/type/regexp/regexp.d.ts | 20 + .../typebox/build/cjs/type/regexp/regexp.js | 12 + .../build/cjs/type/registry/format.d.ts | 13 + .../typebox/build/cjs/type/registry/format.js | 35 + .../build/cjs/type/registry/index.d.ts | 2 + .../typebox/build/cjs/type/registry/index.js | 6 + .../typebox/build/cjs/type/registry/type.d.ts | 13 + .../typebox/build/cjs/type/registry/type.js | 35 + .../build/cjs/type/required/index.d.ts | 2 + .../typebox/build/cjs/type/required/index.js | 19 + .../required/required-from-mapped-result.d.ts | 12 + .../required/required-from-mapped-result.js | 22 + .../build/cjs/type/required/required.d.ts | 35 + .../build/cjs/type/required/required.js | 77 + .../typebox/build/cjs/type/rest/index.d.ts | 1 + .../typebox/build/cjs/type/rest/index.js | 18 + .../typebox/build/cjs/type/rest/rest.d.ts | 10 + .../typebox/build/cjs/type/rest/rest.js | 19 + .../build/cjs/type/return-type/index.d.ts | 1 + .../build/cjs/type/return-type/index.js | 18 + .../cjs/type/return-type/return-type.d.ts | 6 + .../build/cjs/type/return-type/return-type.js | 11 + .../build/cjs/type/schema/anyschema.d.ts | 33 + .../build/cjs/type/schema/anyschema.js | 3 + .../typebox/build/cjs/type/schema/index.d.ts | 2 + .../typebox/build/cjs/type/schema/index.js | 19 + .../typebox/build/cjs/type/schema/schema.d.ts | 29 + .../typebox/build/cjs/type/schema/schema.js | 4 + .../typebox/build/cjs/type/sets/index.d.ts | 1 + .../typebox/build/cjs/type/sets/index.js | 18 + .../typebox/build/cjs/type/sets/set.d.ts | 28 + .../typebox/build/cjs/type/sets/set.js | 59 + .../typebox/build/cjs/type/static/index.d.ts | 1 + .../typebox/build/cjs/type/static/index.js | 18 + .../typebox/build/cjs/type/static/static.d.ts | 39 + .../typebox/build/cjs/type/static/static.js | 3 + .../typebox/build/cjs/type/string/index.d.ts | 1 + .../typebox/build/cjs/type/string/index.js | 18 + .../typebox/build/cjs/type/string/string.d.ts | 25 + .../typebox/build/cjs/type/string/string.js | 10 + .../typebox/build/cjs/type/symbol/index.d.ts | 1 + .../typebox/build/cjs/type/symbol/index.js | 18 + .../typebox/build/cjs/type/symbol/symbol.d.ts | 10 + .../typebox/build/cjs/type/symbol/symbol.js | 10 + .../typebox/build/cjs/type/symbols/index.d.ts | 1 + .../typebox/build/cjs/type/symbols/index.js | 18 + .../build/cjs/type/symbols/symbols.d.ts | 10 + .../typebox/build/cjs/type/symbols/symbols.js | 14 + .../cjs/type/template-literal/finite.d.ts | 19 + .../build/cjs/type/template-literal/finite.js | 56 + .../cjs/type/template-literal/generate.d.ts | 21 + .../cjs/type/template-literal/generate.js | 60 + .../cjs/type/template-literal/index.d.ts | 7 + .../build/cjs/type/template-literal/index.js | 24 + .../cjs/type/template-literal/parse.d.ts | 20 + .../build/cjs/type/template-literal/parse.js | 174 + .../cjs/type/template-literal/pattern.d.ts | 5 + .../cjs/type/template-literal/pattern.js | 39 + .../cjs/type/template-literal/syntax.d.ts | 20 + .../build/cjs/type/template-literal/syntax.js | 59 + .../template-literal/template-literal.d.ts | 30 + .../type/template-literal/template-literal.js | 17 + .../cjs/type/template-literal/union.d.ts | 9 + .../build/cjs/type/template-literal/union.js | 13 + .../build/cjs/type/transform/index.d.ts | 1 + .../typebox/build/cjs/type/transform/index.js | 18 + .../build/cjs/type/transform/transform.d.ts | 30 + .../build/cjs/type/transform/transform.js | 47 + .../typebox/build/cjs/type/tuple/index.d.ts | 1 + .../typebox/build/cjs/type/tuple/index.js | 18 + .../typebox/build/cjs/type/tuple/tuple.d.ts | 16 + .../typebox/build/cjs/type/tuple/tuple.js | 13 + .../typebox/build/cjs/type/type/index.d.ts | 6 + .../typebox/build/cjs/type/type/index.js | 18 + .../build/cjs/type/type/javascript.d.ts | 64 + .../typebox/build/cjs/type/type/javascript.js | 104 + .../typebox/build/cjs/type/type/json.d.ts | 208 + .../typebox/build/cjs/type/type/json.js | 226 + .../typebox/build/cjs/type/type/type.d.ts | 59 + .../typebox/build/cjs/type/type/type.js | 129 + .../build/cjs/type/uint8array/index.d.ts | 1 + .../build/cjs/type/uint8array/index.js | 18 + .../build/cjs/type/uint8array/uint8array.d.ts | 13 + .../build/cjs/type/uint8array/uint8array.js | 10 + .../build/cjs/type/undefined/index.d.ts | 1 + .../typebox/build/cjs/type/undefined/index.js | 18 + .../build/cjs/type/undefined/undefined.d.ts | 9 + .../build/cjs/type/undefined/undefined.js | 10 + .../typebox/build/cjs/type/union/index.d.ts | 3 + .../typebox/build/cjs/type/union/index.js | 20 + .../build/cjs/type/union/union-create.d.ts | 3 + .../build/cjs/type/union/union-create.js | 9 + .../build/cjs/type/union/union-evaluated.d.ts | 13 + .../build/cjs/type/union/union-evaluated.js | 40 + .../build/cjs/type/union/union-type.d.ts | 12 + .../build/cjs/type/union/union-type.js | 4 + .../typebox/build/cjs/type/union/union.d.ts | 6 + .../typebox/build/cjs/type/union/union.js | 14 + .../typebox/build/cjs/type/unknown/index.d.ts | 1 + .../typebox/build/cjs/type/unknown/index.js | 18 + .../build/cjs/type/unknown/unknown.d.ts | 8 + .../typebox/build/cjs/type/unknown/unknown.js | 10 + .../typebox/build/cjs/type/unsafe/index.d.ts | 1 + .../typebox/build/cjs/type/unsafe/index.js | 18 + .../typebox/build/cjs/type/unsafe/unsafe.d.ts | 11 + .../typebox/build/cjs/type/unsafe/unsafe.js | 10 + .../typebox/build/cjs/type/void/index.d.ts | 1 + .../typebox/build/cjs/type/void/index.js | 18 + .../typebox/build/cjs/type/void/void.d.ts | 9 + .../typebox/build/cjs/type/void/void.js | 10 + .../build/cjs/value/assert/assert.d.ts | 15 + .../typebox/build/cjs/value/assert/assert.js | 55 + .../typebox/build/cjs/value/assert/index.d.ts | 1 + .../typebox/build/cjs/value/assert/index.js | 18 + .../typebox/build/cjs/value/cast/cast.d.ts | 11 + .../typebox/build/cjs/value/cast/cast.js | 220 + .../typebox/build/cjs/value/cast/index.d.ts | 1 + .../typebox/build/cjs/value/cast/index.js | 18 + .../typebox/build/cjs/value/check/check.d.ts | 11 + .../typebox/build/cjs/value/check/check.js | 475 + .../typebox/build/cjs/value/check/index.d.ts | 1 + .../typebox/build/cjs/value/check/index.js | 18 + .../typebox/build/cjs/value/clean/clean.d.ts | 5 + .../typebox/build/cjs/value/clean/clean.js | 149 + .../typebox/build/cjs/value/clean/index.d.ts | 1 + .../typebox/build/cjs/value/clean/index.js | 18 + .../typebox/build/cjs/value/clone/clone.d.ts | 2 + .../typebox/build/cjs/value/clone/clone.js | 60 + .../typebox/build/cjs/value/clone/index.d.ts | 1 + .../typebox/build/cjs/value/clone/index.js | 18 + .../build/cjs/value/convert/convert.d.ts | 5 + .../build/cjs/value/convert/convert.js | 257 + .../build/cjs/value/convert/index.d.ts | 1 + .../typebox/build/cjs/value/convert/index.js | 18 + .../build/cjs/value/create/create.d.ts | 11 + .../typebox/build/cjs/value/create/create.js | 483 + .../typebox/build/cjs/value/create/index.d.ts | 1 + .../typebox/build/cjs/value/create/index.js | 18 + .../build/cjs/value/decode/decode.d.ts | 6 + .../typebox/build/cjs/value/decode/decode.js | 14 + .../typebox/build/cjs/value/decode/index.d.ts | 1 + .../typebox/build/cjs/value/decode/index.js | 18 + .../build/cjs/value/default/default.d.ts | 5 + .../build/cjs/value/default/default.js | 176 + .../build/cjs/value/default/index.d.ts | 1 + .../typebox/build/cjs/value/default/index.js | 18 + .../typebox/build/cjs/value/delta/delta.d.ts | 32 + .../typebox/build/cjs/value/delta/delta.js | 178 + .../typebox/build/cjs/value/delta/index.d.ts | 1 + .../typebox/build/cjs/value/delta/index.js | 18 + .../typebox/build/cjs/value/deref/deref.d.ts | 12 + .../typebox/build/cjs/value/deref/deref.js | 36 + .../typebox/build/cjs/value/deref/index.d.ts | 1 + .../typebox/build/cjs/value/deref/index.js | 18 + .../build/cjs/value/encode/encode.d.ts | 6 + .../typebox/build/cjs/value/encode/encode.js | 15 + .../typebox/build/cjs/value/encode/index.d.ts | 1 + .../typebox/build/cjs/value/encode/index.js | 18 + .../typebox/build/cjs/value/equal/equal.d.ts | 2 + .../typebox/build/cjs/value/equal/equal.js | 50 + .../typebox/build/cjs/value/equal/index.d.ts | 1 + .../typebox/build/cjs/value/equal/index.js | 18 + .../typebox/build/cjs/value/guard/guard.d.ts | 74 + .../typebox/build/cjs/value/guard/guard.js | 195 + .../typebox/build/cjs/value/guard/index.d.ts | 1 + .../typebox/build/cjs/value/guard/index.js | 18 + .../typebox/build/cjs/value/hash/hash.d.ts | 7 + .../typebox/build/cjs/value/hash/hash.js | 152 + .../typebox/build/cjs/value/hash/index.d.ts | 1 + .../typebox/build/cjs/value/hash/index.js | 18 + .../typebox/build/cjs/value/index.d.ts | 20 + .../typebox/build/cjs/value/index.js | 53 + .../typebox/build/cjs/value/mutate/index.d.ts | 1 + .../typebox/build/cjs/value/mutate/index.js | 18 + .../build/cjs/value/mutate/mutate.d.ts | 9 + .../typebox/build/cjs/value/mutate/mutate.js | 104 + .../typebox/build/cjs/value/parse/index.d.ts | 1 + .../typebox/build/cjs/value/parse/index.js | 18 + .../typebox/build/cjs/value/parse/parse.d.ts | 22 + .../typebox/build/cjs/value/parse/parse.js | 87 + .../build/cjs/value/pointer/index.d.ts | 1 + .../typebox/build/cjs/value/pointer/index.js | 5 + .../build/cjs/value/pointer/pointer.d.ts | 22 + .../build/cjs/value/pointer/pointer.js | 126 + .../build/cjs/value/transform/decode.d.ts | 22 + .../build/cjs/value/transform/decode.js | 214 + .../build/cjs/value/transform/encode.d.ts | 23 + .../build/cjs/value/transform/encode.js | 225 + .../build/cjs/value/transform/has.d.ts | 3 + .../typebox/build/cjs/value/transform/has.js | 133 + .../build/cjs/value/transform/index.d.ts | 3 + .../build/cjs/value/transform/index.js | 20 + .../typebox/build/cjs/value/value/index.d.ts | 1 + .../typebox/build/cjs/value/value/index.js | 5 + .../typebox/build/cjs/value/value/value.d.ts | 16 + .../typebox/build/cjs/value/value/value.js | 39 + .../typebox/build/esm/compiler/compiler.d.mts | 55 + .../typebox/build/esm/compiler/compiler.mjs | 662 + .../typebox/build/esm/compiler/index.d.mts | 2 + .../typebox/build/esm/compiler/index.mjs | 2 + .../typebox/build/esm/errors/errors.d.mts | 91 + .../typebox/build/esm/errors/errors.mjs | 592 + .../typebox/build/esm/errors/function.d.mts | 21 + .../typebox/build/esm/errors/function.mjs | 147 + .../typebox/build/esm/errors/index.d.mts | 2 + .../typebox/build/esm/errors/index.mjs | 2 + .../@sinclair/typebox/build/esm/index.d.mts | 71 + .../@sinclair/typebox/build/esm/index.mjs | 80 + .../typebox/build/esm/parser/index.d.mts | 2 + .../typebox/build/esm/parser/index.mjs | 2 + .../build/esm/parser/runtime/guard.d.mts | 23 + .../build/esm/parser/runtime/guard.mjs | 72 + .../build/esm/parser/runtime/index.d.mts | 5 + .../build/esm/parser/runtime/index.mjs | 5 + .../build/esm/parser/runtime/module.d.mts | 9 + .../build/esm/parser/runtime/module.mjs | 17 + .../build/esm/parser/runtime/parse.d.mts | 9 + .../build/esm/parser/runtime/parse.mjs | 123 + .../build/esm/parser/runtime/token.d.mts | 8 + .../build/esm/parser/runtime/token.mjs | 223 + .../build/esm/parser/runtime/types.d.mts | 98 + .../build/esm/parser/runtime/types.mjs | 55 + .../build/esm/parser/static/index.d.mts | 3 + .../typebox/build/esm/parser/static/index.mjs | 3 + .../build/esm/parser/static/parse.d.mts | 20 + .../typebox/build/esm/parser/static/parse.mjs | 1 + .../build/esm/parser/static/token.d.mts | 108 + .../typebox/build/esm/parser/static/token.mjs | 1 + .../build/esm/parser/static/types.d.mts | 69 + .../typebox/build/esm/parser/static/types.mjs | 1 + .../typebox/build/esm/syntax/index.d.mts | 1 + .../typebox/build/esm/syntax/index.mjs | 1 + .../typebox/build/esm/syntax/mapping.d.mts | 167 + .../typebox/build/esm/syntax/mapping.mjs | 386 + .../typebox/build/esm/syntax/parser.d.mts | 162 + .../typebox/build/esm/syntax/parser.mjs | 78 + .../typebox/build/esm/syntax/syntax.d.mts | 12 + .../typebox/build/esm/syntax/syntax.mjs | 16 + .../typebox/build/esm/system/index.d.mts | 2 + .../typebox/build/esm/system/index.mjs | 2 + .../typebox/build/esm/system/policy.d.mts | 29 + .../typebox/build/esm/system/policy.mjs | 54 + .../typebox/build/esm/system/system.d.mts | 16 + .../typebox/build/esm/system/system.mjs | 37 + .../typebox/build/esm/type/any/any.d.mts | 8 + .../typebox/build/esm/type/any/any.mjs | 6 + .../typebox/build/esm/type/any/index.d.mts | 1 + .../typebox/build/esm/type/any/index.mjs | 1 + .../build/esm/type/argument/argument.d.mts | 9 + .../build/esm/type/argument/argument.mjs | 6 + .../build/esm/type/argument/index.d.mts | 1 + .../typebox/build/esm/type/argument/index.mjs | 1 + .../typebox/build/esm/type/array/array.d.mts | 28 + .../typebox/build/esm/type/array/array.mjs | 6 + .../typebox/build/esm/type/array/index.d.mts | 1 + .../typebox/build/esm/type/array/index.mjs | 1 + .../type/async-iterator/async-iterator.d.mts | 11 + .../type/async-iterator/async-iterator.mjs | 6 + .../build/esm/type/async-iterator/index.d.mts | 1 + .../build/esm/type/async-iterator/index.mjs | 1 + .../build/esm/type/awaited/awaited.d.mts | 14 + .../build/esm/type/awaited/awaited.mjs | 37 + .../build/esm/type/awaited/index.d.mts | 1 + .../typebox/build/esm/type/awaited/index.mjs | 1 + .../build/esm/type/bigint/bigint.d.mts | 16 + .../typebox/build/esm/type/bigint/bigint.mjs | 6 + .../typebox/build/esm/type/bigint/index.d.mts | 1 + .../typebox/build/esm/type/bigint/index.mjs | 1 + .../build/esm/type/boolean/boolean.d.mts | 9 + .../build/esm/type/boolean/boolean.mjs | 6 + .../build/esm/type/boolean/index.d.mts | 1 + .../typebox/build/esm/type/boolean/index.mjs | 1 + .../typebox/build/esm/type/clone/index.d.mts | 2 + .../typebox/build/esm/type/clone/index.mjs | 2 + .../typebox/build/esm/type/clone/type.d.mts | 5 + .../typebox/build/esm/type/clone/type.mjs | 9 + .../typebox/build/esm/type/clone/value.d.mts | 2 + .../typebox/build/esm/type/clone/value.mjs | 36 + .../build/esm/type/composite/composite.d.mts | 18 + .../build/esm/type/composite/composite.mjs | 42 + .../build/esm/type/composite/index.d.mts | 1 + .../build/esm/type/composite/index.mjs | 1 + .../build/esm/type/computed/computed.d.mts | 9 + .../build/esm/type/computed/computed.mjs | 6 + .../build/esm/type/computed/index.d.mts | 1 + .../typebox/build/esm/type/computed/index.mjs | 1 + .../typebox/build/esm/type/const/const.d.mts | 27 + .../typebox/build/esm/type/const/const.mjs | 54 + .../typebox/build/esm/type/const/index.d.mts | 1 + .../typebox/build/esm/type/const/index.mjs | 1 + .../constructor-parameters.d.mts | 7 + .../constructor-parameters.mjs | 7 + .../type/constructor-parameters/index.d.mts | 1 + .../esm/type/constructor-parameters/index.mjs | 1 + .../esm/type/constructor/constructor.d.mts | 23 + .../esm/type/constructor/constructor.mjs | 6 + .../build/esm/type/constructor/index.d.mts | 1 + .../build/esm/type/constructor/index.mjs | 1 + .../build/esm/type/create/immutable.d.mts | 2 + .../build/esm/type/create/immutable.mjs | 33 + .../typebox/build/esm/type/create/index.d.mts | 1 + .../typebox/build/esm/type/create/index.mjs | 1 + .../typebox/build/esm/type/create/type.d.mts | 3 + .../typebox/build/esm/type/create/type.mjs | 15 + .../typebox/build/esm/type/date/date.d.mts | 21 + .../typebox/build/esm/type/date/date.mjs | 6 + .../typebox/build/esm/type/date/index.d.mts | 1 + .../typebox/build/esm/type/date/index.mjs | 1 + .../build/esm/type/discard/discard.d.mts | 2 + .../build/esm/type/discard/discard.mjs | 8 + .../build/esm/type/discard/index.d.mts | 1 + .../typebox/build/esm/type/discard/index.mjs | 1 + .../typebox/build/esm/type/enum/enum.d.mts | 14 + .../typebox/build/esm/type/enum/enum.mjs | 18 + .../typebox/build/esm/type/enum/index.d.mts | 1 + .../typebox/build/esm/type/enum/index.mjs | 1 + .../typebox/build/esm/type/error/error.d.mts | 4 + .../typebox/build/esm/type/error/error.mjs | 6 + .../typebox/build/esm/type/error/index.d.mts | 1 + .../typebox/build/esm/type/error/index.mjs | 1 + .../exclude/exclude-from-mapped-result.d.mts | 11 + .../exclude/exclude-from-mapped-result.mjs | 18 + .../exclude-from-template-literal.d.mts | 5 + .../exclude/exclude-from-template-literal.mjs | 5 + .../build/esm/type/exclude/exclude.d.mts | 21 + .../build/esm/type/exclude/exclude.mjs | 25 + .../build/esm/type/exclude/index.d.mts | 3 + .../typebox/build/esm/type/exclude/index.mjs | 3 + .../esm/type/extends/extends-check.d.mts | 10 + .../build/esm/type/extends/extends-check.mjs | 635 + .../extends/extends-from-mapped-key.d.mts | 14 + .../type/extends/extends-from-mapped-key.mjs | 25 + .../extends/extends-from-mapped-result.d.mts | 11 + .../extends/extends-from-mapped-result.mjs | 19 + .../esm/type/extends/extends-undefined.d.mts | 3 + .../esm/type/extends/extends-undefined.mjs | 20 + .../build/esm/type/extends/extends.d.mts | 16 + .../build/esm/type/extends/extends.mjs | 23 + .../build/esm/type/extends/index.d.mts | 5 + .../typebox/build/esm/type/extends/index.mjs | 5 + .../extract/extract-from-mapped-result.d.mts | 11 + .../extract/extract-from-mapped-result.mjs | 18 + .../extract-from-template-literal.d.mts | 5 + .../extract/extract-from-template-literal.mjs | 5 + .../build/esm/type/extract/extract.d.mts | 21 + .../build/esm/type/extract/extract.mjs | 25 + .../build/esm/type/extract/index.d.mts | 3 + .../typebox/build/esm/type/extract/index.mjs | 3 + .../build/esm/type/function/function.d.mts | 23 + .../build/esm/type/function/function.mjs | 6 + .../build/esm/type/function/index.d.mts | 1 + .../typebox/build/esm/type/function/index.mjs | 1 + .../typebox/build/esm/type/guard/index.d.mts | 3 + .../typebox/build/esm/type/guard/index.mjs | 3 + .../typebox/build/esm/type/guard/kind.d.mts | 147 + .../typebox/build/esm/type/guard/kind.mjs | 235 + .../typebox/build/esm/type/guard/type.d.mts | 152 + .../typebox/build/esm/type/guard/type.mjs | 509 + .../typebox/build/esm/type/guard/value.d.mts | 34 + .../typebox/build/esm/type/guard/value.mjs | 70 + .../build/esm/type/helpers/helpers.d.mts | 42 + .../build/esm/type/helpers/helpers.mjs | 4 + .../build/esm/type/helpers/index.d.mts | 1 + .../typebox/build/esm/type/helpers/index.mjs | 1 + .../typebox/build/esm/type/index.d.mts | 71 + .../typebox/build/esm/type/index.mjs | 71 + .../build/esm/type/indexed/index.d.mts | 4 + .../typebox/build/esm/type/indexed/index.mjs | 4 + .../indexed/indexed-from-mapped-key.d.mts | 13 + .../type/indexed/indexed-from-mapped-key.mjs | 22 + .../indexed/indexed-from-mapped-result.d.mts | 12 + .../indexed/indexed-from-mapped-result.mjs | 20 + .../type/indexed/indexed-property-keys.d.mts | 14 + .../type/indexed/indexed-property-keys.mjs | 32 + .../build/esm/type/indexed/indexed.d.mts | 52 + .../build/esm/type/indexed/indexed.mjs | 91 + .../build/esm/type/instance-type/index.d.mts | 1 + .../build/esm/type/instance-type/index.mjs | 1 + .../type/instance-type/instance-type.d.mts | 6 + .../esm/type/instance-type/instance-type.mjs | 7 + .../build/esm/type/instantiate/index.d.mts | 1 + .../build/esm/type/instantiate/index.mjs | 1 + .../esm/type/instantiate/instantiate.d.mts | 50 + .../esm/type/instantiate/instantiate.mjs | 115 + .../build/esm/type/integer/index.d.mts | 1 + .../typebox/build/esm/type/integer/index.mjs | 1 + .../build/esm/type/integer/integer.d.mts | 16 + .../build/esm/type/integer/integer.mjs | 6 + .../build/esm/type/intersect/index.d.mts | 3 + .../build/esm/type/intersect/index.mjs | 3 + .../esm/type/intersect/intersect-create.d.mts | 3 + .../esm/type/intersect/intersect-create.mjs | 19 + .../type/intersect/intersect-evaluated.d.mts | 13 + .../type/intersect/intersect-evaluated.mjs | 38 + .../esm/type/intersect/intersect-type.d.mts | 15 + .../esm/type/intersect/intersect-type.mjs | 1 + .../build/esm/type/intersect/intersect.d.mts | 6 + .../build/esm/type/intersect/intersect.mjs | 17 + .../build/esm/type/intrinsic/capitalize.d.mts | 5 + .../build/esm/type/intrinsic/capitalize.mjs | 5 + .../build/esm/type/intrinsic/index.d.mts | 6 + .../build/esm/type/intrinsic/index.mjs | 6 + .../intrinsic/intrinsic-from-mapped-key.d.mts | 14 + .../intrinsic/intrinsic-from-mapped-key.mjs | 26 + .../build/esm/type/intrinsic/intrinsic.d.mts | 16 + .../build/esm/type/intrinsic/intrinsic.mjs | 64 + .../build/esm/type/intrinsic/lowercase.d.mts | 5 + .../build/esm/type/intrinsic/lowercase.mjs | 5 + .../esm/type/intrinsic/uncapitalize.d.mts | 5 + .../build/esm/type/intrinsic/uncapitalize.mjs | 5 + .../build/esm/type/intrinsic/uppercase.d.mts | 5 + .../build/esm/type/intrinsic/uppercase.mjs | 5 + .../build/esm/type/iterator/index.d.mts | 1 + .../typebox/build/esm/type/iterator/index.mjs | 1 + .../build/esm/type/iterator/iterator.d.mts | 11 + .../build/esm/type/iterator/iterator.mjs | 6 + .../typebox/build/esm/type/keyof/index.d.mts | 4 + .../typebox/build/esm/type/keyof/index.mjs | 4 + .../type/keyof/keyof-from-mapped-result.d.mts | 12 + .../type/keyof/keyof-from-mapped-result.mjs | 19 + .../type/keyof/keyof-property-entries.d.mts | 7 + .../esm/type/keyof/keyof-property-entries.mjs | 12 + .../esm/type/keyof/keyof-property-keys.d.mts | 24 + .../esm/type/keyof/keyof-property-keys.mjs | 73 + .../typebox/build/esm/type/keyof/keyof.d.mts | 21 + .../typebox/build/esm/type/keyof/keyof.mjs | 35 + .../build/esm/type/literal/index.d.mts | 1 + .../typebox/build/esm/type/literal/index.mjs | 1 + .../build/esm/type/literal/literal.d.mts | 10 + .../build/esm/type/literal/literal.mjs | 10 + .../typebox/build/esm/type/mapped/index.d.mts | 3 + .../typebox/build/esm/type/mapped/index.mjs | 3 + .../build/esm/type/mapped/mapped-key.d.mts | 8 + .../build/esm/type/mapped/mapped-key.mjs | 9 + .../build/esm/type/mapped/mapped-result.d.mts | 9 + .../build/esm/type/mapped/mapped-result.mjs | 9 + .../build/esm/type/mapped/mapped.d.mts | 47 + .../typebox/build/esm/type/mapped/mapped.mjs | 102 + .../build/esm/type/module/compute.d.mts | 59 + .../typebox/build/esm/type/module/compute.mjs | 166 + .../typebox/build/esm/type/module/index.d.mts | 1 + .../typebox/build/esm/type/module/index.mjs | 1 + .../typebox/build/esm/type/module/infer.d.mts | 48 + .../typebox/build/esm/type/module/infer.mjs | 1 + .../build/esm/type/module/module.d.mts | 27 + .../typebox/build/esm/type/module/module.mjs | 32 + .../typebox/build/esm/type/never/index.d.mts | 1 + .../typebox/build/esm/type/never/index.mjs | 1 + .../typebox/build/esm/type/never/never.d.mts | 9 + .../typebox/build/esm/type/never/never.mjs | 6 + .../typebox/build/esm/type/not/index.d.mts | 1 + .../typebox/build/esm/type/not/index.mjs | 1 + .../typebox/build/esm/type/not/not.d.mts | 10 + .../typebox/build/esm/type/not/not.mjs | 6 + .../typebox/build/esm/type/null/index.d.mts | 1 + .../typebox/build/esm/type/null/index.mjs | 1 + .../typebox/build/esm/type/null/null.d.mts | 9 + .../typebox/build/esm/type/null/null.mjs | 6 + .../typebox/build/esm/type/number/index.d.mts | 1 + .../typebox/build/esm/type/number/index.mjs | 1 + .../build/esm/type/number/number.d.mts | 16 + .../typebox/build/esm/type/number/number.mjs | 6 + .../typebox/build/esm/type/object/index.d.mts | 1 + .../typebox/build/esm/type/object/index.mjs | 1 + .../build/esm/type/object/object.d.mts | 44 + .../typebox/build/esm/type/object/object.mjs | 22 + .../typebox/build/esm/type/omit/index.d.mts | 3 + .../typebox/build/esm/type/omit/index.mjs | 3 + .../esm/type/omit/omit-from-mapped-key.d.mts | 12 + .../esm/type/omit/omit-from-mapped-key.mjs | 22 + .../type/omit/omit-from-mapped-result.d.mts | 12 + .../esm/type/omit/omit-from-mapped-result.mjs | 19 + .../typebox/build/esm/type/omit/omit.d.mts | 36 + .../typebox/build/esm/type/omit/omit.mjs | 71 + .../build/esm/type/optional/index.d.mts | 2 + .../typebox/build/esm/type/optional/index.mjs | 2 + .../optional-from-mapped-result.d.mts | 10 + .../optional/optional-from-mapped-result.mjs | 18 + .../build/esm/type/optional/optional.d.mts | 20 + .../build/esm/type/optional/optional.mjs | 22 + .../build/esm/type/parameters/index.d.mts | 1 + .../build/esm/type/parameters/index.mjs | 1 + .../esm/type/parameters/parameters.d.mts | 7 + .../build/esm/type/parameters/parameters.mjs | 7 + .../build/esm/type/partial/index.d.mts | 2 + .../typebox/build/esm/type/partial/index.mjs | 2 + .../partial/partial-from-mapped-result.d.mts | 12 + .../partial/partial-from-mapped-result.mjs | 19 + .../build/esm/type/partial/partial.d.mts | 35 + .../build/esm/type/partial/partial.mjs | 74 + .../build/esm/type/patterns/index.d.mts | 1 + .../typebox/build/esm/type/patterns/index.mjs | 1 + .../build/esm/type/patterns/patterns.d.mts | 8 + .../build/esm/type/patterns/patterns.mjs | 8 + .../typebox/build/esm/type/pick/index.d.mts | 3 + .../typebox/build/esm/type/pick/index.mjs | 3 + .../esm/type/pick/pick-from-mapped-key.d.mts | 12 + .../esm/type/pick/pick-from-mapped-key.mjs | 24 + .../type/pick/pick-from-mapped-result.d.mts | 12 + .../esm/type/pick/pick-from-mapped-result.mjs | 19 + .../typebox/build/esm/type/pick/pick.d.mts | 36 + .../typebox/build/esm/type/pick/pick.mjs | 66 + .../build/esm/type/promise/index.d.mts | 1 + .../typebox/build/esm/type/promise/index.mjs | 1 + .../build/esm/type/promise/promise.d.mts | 11 + .../build/esm/type/promise/promise.mjs | 6 + .../esm/type/readonly-optional/index.d.mts | 1 + .../esm/type/readonly-optional/index.mjs | 1 + .../readonly-optional/readonly-optional.d.mts | 6 + .../readonly-optional/readonly-optional.mjs | 6 + .../build/esm/type/readonly/index.d.mts | 2 + .../typebox/build/esm/type/readonly/index.mjs | 2 + .../readonly-from-mapped-result.d.mts | 10 + .../readonly/readonly-from-mapped-result.mjs | 18 + .../build/esm/type/readonly/readonly.d.mts | 20 + .../build/esm/type/readonly/readonly.mjs | 22 + .../typebox/build/esm/type/record/index.d.mts | 1 + .../typebox/build/esm/type/record/index.mjs | 1 + .../build/esm/type/record/record.d.mts | 71 + .../typebox/build/esm/type/record/record.mjs | 116 + .../build/esm/type/recursive/index.d.mts | 1 + .../build/esm/type/recursive/index.mjs | 1 + .../build/esm/type/recursive/recursive.d.mts | 16 + .../build/esm/type/recursive/recursive.mjs | 15 + .../typebox/build/esm/type/ref/index.d.mts | 1 + .../typebox/build/esm/type/ref/index.mjs | 1 + .../typebox/build/esm/type/ref/ref.d.mts | 41 + .../typebox/build/esm/type/ref/ref.mjs | 10 + .../typebox/build/esm/type/regexp/index.d.mts | 1 + .../typebox/build/esm/type/regexp/index.mjs | 1 + .../build/esm/type/regexp/regexp.d.mts | 20 + .../typebox/build/esm/type/regexp/regexp.mjs | 8 + .../build/esm/type/registry/format.d.mts | 13 + .../build/esm/type/registry/format.mjs | 26 + .../build/esm/type/registry/index.d.mts | 2 + .../typebox/build/esm/type/registry/index.mjs | 2 + .../build/esm/type/registry/type.d.mts | 13 + .../typebox/build/esm/type/registry/type.mjs | 26 + .../build/esm/type/required/index.d.mts | 2 + .../typebox/build/esm/type/required/index.mjs | 2 + .../required-from-mapped-result.d.mts | 12 + .../required/required-from-mapped-result.mjs | 18 + .../build/esm/type/required/required.d.mts | 35 + .../build/esm/type/required/required.mjs | 73 + .../typebox/build/esm/type/rest/index.d.mts | 1 + .../typebox/build/esm/type/rest/index.mjs | 1 + .../typebox/build/esm/type/rest/rest.d.mts | 10 + .../typebox/build/esm/type/rest/rest.mjs | 15 + .../build/esm/type/return-type/index.d.mts | 1 + .../build/esm/type/return-type/index.mjs | 1 + .../esm/type/return-type/return-type.d.mts | 6 + .../esm/type/return-type/return-type.mjs | 7 + .../build/esm/type/schema/anyschema.d.mts | 33 + .../build/esm/type/schema/anyschema.mjs | 1 + .../typebox/build/esm/type/schema/index.d.mts | 2 + .../typebox/build/esm/type/schema/index.mjs | 2 + .../build/esm/type/schema/schema.d.mts | 29 + .../typebox/build/esm/type/schema/schema.mjs | 1 + .../typebox/build/esm/type/sets/index.d.mts | 1 + .../typebox/build/esm/type/sets/index.mjs | 1 + .../typebox/build/esm/type/sets/set.d.mts | 28 + .../typebox/build/esm/type/sets/set.mjs | 48 + .../typebox/build/esm/type/static/index.d.mts | 1 + .../typebox/build/esm/type/static/index.mjs | 1 + .../build/esm/type/static/static.d.mts | 39 + .../typebox/build/esm/type/static/static.mjs | 1 + .../typebox/build/esm/type/string/index.d.mts | 1 + .../typebox/build/esm/type/string/index.mjs | 1 + .../build/esm/type/string/string.d.mts | 25 + .../typebox/build/esm/type/string/string.mjs | 6 + .../typebox/build/esm/type/symbol/index.d.mts | 1 + .../typebox/build/esm/type/symbol/index.mjs | 1 + .../build/esm/type/symbol/symbol.d.mts | 10 + .../typebox/build/esm/type/symbol/symbol.mjs | 6 + .../build/esm/type/symbols/index.d.mts | 1 + .../typebox/build/esm/type/symbols/index.mjs | 1 + .../build/esm/type/symbols/symbols.d.mts | 10 + .../build/esm/type/symbols/symbols.mjs | 10 + .../esm/type/template-literal/finite.d.mts | 19 + .../esm/type/template-literal/finite.mjs | 49 + .../esm/type/template-literal/generate.d.mts | 21 + .../esm/type/template-literal/generate.mjs | 53 + .../esm/type/template-literal/index.d.mts | 7 + .../build/esm/type/template-literal/index.mjs | 7 + .../esm/type/template-literal/parse.d.mts | 20 + .../build/esm/type/template-literal/parse.mjs | 167 + .../esm/type/template-literal/pattern.d.mts | 5 + .../esm/type/template-literal/pattern.mjs | 33 + .../esm/type/template-literal/syntax.d.mts | 20 + .../esm/type/template-literal/syntax.mjs | 55 + .../template-literal/template-literal.d.mts | 30 + .../template-literal/template-literal.mjs | 13 + .../esm/type/template-literal/union.d.mts | 9 + .../build/esm/type/template-literal/union.mjs | 9 + .../build/esm/type/transform/index.d.mts | 1 + .../build/esm/type/transform/index.mjs | 1 + .../build/esm/type/transform/transform.d.mts | 30 + .../build/esm/type/transform/transform.mjs | 40 + .../typebox/build/esm/type/tuple/index.d.mts | 1 + .../typebox/build/esm/type/tuple/index.mjs | 1 + .../typebox/build/esm/type/tuple/tuple.d.mts | 16 + .../typebox/build/esm/type/tuple/tuple.mjs | 9 + .../typebox/build/esm/type/type/index.d.mts | 6 + .../typebox/build/esm/type/type/index.mjs | 13 + .../build/esm/type/type/javascript.d.mts | 64 + .../build/esm/type/type/javascript.mjs | 99 + .../typebox/build/esm/type/type/json.d.mts | 208 + .../typebox/build/esm/type/type/json.mjs | 221 + .../typebox/build/esm/type/type/type.d.mts | 59 + .../typebox/build/esm/type/type/type.mjs | 62 + .../build/esm/type/uint8array/index.d.mts | 1 + .../build/esm/type/uint8array/index.mjs | 1 + .../esm/type/uint8array/uint8array.d.mts | 13 + .../build/esm/type/uint8array/uint8array.mjs | 6 + .../build/esm/type/undefined/index.d.mts | 1 + .../build/esm/type/undefined/index.mjs | 1 + .../build/esm/type/undefined/undefined.d.mts | 9 + .../build/esm/type/undefined/undefined.mjs | 6 + .../typebox/build/esm/type/union/index.d.mts | 3 + .../typebox/build/esm/type/union/index.mjs | 3 + .../build/esm/type/union/union-create.d.mts | 3 + .../build/esm/type/union/union-create.mjs | 5 + .../esm/type/union/union-evaluated.d.mts | 13 + .../build/esm/type/union/union-evaluated.mjs | 36 + .../build/esm/type/union/union-type.d.mts | 12 + .../build/esm/type/union/union-type.mjs | 1 + .../typebox/build/esm/type/union/union.d.mts | 6 + .../typebox/build/esm/type/union/union.mjs | 10 + .../build/esm/type/unknown/index.d.mts | 1 + .../typebox/build/esm/type/unknown/index.mjs | 1 + .../build/esm/type/unknown/unknown.d.mts | 8 + .../build/esm/type/unknown/unknown.mjs | 6 + .../typebox/build/esm/type/unsafe/index.d.mts | 1 + .../typebox/build/esm/type/unsafe/index.mjs | 1 + .../build/esm/type/unsafe/unsafe.d.mts | 11 + .../typebox/build/esm/type/unsafe/unsafe.mjs | 6 + .../typebox/build/esm/type/void/index.d.mts | 1 + .../typebox/build/esm/type/void/index.mjs | 1 + .../typebox/build/esm/type/void/void.d.mts | 9 + .../typebox/build/esm/type/void/void.mjs | 6 + .../build/esm/value/assert/assert.d.mts | 15 + .../typebox/build/esm/value/assert/assert.mjs | 49 + .../build/esm/value/assert/index.d.mts | 1 + .../typebox/build/esm/value/assert/index.mjs | 1 + .../typebox/build/esm/value/cast/cast.d.mts | 11 + .../typebox/build/esm/value/cast/cast.mjs | 214 + .../typebox/build/esm/value/cast/index.d.mts | 1 + .../typebox/build/esm/value/cast/index.mjs | 1 + .../typebox/build/esm/value/check/check.d.mts | 11 + .../typebox/build/esm/value/check/check.mjs | 469 + .../typebox/build/esm/value/check/index.d.mts | 1 + .../typebox/build/esm/value/check/index.mjs | 1 + .../typebox/build/esm/value/clean/clean.d.mts | 5 + .../typebox/build/esm/value/clean/clean.mjs | 145 + .../typebox/build/esm/value/clean/index.d.mts | 1 + .../typebox/build/esm/value/clean/index.mjs | 1 + .../typebox/build/esm/value/clone/clone.d.mts | 2 + .../typebox/build/esm/value/clone/clone.mjs | 56 + .../typebox/build/esm/value/clone/index.d.mts | 1 + .../typebox/build/esm/value/clone/index.mjs | 1 + .../build/esm/value/convert/convert.d.mts | 5 + .../build/esm/value/convert/convert.mjs | 253 + .../build/esm/value/convert/index.d.mts | 1 + .../typebox/build/esm/value/convert/index.mjs | 1 + .../build/esm/value/create/create.d.mts | 11 + .../typebox/build/esm/value/create/create.mjs | 477 + .../build/esm/value/create/index.d.mts | 1 + .../typebox/build/esm/value/create/index.mjs | 1 + .../build/esm/value/decode/decode.d.mts | 6 + .../typebox/build/esm/value/decode/decode.mjs | 10 + .../build/esm/value/decode/index.d.mts | 1 + .../typebox/build/esm/value/decode/index.mjs | 1 + .../build/esm/value/default/default.d.mts | 5 + .../build/esm/value/default/default.mjs | 172 + .../build/esm/value/default/index.d.mts | 1 + .../typebox/build/esm/value/default/index.mjs | 1 + .../typebox/build/esm/value/delta/delta.d.mts | 32 + .../typebox/build/esm/value/delta/delta.mjs | 171 + .../typebox/build/esm/value/delta/index.d.mts | 1 + .../typebox/build/esm/value/delta/index.mjs | 1 + .../typebox/build/esm/value/deref/deref.d.mts | 12 + .../typebox/build/esm/value/deref/deref.mjs | 29 + .../typebox/build/esm/value/deref/index.d.mts | 1 + .../typebox/build/esm/value/deref/index.mjs | 1 + .../build/esm/value/encode/encode.d.mts | 6 + .../typebox/build/esm/value/encode/encode.mjs | 11 + .../build/esm/value/encode/index.d.mts | 1 + .../typebox/build/esm/value/encode/index.mjs | 1 + .../typebox/build/esm/value/equal/equal.d.mts | 2 + .../typebox/build/esm/value/equal/equal.mjs | 46 + .../typebox/build/esm/value/equal/index.d.mts | 1 + .../typebox/build/esm/value/equal/index.mjs | 1 + .../typebox/build/esm/value/guard/guard.d.mts | 74 + .../typebox/build/esm/value/guard/guard.mjs | 158 + .../typebox/build/esm/value/guard/index.d.mts | 1 + .../typebox/build/esm/value/guard/index.mjs | 1 + .../typebox/build/esm/value/hash/hash.d.mts | 7 + .../typebox/build/esm/value/hash/hash.mjs | 146 + .../typebox/build/esm/value/hash/index.d.mts | 1 + .../typebox/build/esm/value/hash/index.mjs | 1 + .../typebox/build/esm/value/index.d.mts | 20 + .../typebox/build/esm/value/index.mjs | 32 + .../build/esm/value/mutate/index.d.mts | 1 + .../typebox/build/esm/value/mutate/index.mjs | 1 + .../build/esm/value/mutate/mutate.d.mts | 9 + .../typebox/build/esm/value/mutate/mutate.mjs | 98 + .../typebox/build/esm/value/parse/index.d.mts | 1 + .../typebox/build/esm/value/parse/index.mjs | 1 + .../typebox/build/esm/value/parse/parse.d.mts | 22 + .../typebox/build/esm/value/parse/parse.mjs | 81 + .../build/esm/value/pointer/index.d.mts | 1 + .../typebox/build/esm/value/pointer/index.mjs | 1 + .../build/esm/value/pointer/pointer.d.mts | 22 + .../build/esm/value/pointer/pointer.mjs | 115 + .../build/esm/value/transform/decode.d.mts | 22 + .../build/esm/value/transform/decode.mjs | 207 + .../build/esm/value/transform/encode.d.mts | 23 + .../build/esm/value/transform/encode.mjs | 218 + .../build/esm/value/transform/has.d.mts | 3 + .../typebox/build/esm/value/transform/has.mjs | 129 + .../build/esm/value/transform/index.d.mts | 3 + .../build/esm/value/transform/index.mjs | 3 + .../typebox/build/esm/value/value/index.d.mts | 1 + .../typebox/build/esm/value/value/index.mjs | 1 + .../typebox/build/esm/value/value/value.d.mts | 16 + .../typebox/build/esm/value/value/value.mjs | 16 + .../@sinclair/typebox/compiler/package.json | 4 + .../@sinclair/typebox/errors/package.json | 4 + .../node_modules/@sinclair/typebox/license | 25 + .../@sinclair/typebox/package.json | 116 + .../@sinclair/typebox/parser/package.json | 4 + .../node_modules/@sinclair/typebox/readme.md | 1860 ++ .../@sinclair/typebox/syntax/package.json | 4 + .../@sinclair/typebox/system/package.json | 4 + .../@sinclair/typebox/type/package.json | 4 + .../@sinclair/typebox/value/package.json | 4 + .../node_modules/@types/node/LICENSE | 21 + .../node_modules/@types/node/README.md | 15 + .../node_modules/@types/node/assert.d.ts | 1095 + .../@types/node/assert/strict.d.ts | 8 + .../node_modules/@types/node/async_hooks.d.ts | 541 + .../@types/node/buffer.buffer.d.ts | 460 + .../node_modules/@types/node/buffer.d.ts | 1926 ++ .../@types/node/child_process.d.ts | 1549 ++ .../node_modules/@types/node/cluster.d.ts | 579 + .../@types/node/compatibility/disposable.d.ts | 16 + .../@types/node/compatibility/index.d.ts | 9 + .../@types/node/compatibility/indexable.d.ts | 23 + .../@types/node/compatibility/iterators.d.ts | 21 + .../node_modules/@types/node/console.d.ts | 452 + .../node_modules/@types/node/constants.d.ts | 21 + .../node_modules/@types/node/crypto.d.ts | 4510 ++++ .../node_modules/@types/node/dgram.d.ts | 599 + .../@types/node/diagnostics_channel.d.ts | 554 + .../node_modules/@types/node/dns.d.ts | 865 + .../@types/node/dns/promises.d.ts | 476 + .../node_modules/@types/node/dom-events.d.ts | 124 + .../node_modules/@types/node/domain.d.ts | 170 + .../node_modules/@types/node/events.d.ts | 931 + .../node_modules/@types/node/fs.d.ts | 4353 ++++ .../node_modules/@types/node/fs/promises.d.ts | 1275 ++ .../node_modules/@types/node/globals.d.ts | 511 + .../@types/node/globals.typedarray.d.ts | 21 + .../node_modules/@types/node/http.d.ts | 1959 ++ .../node_modules/@types/node/http2.d.ts | 2558 +++ .../node_modules/@types/node/https.d.ts | 545 + .../node_modules/@types/node/index.d.ts | 92 + .../node_modules/@types/node/inspector.d.ts | 3966 ++++ .../node_modules/@types/node/module.d.ts | 747 + .../node_modules/@types/node/net.d.ts | 1029 + .../node_modules/@types/node/os.d.ts | 495 + .../node_modules/@types/node/package.json | 220 + .../node_modules/@types/node/path.d.ts | 200 + .../node_modules/@types/node/perf_hooks.d.ts | 970 + .../node_modules/@types/node/process.d.ts | 2041 ++ .../node_modules/@types/node/punycode.d.ts | 117 + .../node_modules/@types/node/querystring.d.ts | 153 + .../node_modules/@types/node/readline.d.ts | 589 + .../@types/node/readline/promises.d.ts | 162 + .../node_modules/@types/node/repl.d.ts | 430 + .../node_modules/@types/node/sea.d.ts | 153 + .../node_modules/@types/node/sqlite.d.ts | 485 + .../node_modules/@types/node/stream.d.ts | 1662 ++ .../@types/node/stream/consumers.d.ts | 38 + .../@types/node/stream/promises.d.ts | 90 + .../node_modules/@types/node/stream/web.d.ts | 614 + .../@types/node/string_decoder.d.ts | 67 + .../node_modules/@types/node/test.d.ts | 2232 ++ .../node_modules/@types/node/timers.d.ts | 287 + .../@types/node/timers/promises.d.ts | 108 + .../node_modules/@types/node/tls.d.ts | 1226 ++ .../@types/node/trace_events.d.ts | 197 + .../@types/node/ts5.6/buffer.buffer.d.ts | 457 + .../@types/node/ts5.6/globals.typedarray.d.ts | 19 + .../node_modules/@types/node/ts5.6/index.d.ts | 92 + .../node_modules/@types/node/tty.d.ts | 208 + .../node_modules/@types/node/url.d.ts | 972 + .../node_modules/@types/node/util.d.ts | 2452 +++ .../node_modules/@types/node/v8.d.ts | 808 + .../node_modules/@types/node/vm.d.ts | 976 + .../node_modules/@types/node/wasi.d.ts | 181 + .../@types/node/worker_threads.d.ts | 746 + .../node_modules/@types/node/zlib.d.ts | 539 + .../node_modules/undici-types | 1 + .../@types+ws@8.18.1/node_modules/@types/node | 1 + .../node_modules/@types/ws/LICENSE | 21 + .../node_modules/@types/ws/README.md | 15 + .../node_modules/@types/ws/index.d.mts | 451 + .../node_modules/@types/ws/index.d.ts | 445 + .../node_modules/@types/ws/package.json | 72 + .../async_event_emitter/CHANGELOG.md | 111 + .../async_event_emitter/LICENSE.md | 24 + .../@vladfrangu/async_event_emitter/README.md | 51 + .../THIRD_PARTY_LICENSE.md | 23 + .../async_event_emitter/dist/index.cjs | 590 + .../async_event_emitter/dist/index.cjs.map | 1 + .../async_event_emitter/dist/index.d.mts | 76 + .../async_event_emitter/dist/index.d.ts | 76 + .../async_event_emitter/dist/index.global.js | 592 + .../dist/index.global.js.map | 1 + .../async_event_emitter/dist/index.mjs | 571 + .../async_event_emitter/dist/index.mjs.map | 1 + .../async_event_emitter/package.json | 111 + .../bun-types@1.2.9/node_modules/@types/node | 1 + .../bun-types@1.2.9/node_modules/@types/ws | 1 + .../node_modules/bun-types/README.md | 33 + .../node_modules/bun-types/bun.d.ts | 7572 +++++++ .../node_modules/bun-types/bun.ns.d.ts | 7 + .../node_modules/bun-types/deprecated.d.ts | 74 + .../node_modules/bun-types/devserver.d.ts | 189 + .../bun-types/docs/api/binary-data.md | 1028 + .../node_modules/bun-types/docs/api/cc.md | 197 + .../node_modules/bun-types/docs/api/color.md | 262 + .../bun-types/docs/api/console.md | 38 + .../node_modules/bun-types/docs/api/cookie.md | 449 + .../node_modules/bun-types/docs/api/dns.md | 113 + .../node_modules/bun-types/docs/api/fetch.md | 463 + .../node_modules/bun-types/docs/api/ffi.md | 557 + .../bun-types/docs/api/file-io.md | 366 + .../bun-types/docs/api/file-system-router.md | 112 + .../node_modules/bun-types/docs/api/file.md | 19 + .../node_modules/bun-types/docs/api/glob.md | 157 + .../bun-types/docs/api/globals.md | 387 + .../bun-types/docs/api/hashing.md | 317 + .../bun-types/docs/api/html-rewriter.md | 334 + .../node_modules/bun-types/docs/api/http.md | 1340 ++ .../bun-types/docs/api/import-meta.md | 69 + .../bun-types/docs/api/node-api.md | 14 + .../node_modules/bun-types/docs/api/redis.md | 514 + .../node_modules/bun-types/docs/api/s3.md | 750 + .../node_modules/bun-types/docs/api/semver.md | 52 + .../node_modules/bun-types/docs/api/spawn.md | 562 + .../node_modules/bun-types/docs/api/sql.md | 674 + .../node_modules/bun-types/docs/api/sqlite.md | 692 + .../bun-types/docs/api/streams.md | 214 + .../node_modules/bun-types/docs/api/tcp.md | 221 + .../node_modules/bun-types/docs/api/test.md | 1 + .../bun-types/docs/api/transpiler.md | 276 + .../node_modules/bun-types/docs/api/udp.md | 125 + .../node_modules/bun-types/docs/api/utils.md | 798 + .../bun-types/docs/api/websockets.md | 547 + .../bun-types/docs/api/workers.md | 244 + .../node_modules/bun-types/docs/benchmarks.md | 120 + .../bun-types/docs/bun-flavored-toml.md | 42 + .../bun-types/docs/bundler/css.md | 1028 + .../bun-types/docs/bundler/css_modules.md | 145 + .../bun-types/docs/bundler/executables.md | 357 + .../bun-types/docs/bundler/fullstack.md | 312 + .../bun-types/docs/bundler/hmr.md | 234 + .../bun-types/docs/bundler/html.md | 306 + .../bun-types/docs/bundler/index.md | 1633 ++ .../bun-types/docs/bundler/intro.md | 75 + .../bun-types/docs/bundler/loaders.md | 347 + .../bun-types/docs/bundler/macros.md | 327 + .../bun-types/docs/bundler/plugins.md | 400 + .../bun-types/docs/bundler/vs-esbuild.md | 1127 + .../node_modules/bun-types/docs/cli/add.md | 173 + .../bun-types/docs/cli/bun-completions.md | 3 + .../bun-types/docs/cli/bun-create.md | 341 + .../bun-types/docs/cli/bun-install.md | 248 + .../bun-types/docs/cli/bun-upgrade.md | 39 + .../node_modules/bun-types/docs/cli/bunx.md | 80 + .../node_modules/bun-types/docs/cli/filter.md | 90 + .../node_modules/bun-types/docs/cli/init.md | 42 + .../bun-types/docs/cli/install.md | 239 + .../node_modules/bun-types/docs/cli/link.md | 40 + .../bun-types/docs/cli/outdated.md | 47 + .../bun-types/docs/cli/patch-commit.md | 11 + .../node_modules/bun-types/docs/cli/pm.md | 153 + .../bun-types/docs/cli/publish.md | 112 + .../node_modules/bun-types/docs/cli/remove.md | 7 + .../node_modules/bun-types/docs/cli/run.md | 209 + .../node_modules/bun-types/docs/cli/test.md | 251 + .../node_modules/bun-types/docs/cli/unlink.md | 9 + .../node_modules/bun-types/docs/cli/update.md | 36 + .../docs/contributing/upgrading-webkit.md | 57 + .../bun-types/docs/ecosystem/elysia.md | 24 + .../bun-types/docs/ecosystem/express.md | 37 + .../bun-types/docs/ecosystem/hono.md | 18 + .../bun-types/docs/ecosystem/react.md | 65 + .../bun-types/docs/ecosystem/stric.md | 37 + .../guides/binary/arraybuffer-to-array.md | 27 + .../docs/guides/binary/arraybuffer-to-blob.md | 24 + .../guides/binary/arraybuffer-to-buffer.md | 25 + .../guides/binary/arraybuffer-to-string.md | 15 + .../binary/arraybuffer-to-typedarray.md | 39 + .../docs/guides/binary/blob-to-arraybuffer.md | 14 + .../docs/guides/binary/blob-to-dataview.md | 14 + .../docs/guides/binary/blob-to-stream.md | 14 + .../docs/guides/binary/blob-to-string.md | 15 + .../docs/guides/binary/blob-to-typedarray.md | 14 + .../guides/binary/buffer-to-arraybuffer.md | 14 + .../docs/guides/binary/buffer-to-blob.md | 14 + .../guides/binary/buffer-to-readablestream.md | 41 + .../docs/guides/binary/buffer-to-string.md | 25 + .../guides/binary/buffer-to-typedarray.md | 14 + .../docs/guides/binary/dataview-to-string.md | 15 + .../binary/typedarray-to-arraybuffer.md | 25 + .../docs/guides/binary/typedarray-to-blob.md | 16 + .../guides/binary/typedarray-to-buffer.md | 14 + .../guides/binary/typedarray-to-dataview.md | 14 + .../binary/typedarray-to-readablestream.md | 41 + .../guides/binary/typedarray-to-string.md | 16 + .../bun-types/docs/guides/ecosystem/astro.md | 72 + .../docs/guides/ecosystem/discordjs.md | 77 + .../bun-types/docs/guides/ecosystem/docker.md | 140 + .../docs/guides/ecosystem/drizzle.md | 185 + .../bun-types/docs/guides/ecosystem/edgedb.md | 228 + .../bun-types/docs/guides/ecosystem/elysia.md | 31 + .../docs/guides/ecosystem/express.md | 40 + .../bun-types/docs/guides/ecosystem/hono.md | 39 + .../docs/guides/ecosystem/mongoose.md | 87 + .../docs/guides/ecosystem/neon-drizzle.md | 220 + .../ecosystem/neon-serverless-postgres.md | 55 + .../bun-types/docs/guides/ecosystem/nextjs.md | 48 + .../bun-types/docs/guides/ecosystem/nuxt.md | 56 + .../bun-types/docs/guides/ecosystem/pm2.md | 57 + .../bun-types/docs/guides/ecosystem/prisma.md | 140 + .../bun-types/docs/guides/ecosystem/qwik.md | 107 + .../bun-types/docs/guides/ecosystem/react.md | 49 + .../bun-types/docs/guides/ecosystem/remix.md | 78 + .../bun-types/docs/guides/ecosystem/render.md | 79 + .../bun-types/docs/guides/ecosystem/sentry.md | 52 + .../docs/guides/ecosystem/solidstart.md | 58 + .../docs/guides/ecosystem/ssr-react.md | 51 + .../bun-types/docs/guides/ecosystem/stric.md | 55 + .../docs/guides/ecosystem/sveltekit.md | 125 + .../docs/guides/ecosystem/systemd.md | 113 + .../bun-types/docs/guides/ecosystem/vite.md | 70 + .../guides/html-rewriter/extract-links.md | 68 + .../html-rewriter/extract-social-meta.md | 93 + .../bun-types/docs/guides/http/cluster.md | 66 + .../bun-types/docs/guides/http/fetch-unix.md | 33 + .../bun-types/docs/guides/http/fetch.md | 24 + .../docs/guides/http/file-uploads.md | 94 + .../bun-types/docs/guides/http/hot.md | 26 + .../bun-types/docs/guides/http/proxy.md | 24 + .../bun-types/docs/guides/http/server.md | 46 + .../bun-types/docs/guides/http/simple.md | 18 + .../bun-types/docs/guides/http/stream-file.md | 48 + .../docs/guides/http/stream-iterator.md | 47 + .../guides/http/stream-node-streams-in-bun.md | 20 + .../bun-types/docs/guides/http/tls.md | 30 + .../bun-types/docs/guides/install/add-dev.md | 26 + .../bun-types/docs/guides/install/add-git.md | 36 + .../docs/guides/install/add-optional.md | 25 + .../bun-types/docs/guides/install/add-peer.md | 44 + .../docs/guides/install/add-tarball.md | 33 + .../bun-types/docs/guides/install/add.md | 42 + .../docs/guides/install/azure-artifacts.md | 73 + .../bun-types/docs/guides/install/cicd.md | 41 + .../docs/guides/install/custom-registry.md | 30 + .../from-npm-install-to-bun-install.md | 214 + .../guides/install/git-diff-bun-lockfile.md | 44 + .../docs/guides/install/jfrog-artifactory.md | 28 + .../docs/guides/install/npm-alias.md | 23 + .../docs/guides/install/registry-scope.md | 38 + .../bun-types/docs/guides/install/trusted.md | 46 + .../docs/guides/install/workspaces.md | 70 + .../bun-types/docs/guides/install/yarnlock.md | 44 + .../bun-types/docs/guides/process/argv.md | 59 + .../bun-types/docs/guides/process/ctrl-c.md | 16 + .../bun-types/docs/guides/process/ipc.md | 66 + .../docs/guides/process/nanoseconds.md | 13 + .../docs/guides/process/os-signals.md | 39 + .../docs/guides/process/spawn-stderr.md | 31 + .../docs/guides/process/spawn-stdout.md | 26 + .../bun-types/docs/guides/process/spawn.md | 41 + .../bun-types/docs/guides/process/stdin.md | 54 + .../docs/guides/read-file/arraybuffer.md | 28 + .../bun-types/docs/guides/read-file/buffer.md | 19 + .../bun-types/docs/guides/read-file/exists.md | 16 + .../bun-types/docs/guides/read-file/json.md | 17 + .../bun-types/docs/guides/read-file/mime.md | 20 + .../bun-types/docs/guides/read-file/stream.md | 26 + .../bun-types/docs/guides/read-file/string.md | 22 + .../docs/guides/read-file/uint8array.md | 21 + .../bun-types/docs/guides/read-file/watch.md | 68 + .../bun-types/docs/guides/runtime/cicd.md | 43 + .../runtime/codesign-macos-executable.md | 56 + .../docs/guides/runtime/define-constant.md | 145 + .../docs/guides/runtime/delete-directory.md | 37 + .../docs/guides/runtime/delete-file.md | 19 + .../docs/guides/runtime/heap-snapshot.md | 26 + .../docs/guides/runtime/import-html.md | 15 + .../docs/guides/runtime/import-json.md | 44 + .../docs/guides/runtime/import-toml.md | 30 + .../bun-types/docs/guides/runtime/read-env.md | 32 + .../bun-types/docs/guides/runtime/set-env.md | 48 + .../bun-types/docs/guides/runtime/shell.md | 40 + .../bun-types/docs/guides/runtime/timezone.md | 35 + .../docs/guides/runtime/tsconfig-paths.md | 29 + .../docs/guides/runtime/typescript.md | 48 + .../docs/guides/runtime/vscode-debugger.md | 47 + .../docs/guides/runtime/web-debugger.md | 82 + .../streams/node-readable-to-arraybuffer.md | 11 + .../guides/streams/node-readable-to-blob.md | 11 + .../guides/streams/node-readable-to-json.md | 12 + .../guides/streams/node-readable-to-string.md | 12 + .../streams/node-readable-to-uint8array.md | 11 + .../bun-types/docs/guides/streams/to-array.md | 14 + .../docs/guides/streams/to-arraybuffer.md | 14 + .../bun-types/docs/guides/streams/to-blob.md | 14 + .../docs/guides/streams/to-buffer.md | 15 + .../bun-types/docs/guides/streams/to-json.md | 14 + .../docs/guides/streams/to-string.md | 14 + .../docs/guides/streams/to-typedarray.md | 22 + .../bun-types/docs/guides/test/bail.md | 22 + .../docs/guides/test/coverage-threshold.md | 60 + .../bun-types/docs/guides/test/coverage.md | 44 + .../bun-types/docs/guides/test/happy-dom.md | 68 + .../docs/guides/test/migrate-from-jest.md | 109 + .../bun-types/docs/guides/test/mock-clock.md | 48 + .../docs/guides/test/mock-functions.md | 68 + .../bun-types/docs/guides/test/rerun-each.md | 14 + .../bun-types/docs/guides/test/run-tests.md | 111 + .../bun-types/docs/guides/test/skip-tests.md | 39 + .../bun-types/docs/guides/test/snapshot.md | 95 + .../bun-types/docs/guides/test/spy-on.md | 46 + .../bun-types/docs/guides/test/svelte-test.md | 120 + .../docs/guides/test/testing-library.md | 87 + .../bun-types/docs/guides/test/timeout.md | 15 + .../bun-types/docs/guides/test/todo-tests.md | 67 + .../docs/guides/test/update-snapshots.md | 46 + .../bun-types/docs/guides/test/watch-mode.md | 19 + .../bun-types/docs/guides/util/base64.md | 15 + .../bun-types/docs/guides/util/deep-equals.md | 39 + .../bun-types/docs/guides/util/deflate.md | 18 + .../bun-types/docs/guides/util/detect-bun.md | 23 + .../bun-types/docs/guides/util/entrypoint.md | 17 + .../bun-types/docs/guides/util/escape-html.md | 22 + .../docs/guides/util/file-url-to-path.md | 14 + .../bun-types/docs/guides/util/gzip.md | 18 + .../docs/guides/util/hash-a-password.md | 54 + .../docs/guides/util/import-meta-dir.md | 13 + .../docs/guides/util/import-meta-file.md | 13 + .../docs/guides/util/import-meta-path.md | 13 + .../bun-types/docs/guides/util/main.md | 32 + .../docs/guides/util/path-to-file-url.md | 14 + .../bun-types/docs/guides/util/sleep.md | 22 + .../bun-types/docs/guides/util/version.md | 21 + .../util/which-path-to-executable-bin.md | 15 + .../docs/guides/websocket/compression.md | 31 + .../docs/guides/websocket/context.md | 72 + .../bun-types/docs/guides/websocket/pubsub.md | 38 + .../bun-types/docs/guides/websocket/simple.md | 33 + .../docs/guides/write-file/append.md | 52 + .../bun-types/docs/guides/write-file/basic.md | 44 + .../bun-types/docs/guides/write-file/blob.md | 28 + .../bun-types/docs/guides/write-file/cat.md | 17 + .../docs/guides/write-file/file-cp.md | 16 + .../docs/guides/write-file/filesink.md | 52 + .../docs/guides/write-file/response.md | 17 + .../docs/guides/write-file/stdout.md | 21 + .../docs/guides/write-file/stream.md | 17 + .../docs/guides/write-file/unlink.md | 16 + .../node_modules/bun-types/docs/index.md | 77 + .../bun-types/docs/install/cache.md | 59 + .../bun-types/docs/install/index.md | 224 + .../bun-types/docs/install/lifecycle.md | 46 + .../bun-types/docs/install/lockfile.md | 48 + .../bun-types/docs/install/npmrc.md | 75 + .../bun-types/docs/install/overrides.md | 73 + .../bun-types/docs/install/patch.md | 59 + .../bun-types/docs/install/registries.md | 30 + .../bun-types/docs/install/workspaces.md | 94 + .../bun-types/docs/installation.md | 318 + .../bun-types/docs/project/benchmarking.md | 203 + .../bun-types/docs/project/bindgen.md | 225 + .../docs/project/building-windows.md | 162 + .../bun-types/docs/project/contributing.md | 326 + .../project/internals/build-process-for-ci.md | 75 + .../bun-types/docs/project/licensing.md | 73 + .../bun-types/docs/project/roadmap.md | 87 + .../node_modules/bun-types/docs/quickstart.md | 144 + .../bun-types/docs/runtime/autoimport.md | 94 + .../bun-types/docs/runtime/bun-apis.md | 129 + .../bun-types/docs/runtime/bunfig.md | 562 + .../bun-types/docs/runtime/debugger.md | 325 + .../bun-types/docs/runtime/env.md | 244 + .../bun-types/docs/runtime/hot.md | 146 + .../bun-types/docs/runtime/index.md | 309 + .../bun-types/docs/runtime/jsx.md | 326 + .../bun-types/docs/runtime/loaders.md | 127 + .../bun-types/docs/runtime/modules.md | 297 + .../bun-types/docs/runtime/nodejs-apis.md | 460 + .../bun-types/docs/runtime/plugins.md | 555 + .../bun-types/docs/runtime/shell.md | 537 + .../bun-types/docs/runtime/typescript.md | 139 + .../bun-types/docs/runtime/web-apis.md | 128 + .../bun-types/docs/test/configuration.md | 87 + .../bun-types/docs/test/coverage.md | 112 + .../bun-types/docs/test/discovery.md | 85 + .../node_modules/bun-types/docs/test/dom.md | 75 + .../node_modules/bun-types/docs/test/hot.md | 15 + .../bun-types/docs/test/lifecycle.md | 81 + .../node_modules/bun-types/docs/test/mocks.md | 313 + .../bun-types/docs/test/reporters.md | 108 + .../bun-types/docs/test/runtime-behavior.md | 93 + .../bun-types/docs/test/snapshots.md | 68 + .../node_modules/bun-types/docs/test/time.md | 126 + .../bun-types/docs/test/writing.md | 710 + .../node_modules/bun-types/docs/typescript.md | 52 + .../node_modules/bun-types/extensions.d.ts | 25 + .../node_modules/bun-types/fetch.d.ts | 72 + .../node_modules/bun-types/ffi.d.ts | 1159 ++ .../node_modules/bun-types/globals.d.ts | 1795 ++ .../node_modules/bun-types/html-rewriter.d.ts | 186 + .../node_modules/bun-types/index.d.ts | 26 + .../node_modules/bun-types/jsc.d.ts | 229 + .../node_modules/bun-types/overrides.d.ts | 206 + .../node_modules/bun-types/package.json | 40 + .../node_modules/bun-types/redis.d.ts | 610 + .../node_modules/bun-types/s3.d.ts | 945 + .../node_modules/bun-types/sqlite.d.ts | 1220 ++ .../node_modules/bun-types/test.d.ts | 2183 ++ .../node_modules/bun-types/wasm.d.ts | 193 + .../cookie@1.0.2/node_modules/cookie/LICENSE | 24 + .../node_modules/cookie/README.md | 248 + .../node_modules/cookie/dist/index.d.ts | 114 + .../node_modules/cookie/dist/index.js | 239 + .../node_modules/cookie/dist/index.js.map | 1 + .../node_modules/cookie/package.json | 42 + .../node_modules/discord-api-types/LICENSE | 21 + .../node_modules/discord-api-types/README.md | 105 + .../discord-api-types/gateway/common.d.ts | 9 + .../discord-api-types/gateway/common.d.ts.map | 1 + .../discord-api-types/gateway/common.js | 3 + .../discord-api-types/gateway/common.js.map | 1 + .../discord-api-types/gateway/index.d.ts | 2 + .../discord-api-types/gateway/index.d.ts.map | 1 + .../discord-api-types/gateway/index.js | 20 + .../discord-api-types/gateway/index.js.map | 1 + .../discord-api-types/gateway/index.mjs | 9 + .../discord-api-types/gateway/v10.d.ts | 1993 ++ .../discord-api-types/gateway/v10.d.ts.map | 1 + .../discord-api-types/gateway/v10.js | 291 + .../discord-api-types/gateway/v10.js.map | 1 + .../discord-api-types/gateway/v10.mjs | 9 + .../discord-api-types/gateway/v6.d.ts | 658 + .../discord-api-types/gateway/v6.d.ts.map | 1 + .../discord-api-types/gateway/v6.js | 173 + .../discord-api-types/gateway/v6.js.map | 1 + .../discord-api-types/gateway/v6.mjs | 10 + .../discord-api-types/gateway/v8.d.ts | 1575 ++ .../discord-api-types/gateway/v8.d.ts.map | 1 + .../discord-api-types/gateway/v8.js | 246 + .../discord-api-types/gateway/v8.js.map | 1 + .../discord-api-types/gateway/v8.mjs | 8 + .../discord-api-types/gateway/v9.d.ts | 1993 ++ .../discord-api-types/gateway/v9.d.ts.map | 1 + .../discord-api-types/gateway/v9.js | 290 + .../discord-api-types/gateway/v9.js.map | 1 + .../discord-api-types/gateway/v9.mjs | 9 + .../discord-api-types/globals.d.ts | 102 + .../discord-api-types/globals.d.ts.map | 1 + .../node_modules/discord-api-types/globals.js | 106 + .../discord-api-types/globals.js.map | 1 + .../discord-api-types/globals.mjs | 4 + .../discord-api-types/package.json | 198 + .../discord-api-types/payloads/common.d.ts | 332 + .../payloads/common.d.ts.map | 1 + .../discord-api-types/payloads/common.js | 299 + .../discord-api-types/payloads/common.js.map | 1 + .../discord-api-types/payloads/index.d.ts | 2 + .../discord-api-types/payloads/index.d.ts.map | 1 + .../discord-api-types/payloads/index.js | 20 + .../discord-api-types/payloads/index.js.map | 1 + .../discord-api-types/payloads/index.mjs | 87 + .../_chatInput/attachment.d.ts | 6 + .../_chatInput/attachment.d.ts.map | 1 + .../_chatInput/attachment.js | 3 + .../_chatInput/attachment.js.map | 1 + .../_applicationCommands/_chatInput/base.d.ts | 23 + .../_chatInput/base.d.ts.map | 1 + .../_applicationCommands/_chatInput/base.js | 3 + .../_chatInput/base.js.map | 1 + .../_chatInput/boolean.d.ts | 5 + .../_chatInput/boolean.d.ts.map | 1 + .../_chatInput/boolean.js | 3 + .../_chatInput/boolean.js.map | 1 + .../_chatInput/channel.d.ts | 9 + .../_chatInput/channel.d.ts.map | 1 + .../_chatInput/channel.js | 3 + .../_chatInput/channel.js.map | 1 + .../_chatInput/integer.d.ts | 18 + .../_chatInput/integer.d.ts.map | 1 + .../_chatInput/integer.js | 3 + .../_chatInput/integer.js.map | 1 + .../_chatInput/mentionable.d.ts | 6 + .../_chatInput/mentionable.d.ts.map | 1 + .../_chatInput/mentionable.js | 3 + .../_chatInput/mentionable.js.map | 1 + .../_chatInput/number.d.ts | 18 + .../_chatInput/number.d.ts.map | 1 + .../_applicationCommands/_chatInput/number.js | 3 + .../_chatInput/number.js.map | 1 + .../_applicationCommands/_chatInput/role.d.ts | 6 + .../_chatInput/role.d.ts.map | 1 + .../_applicationCommands/_chatInput/role.js | 3 + .../_chatInput/role.js.map | 1 + .../_chatInput/shared.d.ts | 26 + .../_chatInput/shared.d.ts.map | 1 + .../_applicationCommands/_chatInput/shared.js | 21 + .../_chatInput/shared.js.map | 1 + .../_chatInput/string.d.ts | 17 + .../_chatInput/string.d.ts.map | 1 + .../_applicationCommands/_chatInput/string.js | 3 + .../_chatInput/string.js.map | 1 + .../_chatInput/subcommand.d.ts | 13 + .../_chatInput/subcommand.d.ts.map | 1 + .../_chatInput/subcommand.js | 3 + .../_chatInput/subcommand.js.map | 1 + .../_chatInput/subcommandGroup.d.ts | 13 + .../_chatInput/subcommandGroup.d.ts.map | 1 + .../_chatInput/subcommandGroup.js | 3 + .../_chatInput/subcommandGroup.js.map | 1 + .../_applicationCommands/_chatInput/user.d.ts | 6 + .../_chatInput/user.d.ts.map | 1 + .../_applicationCommands/_chatInput/user.js | 3 + .../_chatInput/user.js.map | 1 + .../_applicationCommands/chatInput.d.ts | 68 + .../_applicationCommands/chatInput.d.ts.map | 1 + .../_applicationCommands/chatInput.js | 30 + .../_applicationCommands/chatInput.js.map | 1 + .../_applicationCommands/contextMenu.d.ts | 66 + .../_applicationCommands/contextMenu.d.ts.map | 1 + .../_applicationCommands/contextMenu.js | 3 + .../_applicationCommands/contextMenu.js.map | 1 + .../_applicationCommands/entryPoint.d.ts | 20 + .../_applicationCommands/entryPoint.d.ts.map | 1 + .../_applicationCommands/entryPoint.js | 3 + .../_applicationCommands/entryPoint.js.map | 1 + .../_applicationCommands/internals.d.ts | 9 + .../_applicationCommands/internals.d.ts.map | 1 + .../_applicationCommands/internals.js | 3 + .../_applicationCommands/internals.js.map | 1 + .../_applicationCommands/permissions.d.ts | 55 + .../_applicationCommands/permissions.d.ts.map | 1 + .../_applicationCommands/permissions.js | 21 + .../_applicationCommands/permissions.js.map | 1 + .../_interactions/applicationCommands.d.ts | 188 + .../applicationCommands.d.ts.map | 1 + .../v10/_interactions/applicationCommands.js | 92 + .../_interactions/applicationCommands.js.map | 1 + .../v10/_interactions/autocomplete.d.ts | 11 + .../v10/_interactions/autocomplete.d.ts.map | 1 + .../v10/_interactions/autocomplete.js | 3 + .../v10/_interactions/autocomplete.js.map | 1 + .../payloads/v10/_interactions/base.d.ts | 229 + .../payloads/v10/_interactions/base.d.ts.map | 1 + .../payloads/v10/_interactions/base.js | 3 + .../payloads/v10/_interactions/base.js.map | 1 + .../v10/_interactions/messageComponents.d.ts | 42 + .../_interactions/messageComponents.d.ts.map | 1 + .../v10/_interactions/messageComponents.js | 3 + .../_interactions/messageComponents.js.map | 1 + .../v10/_interactions/modalSubmit.d.ts | 36 + .../v10/_interactions/modalSubmit.d.ts.map | 1 + .../payloads/v10/_interactions/modalSubmit.js | 3 + .../v10/_interactions/modalSubmit.js.map | 1 + .../payloads/v10/_interactions/ping.d.ts | 4 + .../payloads/v10/_interactions/ping.d.ts.map | 1 + .../payloads/v10/_interactions/ping.js | 3 + .../payloads/v10/_interactions/ping.js.map | 1 + .../payloads/v10/_interactions/responses.d.ts | 121 + .../v10/_interactions/responses.d.ts.map | 1 + .../payloads/v10/_interactions/responses.js | 63 + .../v10/_interactions/responses.js.map | 1 + .../payloads/v10/application.d.ts | 324 + .../payloads/v10/application.d.ts.map | 1 + .../payloads/v10/application.js | 138 + .../payloads/v10/application.js.map | 1 + .../payloads/v10/auditLog.d.ts | 675 + .../payloads/v10/auditLog.d.ts.map | 1 + .../payloads/v10/auditLog.js | 84 + .../payloads/v10/auditLog.js.map | 1 + .../payloads/v10/autoModeration.d.ts | 222 + .../payloads/v10/autoModeration.d.ts.map | 1 + .../payloads/v10/autoModeration.js | 88 + .../payloads/v10/autoModeration.js.map | 1 + .../payloads/v10/channel.d.ts | 1814 ++ .../payloads/v10/channel.d.ts.map | 1 + .../discord-api-types/payloads/v10/channel.js | 490 + .../payloads/v10/channel.js.map | 1 + .../discord-api-types/payloads/v10/emoji.d.ts | 49 + .../payloads/v10/emoji.d.ts.map | 1 + .../discord-api-types/payloads/v10/emoji.js | 6 + .../payloads/v10/emoji.js.map | 1 + .../payloads/v10/gateway.d.ts | 373 + .../payloads/v10/gateway.d.ts.map | 1 + .../discord-api-types/payloads/v10/gateway.js | 83 + .../payloads/v10/gateway.js.map | 1 + .../discord-api-types/payloads/v10/guild.d.ts | 1145 + .../payloads/v10/guild.d.ts.map | 1 + .../discord-api-types/payloads/v10/guild.js | 378 + .../payloads/v10/guild.js.map | 1 + .../payloads/v10/guildScheduledEvent.d.ts | 244 + .../payloads/v10/guildScheduledEvent.d.ts.map | 1 + .../payloads/v10/guildScheduledEvent.js | 74 + .../payloads/v10/guildScheduledEvent.js.map | 1 + .../discord-api-types/payloads/v10/index.d.ts | 24 + .../payloads/v10/index.d.ts.map | 1 + .../discord-api-types/payloads/v10/index.js | 40 + .../payloads/v10/index.js.map | 1 + .../discord-api-types/payloads/v10/index.mjs | 87 + .../payloads/v10/interactions.d.ts | 25 + .../payloads/v10/interactions.d.ts.map | 1 + .../payloads/v10/interactions.js | 24 + .../payloads/v10/interactions.js.map | 1 + .../payloads/v10/invite.d.ts | 123 + .../payloads/v10/invite.d.ts.map | 1 + .../discord-api-types/payloads/v10/invite.js | 24 + .../payloads/v10/invite.js.map | 1 + .../payloads/v10/monetization.d.ts | 216 + .../payloads/v10/monetization.d.ts.map | 1 + .../payloads/v10/monetization.js | 101 + .../payloads/v10/monetization.js.map | 1 + .../payloads/v10/oauth2.d.ts | 144 + .../payloads/v10/oauth2.d.ts.map | 1 + .../discord-api-types/payloads/v10/oauth2.js | 148 + .../payloads/v10/oauth2.js.map | 1 + .../payloads/v10/permissions.d.ts | 98 + .../payloads/v10/permissions.d.ts.map | 1 + .../payloads/v10/permissions.js | 17 + .../payloads/v10/permissions.js.map | 1 + .../discord-api-types/payloads/v10/poll.d.ts | 105 + .../payloads/v10/poll.d.ts.map | 1 + .../discord-api-types/payloads/v10/poll.js | 17 + .../payloads/v10/poll.js.map | 1 + .../payloads/v10/soundboard.d.ts | 43 + .../payloads/v10/soundboard.d.ts.map | 1 + .../payloads/v10/soundboard.js | 6 + .../payloads/v10/soundboard.js.map | 1 + .../payloads/v10/stageInstance.d.ts | 82 + .../payloads/v10/stageInstance.d.ts.map | 1 + .../payloads/v10/stageInstance.js | 21 + .../payloads/v10/stageInstance.js.map | 1 + .../payloads/v10/sticker.d.ts | 125 + .../payloads/v10/sticker.d.ts.map | 1 + .../discord-api-types/payloads/v10/sticker.js | 31 + .../payloads/v10/sticker.js.map | 1 + .../discord-api-types/payloads/v10/teams.d.ts | 79 + .../payloads/v10/teams.d.ts.map | 1 + .../discord-api-types/payloads/v10/teams.js | 24 + .../payloads/v10/teams.js.map | 1 + .../payloads/v10/template.d.ts | 64 + .../payloads/v10/template.d.ts.map | 1 + .../payloads/v10/template.js | 6 + .../payloads/v10/template.js.map | 1 + .../discord-api-types/payloads/v10/user.d.ts | 342 + .../payloads/v10/user.d.ts.map | 1 + .../discord-api-types/payloads/v10/user.js | 172 + .../payloads/v10/user.js.map | 1 + .../discord-api-types/payloads/v10/voice.d.ts | 95 + .../payloads/v10/voice.d.ts.map | 1 + .../discord-api-types/payloads/v10/voice.js | 6 + .../payloads/v10/voice.js.map | 1 + .../payloads/v10/webhook.d.ts | 170 + .../payloads/v10/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v10/webhook.js | 57 + .../payloads/v10/webhook.js.map | 1 + .../payloads/v6/auditLog.d.ts | 469 + .../payloads/v6/auditLog.d.ts.map | 1 + .../discord-api-types/payloads/v6/auditLog.js | 58 + .../payloads/v6/auditLog.js.map | 1 + .../payloads/v6/channel.d.ts | 339 + .../payloads/v6/channel.d.ts.map | 1 + .../discord-api-types/payloads/v6/channel.js | 94 + .../payloads/v6/channel.js.map | 1 + .../discord-api-types/payloads/v6/emoji.d.ts | 27 + .../payloads/v6/emoji.d.ts.map | 1 + .../discord-api-types/payloads/v6/emoji.js | 6 + .../payloads/v6/emoji.js.map | 1 + .../payloads/v6/gateway.d.ts | 149 + .../payloads/v6/gateway.d.ts.map | 1 + .../discord-api-types/payloads/v6/gateway.js | 45 + .../payloads/v6/gateway.js.map | 1 + .../discord-api-types/payloads/v6/guild.d.ts | 310 + .../payloads/v6/guild.d.ts.map | 1 + .../discord-api-types/payloads/v6/guild.js | 118 + .../payloads/v6/guild.js.map | 1 + .../discord-api-types/payloads/v6/index.d.ts | 13 + .../payloads/v6/index.d.ts.map | 1 + .../discord-api-types/payloads/v6/index.js | 29 + .../payloads/v6/index.js.map | 1 + .../discord-api-types/payloads/v6/index.mjs | 30 + .../discord-api-types/payloads/v6/invite.d.ts | 42 + .../payloads/v6/invite.d.ts.map | 1 + .../discord-api-types/payloads/v6/invite.js | 16 + .../payloads/v6/invite.js.map | 1 + .../discord-api-types/payloads/v6/oauth2.d.ts | 28 + .../payloads/v6/oauth2.d.ts.map | 1 + .../discord-api-types/payloads/v6/oauth2.js | 6 + .../payloads/v6/oauth2.js.map | 1 + .../payloads/v6/permissions.d.ts | 75 + .../payloads/v6/permissions.d.ts.map | 1 + .../payloads/v6/permissions.js | 56 + .../payloads/v6/permissions.js.map | 1 + .../discord-api-types/payloads/v6/teams.d.ts | 36 + .../payloads/v6/teams.d.ts.map | 1 + .../discord-api-types/payloads/v6/teams.js | 17 + .../payloads/v6/teams.js.map | 1 + .../discord-api-types/payloads/v6/user.d.ts | 79 + .../payloads/v6/user.d.ts.map | 1 + .../discord-api-types/payloads/v6/user.js | 48 + .../discord-api-types/payloads/v6/user.js.map | 1 + .../discord-api-types/payloads/v6/voice.d.ts | 37 + .../payloads/v6/voice.d.ts.map | 1 + .../discord-api-types/payloads/v6/voice.js | 6 + .../payloads/v6/voice.js.map | 1 + .../payloads/v6/webhook.d.ts | 32 + .../payloads/v6/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v6/webhook.js | 15 + .../payloads/v6/webhook.js.map | 1 + .../_chatInput/attachment.d.ts | 12 + .../_chatInput/attachment.d.ts.map | 1 + .../_chatInput/attachment.js | 3 + .../_chatInput/attachment.js.map | 1 + .../_applicationCommands/_chatInput/base.d.ts | 28 + .../_chatInput/base.d.ts.map | 1 + .../_applicationCommands/_chatInput/base.js | 3 + .../_chatInput/base.js.map | 1 + .../_chatInput/boolean.d.ts | 11 + .../_chatInput/boolean.d.ts.map | 1 + .../_chatInput/boolean.js | 3 + .../_chatInput/boolean.js.map | 1 + .../_chatInput/channel.d.ts | 15 + .../_chatInput/channel.d.ts.map | 1 + .../_chatInput/channel.js | 3 + .../_chatInput/channel.js.map | 1 + .../_chatInput/integer.d.ts | 27 + .../_chatInput/integer.d.ts.map | 1 + .../_chatInput/integer.js | 3 + .../_chatInput/integer.js.map | 1 + .../_chatInput/mentionable.d.ts | 12 + .../_chatInput/mentionable.d.ts.map | 1 + .../_chatInput/mentionable.js | 3 + .../_chatInput/mentionable.js.map | 1 + .../_chatInput/number.d.ts | 27 + .../_chatInput/number.d.ts.map | 1 + .../_applicationCommands/_chatInput/number.js | 3 + .../_chatInput/number.js.map | 1 + .../_applicationCommands/_chatInput/role.d.ts | 12 + .../_chatInput/role.d.ts.map | 1 + .../_applicationCommands/_chatInput/role.js | 3 + .../_chatInput/role.js.map | 1 + .../_chatInput/shared.d.ts | 28 + .../_chatInput/shared.d.ts.map | 1 + .../_applicationCommands/_chatInput/shared.js | 23 + .../_chatInput/shared.js.map | 1 + .../_chatInput/string.d.ts | 13 + .../_chatInput/string.d.ts.map | 1 + .../_applicationCommands/_chatInput/string.js | 3 + .../_chatInput/string.js.map | 1 + .../_chatInput/subcommand.d.ts | 18 + .../_chatInput/subcommand.d.ts.map | 1 + .../_chatInput/subcommand.js | 3 + .../_chatInput/subcommand.js.map | 1 + .../_chatInput/subcommandGroup.d.ts | 18 + .../_chatInput/subcommandGroup.d.ts.map | 1 + .../_chatInput/subcommandGroup.js | 3 + .../_chatInput/subcommandGroup.js.map | 1 + .../_applicationCommands/_chatInput/user.d.ts | 12 + .../_chatInput/user.d.ts.map | 1 + .../_applicationCommands/_chatInput/user.js | 3 + .../_chatInput/user.js.map | 1 + .../_applicationCommands/chatInput.d.ts | 90 + .../_applicationCommands/chatInput.d.ts.map | 1 + .../_applicationCommands/chatInput.js | 29 + .../_applicationCommands/chatInput.js.map | 1 + .../_applicationCommands/contextMenu.d.ts | 102 + .../_applicationCommands/contextMenu.d.ts.map | 1 + .../_applicationCommands/contextMenu.js | 3 + .../_applicationCommands/contextMenu.js.map | 1 + .../_applicationCommands/internals.d.ts | 11 + .../_applicationCommands/internals.d.ts.map | 1 + .../_applicationCommands/internals.js | 3 + .../_applicationCommands/internals.js.map | 1 + .../_applicationCommands/permissions.d.ts | 53 + .../_applicationCommands/permissions.d.ts.map | 1 + .../_applicationCommands/permissions.js | 14 + .../_applicationCommands/permissions.js.map | 1 + .../v8/_interactions/applicationCommands.d.ts | 112 + .../applicationCommands.d.ts.map | 1 + .../v8/_interactions/applicationCommands.js | 32 + .../_interactions/applicationCommands.js.map | 1 + .../v8/_interactions/autocomplete.d.ts | 18 + .../v8/_interactions/autocomplete.d.ts.map | 1 + .../payloads/v8/_interactions/autocomplete.js | 3 + .../v8/_interactions/autocomplete.js.map | 1 + .../payloads/v8/_interactions/base.d.ts | 116 + .../payloads/v8/_interactions/base.d.ts.map | 1 + .../payloads/v8/_interactions/base.js | 3 + .../payloads/v8/_interactions/base.js.map | 1 + .../v8/_interactions/messageComponents.d.ts | 43 + .../_interactions/messageComponents.d.ts.map | 1 + .../v8/_interactions/messageComponents.js | 3 + .../v8/_interactions/messageComponents.js.map | 1 + .../v8/_interactions/modalSubmit.d.ts | 48 + .../v8/_interactions/modalSubmit.d.ts.map | 1 + .../payloads/v8/_interactions/modalSubmit.js | 3 + .../v8/_interactions/modalSubmit.js.map | 1 + .../payloads/v8/_interactions/ping.d.ts | 7 + .../payloads/v8/_interactions/ping.d.ts.map | 1 + .../payloads/v8/_interactions/ping.js | 3 + .../payloads/v8/_interactions/ping.js.map | 1 + .../payloads/v8/_interactions/responses.d.ts | 138 + .../v8/_interactions/responses.d.ts.map | 1 + .../payloads/v8/_interactions/responses.js | 53 + .../v8/_interactions/responses.js.map | 1 + .../payloads/v8/application.d.ts | 134 + .../payloads/v8/application.d.ts.map | 1 + .../payloads/v8/application.js | 28 + .../payloads/v8/application.js.map | 1 + .../payloads/v8/auditLog.d.ts | 637 + .../payloads/v8/auditLog.d.ts.map | 1 + .../discord-api-types/payloads/v8/auditLog.js | 67 + .../payloads/v8/auditLog.js.map | 1 + .../payloads/v8/channel.d.ts | 1268 ++ .../payloads/v8/channel.d.ts.map | 1 + .../discord-api-types/payloads/v8/channel.js | 253 + .../payloads/v8/channel.js.map | 1 + .../discord-api-types/payloads/v8/emoji.d.ts | 53 + .../payloads/v8/emoji.d.ts.map | 1 + .../discord-api-types/payloads/v8/emoji.js | 6 + .../payloads/v8/emoji.js.map | 1 + .../payloads/v8/gateway.d.ts | 332 + .../payloads/v8/gateway.d.ts.map | 1 + .../discord-api-types/payloads/v8/gateway.js | 79 + .../payloads/v8/gateway.js.map | 1 + .../discord-api-types/payloads/v8/guild.d.ts | 1001 + .../payloads/v8/guild.d.ts.map | 1 + .../discord-api-types/payloads/v8/guild.js | 264 + .../payloads/v8/guild.js.map | 1 + .../payloads/v8/guildScheduledEvent.d.ts | 163 + .../payloads/v8/guildScheduledEvent.d.ts.map | 1 + .../payloads/v8/guildScheduledEvent.js | 39 + .../payloads/v8/guildScheduledEvent.js.map | 1 + .../discord-api-types/payloads/v8/index.d.ts | 20 + .../payloads/v8/index.d.ts.map | 1 + .../discord-api-types/payloads/v8/index.js | 36 + .../payloads/v8/index.js.map | 1 + .../discord-api-types/payloads/v8/index.mjs | 51 + .../payloads/v8/interactions.d.ts | 31 + .../payloads/v8/interactions.d.ts.map | 1 + .../payloads/v8/interactions.js | 24 + .../payloads/v8/interactions.js.map | 1 + .../discord-api-types/payloads/v8/invite.d.ts | 114 + .../payloads/v8/invite.d.ts.map | 1 + .../discord-api-types/payloads/v8/invite.js | 17 + .../payloads/v8/invite.js.map | 1 + .../discord-api-types/payloads/v8/oauth2.d.ts | 117 + .../payloads/v8/oauth2.d.ts.map | 1 + .../discord-api-types/payloads/v8/oauth2.js | 121 + .../payloads/v8/oauth2.js.map | 1 + .../payloads/v8/permissions.d.ts | 77 + .../payloads/v8/permissions.d.ts.map | 1 + .../payloads/v8/permissions.js | 6 + .../payloads/v8/permissions.js.map | 1 + .../payloads/v8/stageInstance.d.ts | 76 + .../payloads/v8/stageInstance.d.ts.map | 1 + .../payloads/v8/stageInstance.js | 20 + .../payloads/v8/stageInstance.js.map | 1 + .../payloads/v8/sticker.d.ts | 133 + .../payloads/v8/sticker.d.ts.map | 1 + .../discord-api-types/payloads/v8/sticker.js | 34 + .../payloads/v8/sticker.js.map | 1 + .../discord-api-types/payloads/v8/teams.d.ts | 69 + .../payloads/v8/teams.d.ts.map | 1 + .../discord-api-types/payloads/v8/teams.js | 17 + .../payloads/v8/teams.js.map | 1 + .../payloads/v8/template.d.ts | 68 + .../payloads/v8/template.d.ts.map | 1 + .../discord-api-types/payloads/v8/template.js | 6 + .../payloads/v8/template.js.map | 1 + .../discord-api-types/payloads/v8/user.d.ts | 228 + .../payloads/v8/user.d.ts.map | 1 + .../discord-api-types/payloads/v8/user.js | 108 + .../discord-api-types/payloads/v8/user.js.map | 1 + .../discord-api-types/payloads/v8/voice.d.ts | 94 + .../payloads/v8/voice.d.ts.map | 1 + .../discord-api-types/payloads/v8/voice.js | 6 + .../payloads/v8/voice.js.map | 1 + .../payloads/v8/webhook.d.ts | 82 + .../payloads/v8/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v8/webhook.js | 25 + .../payloads/v8/webhook.js.map | 1 + .../_chatInput/attachment.d.ts | 6 + .../_chatInput/attachment.d.ts.map | 1 + .../_chatInput/attachment.js | 3 + .../_chatInput/attachment.js.map | 1 + .../_applicationCommands/_chatInput/base.d.ts | 23 + .../_chatInput/base.d.ts.map | 1 + .../_applicationCommands/_chatInput/base.js | 3 + .../_chatInput/base.js.map | 1 + .../_chatInput/boolean.d.ts | 5 + .../_chatInput/boolean.d.ts.map | 1 + .../_chatInput/boolean.js | 3 + .../_chatInput/boolean.js.map | 1 + .../_chatInput/channel.d.ts | 9 + .../_chatInput/channel.d.ts.map | 1 + .../_chatInput/channel.js | 3 + .../_chatInput/channel.js.map | 1 + .../_chatInput/integer.d.ts | 18 + .../_chatInput/integer.d.ts.map | 1 + .../_chatInput/integer.js | 3 + .../_chatInput/integer.js.map | 1 + .../_chatInput/mentionable.d.ts | 6 + .../_chatInput/mentionable.d.ts.map | 1 + .../_chatInput/mentionable.js | 3 + .../_chatInput/mentionable.js.map | 1 + .../_chatInput/number.d.ts | 18 + .../_chatInput/number.d.ts.map | 1 + .../_applicationCommands/_chatInput/number.js | 3 + .../_chatInput/number.js.map | 1 + .../_applicationCommands/_chatInput/role.d.ts | 6 + .../_chatInput/role.d.ts.map | 1 + .../_applicationCommands/_chatInput/role.js | 3 + .../_chatInput/role.js.map | 1 + .../_chatInput/shared.d.ts | 26 + .../_chatInput/shared.d.ts.map | 1 + .../_applicationCommands/_chatInput/shared.js | 21 + .../_chatInput/shared.js.map | 1 + .../_chatInput/string.d.ts | 17 + .../_chatInput/string.d.ts.map | 1 + .../_applicationCommands/_chatInput/string.js | 3 + .../_chatInput/string.js.map | 1 + .../_chatInput/subcommand.d.ts | 13 + .../_chatInput/subcommand.d.ts.map | 1 + .../_chatInput/subcommand.js | 3 + .../_chatInput/subcommand.js.map | 1 + .../_chatInput/subcommandGroup.d.ts | 13 + .../_chatInput/subcommandGroup.d.ts.map | 1 + .../_chatInput/subcommandGroup.js | 3 + .../_chatInput/subcommandGroup.js.map | 1 + .../_applicationCommands/_chatInput/user.d.ts | 6 + .../_chatInput/user.d.ts.map | 1 + .../_applicationCommands/_chatInput/user.js | 3 + .../_chatInput/user.js.map | 1 + .../_applicationCommands/chatInput.d.ts | 68 + .../_applicationCommands/chatInput.d.ts.map | 1 + .../_applicationCommands/chatInput.js | 30 + .../_applicationCommands/chatInput.js.map | 1 + .../_applicationCommands/contextMenu.d.ts | 66 + .../_applicationCommands/contextMenu.d.ts.map | 1 + .../_applicationCommands/contextMenu.js | 3 + .../_applicationCommands/contextMenu.js.map | 1 + .../_applicationCommands/entryPoint.d.ts | 20 + .../_applicationCommands/entryPoint.d.ts.map | 1 + .../_applicationCommands/entryPoint.js | 3 + .../_applicationCommands/entryPoint.js.map | 1 + .../_applicationCommands/internals.d.ts | 9 + .../_applicationCommands/internals.d.ts.map | 1 + .../_applicationCommands/internals.js | 3 + .../_applicationCommands/internals.js.map | 1 + .../_applicationCommands/permissions.d.ts | 55 + .../_applicationCommands/permissions.d.ts.map | 1 + .../_applicationCommands/permissions.js | 21 + .../_applicationCommands/permissions.js.map | 1 + .../v9/_interactions/applicationCommands.d.ts | 188 + .../applicationCommands.d.ts.map | 1 + .../v9/_interactions/applicationCommands.js | 92 + .../_interactions/applicationCommands.js.map | 1 + .../v9/_interactions/autocomplete.d.ts | 11 + .../v9/_interactions/autocomplete.d.ts.map | 1 + .../payloads/v9/_interactions/autocomplete.js | 3 + .../v9/_interactions/autocomplete.js.map | 1 + .../payloads/v9/_interactions/base.d.ts | 232 + .../payloads/v9/_interactions/base.d.ts.map | 1 + .../payloads/v9/_interactions/base.js | 3 + .../payloads/v9/_interactions/base.js.map | 1 + .../v9/_interactions/messageComponents.d.ts | 42 + .../_interactions/messageComponents.d.ts.map | 1 + .../v9/_interactions/messageComponents.js | 3 + .../v9/_interactions/messageComponents.js.map | 1 + .../v9/_interactions/modalSubmit.d.ts | 36 + .../v9/_interactions/modalSubmit.d.ts.map | 1 + .../payloads/v9/_interactions/modalSubmit.js | 3 + .../v9/_interactions/modalSubmit.js.map | 1 + .../payloads/v9/_interactions/ping.d.ts | 4 + .../payloads/v9/_interactions/ping.d.ts.map | 1 + .../payloads/v9/_interactions/ping.js | 3 + .../payloads/v9/_interactions/ping.js.map | 1 + .../payloads/v9/_interactions/responses.d.ts | 121 + .../v9/_interactions/responses.d.ts.map | 1 + .../payloads/v9/_interactions/responses.js | 63 + .../v9/_interactions/responses.js.map | 1 + .../payloads/v9/application.d.ts | 324 + .../payloads/v9/application.d.ts.map | 1 + .../payloads/v9/application.js | 138 + .../payloads/v9/application.js.map | 1 + .../payloads/v9/auditLog.d.ts | 675 + .../payloads/v9/auditLog.d.ts.map | 1 + .../discord-api-types/payloads/v9/auditLog.js | 84 + .../payloads/v9/auditLog.js.map | 1 + .../payloads/v9/autoModeration.d.ts | 222 + .../payloads/v9/autoModeration.d.ts.map | 1 + .../payloads/v9/autoModeration.js | 88 + .../payloads/v9/autoModeration.js.map | 1 + .../payloads/v9/channel.d.ts | 1783 ++ .../payloads/v9/channel.d.ts.map | 1 + .../discord-api-types/payloads/v9/channel.js | 490 + .../payloads/v9/channel.js.map | 1 + .../discord-api-types/payloads/v9/emoji.d.ts | 49 + .../payloads/v9/emoji.d.ts.map | 1 + .../discord-api-types/payloads/v9/emoji.js | 6 + .../payloads/v9/emoji.js.map | 1 + .../payloads/v9/gateway.d.ts | 361 + .../payloads/v9/gateway.d.ts.map | 1 + .../discord-api-types/payloads/v9/gateway.js | 83 + .../payloads/v9/gateway.js.map | 1 + .../discord-api-types/payloads/v9/guild.d.ts | 1137 + .../payloads/v9/guild.d.ts.map | 1 + .../discord-api-types/payloads/v9/guild.js | 370 + .../payloads/v9/guild.js.map | 1 + .../payloads/v9/guildScheduledEvent.d.ts | 244 + .../payloads/v9/guildScheduledEvent.d.ts.map | 1 + .../payloads/v9/guildScheduledEvent.js | 74 + .../payloads/v9/guildScheduledEvent.js.map | 1 + .../discord-api-types/payloads/v9/index.d.ts | 24 + .../payloads/v9/index.d.ts.map | 1 + .../discord-api-types/payloads/v9/index.js | 40 + .../payloads/v9/index.js.map | 1 + .../discord-api-types/payloads/v9/index.mjs | 87 + .../payloads/v9/interactions.d.ts | 25 + .../payloads/v9/interactions.d.ts.map | 1 + .../payloads/v9/interactions.js | 24 + .../payloads/v9/interactions.js.map | 1 + .../discord-api-types/payloads/v9/invite.d.ts | 123 + .../payloads/v9/invite.d.ts.map | 1 + .../discord-api-types/payloads/v9/invite.js | 24 + .../payloads/v9/invite.js.map | 1 + .../payloads/v9/monetization.d.ts | 216 + .../payloads/v9/monetization.d.ts.map | 1 + .../payloads/v9/monetization.js | 101 + .../payloads/v9/monetization.js.map | 1 + .../discord-api-types/payloads/v9/oauth2.d.ts | 132 + .../payloads/v9/oauth2.d.ts.map | 1 + .../discord-api-types/payloads/v9/oauth2.js | 136 + .../payloads/v9/oauth2.js.map | 1 + .../payloads/v9/permissions.d.ts | 98 + .../payloads/v9/permissions.d.ts.map | 1 + .../payloads/v9/permissions.js | 17 + .../payloads/v9/permissions.js.map | 1 + .../discord-api-types/payloads/v9/poll.d.ts | 105 + .../payloads/v9/poll.d.ts.map | 1 + .../discord-api-types/payloads/v9/poll.js | 17 + .../discord-api-types/payloads/v9/poll.js.map | 1 + .../payloads/v9/soundboard.d.ts | 43 + .../payloads/v9/soundboard.d.ts.map | 1 + .../payloads/v9/soundboard.js | 6 + .../payloads/v9/soundboard.js.map | 1 + .../payloads/v9/stageInstance.d.ts | 82 + .../payloads/v9/stageInstance.d.ts.map | 1 + .../payloads/v9/stageInstance.js | 21 + .../payloads/v9/stageInstance.js.map | 1 + .../payloads/v9/sticker.d.ts | 125 + .../payloads/v9/sticker.d.ts.map | 1 + .../discord-api-types/payloads/v9/sticker.js | 31 + .../payloads/v9/sticker.js.map | 1 + .../discord-api-types/payloads/v9/teams.d.ts | 79 + .../payloads/v9/teams.d.ts.map | 1 + .../discord-api-types/payloads/v9/teams.js | 24 + .../payloads/v9/teams.js.map | 1 + .../payloads/v9/template.d.ts | 64 + .../payloads/v9/template.d.ts.map | 1 + .../discord-api-types/payloads/v9/template.js | 6 + .../payloads/v9/template.js.map | 1 + .../discord-api-types/payloads/v9/user.d.ts | 342 + .../payloads/v9/user.d.ts.map | 1 + .../discord-api-types/payloads/v9/user.js | 172 + .../discord-api-types/payloads/v9/user.js.map | 1 + .../discord-api-types/payloads/v9/voice.d.ts | 95 + .../payloads/v9/voice.d.ts.map | 1 + .../discord-api-types/payloads/v9/voice.js | 6 + .../payloads/v9/voice.js.map | 1 + .../payloads/v9/webhook.d.ts | 170 + .../payloads/v9/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v9/webhook.js | 57 + .../payloads/v9/webhook.js.map | 1 + .../discord-api-types/rest/common.d.ts | 271 + .../discord-api-types/rest/common.d.ts.map | 1 + .../discord-api-types/rest/common.js | 272 + .../discord-api-types/rest/common.js.map | 1 + .../discord-api-types/rest/index.d.ts | 2 + .../discord-api-types/rest/index.d.ts.map | 1 + .../discord-api-types/rest/index.js | 20 + .../discord-api-types/rest/index.js.map | 1 + .../discord-api-types/rest/index.mjs | 14 + .../rest/v10/application.d.ts | 27 + .../rest/v10/application.d.ts.map | 1 + .../discord-api-types/rest/v10/application.js | 3 + .../rest/v10/application.js.map | 1 + .../discord-api-types/rest/v10/auditLog.d.ts | 31 + .../rest/v10/auditLog.d.ts.map | 1 + .../discord-api-types/rest/v10/auditLog.js | 3 + .../rest/v10/auditLog.js.map | 1 + .../rest/v10/autoModeration.d.ts | 68 + .../rest/v10/autoModeration.d.ts.map | 1 + .../rest/v10/autoModeration.js | 3 + .../rest/v10/autoModeration.js.map | 1 + .../discord-api-types/rest/v10/channel.d.ts | 714 + .../rest/v10/channel.d.ts.map | 1 + .../discord-api-types/rest/v10/channel.js | 12 + .../discord-api-types/rest/v10/channel.js.map | 1 + .../discord-api-types/rest/v10/emoji.d.ts | 85 + .../discord-api-types/rest/v10/emoji.d.ts.map | 1 + .../discord-api-types/rest/v10/emoji.js | 3 + .../discord-api-types/rest/v10/emoji.js.map | 1 + .../discord-api-types/rest/v10/gateway.d.ts | 10 + .../rest/v10/gateway.d.ts.map | 1 + .../discord-api-types/rest/v10/gateway.js | 3 + .../discord-api-types/rest/v10/gateway.js.map | 1 + .../discord-api-types/rest/v10/guild.d.ts | 863 + .../discord-api-types/rest/v10/guild.d.ts.map | 1 + .../discord-api-types/rest/v10/guild.js | 3 + .../discord-api-types/rest/v10/guild.js.map | 1 + .../rest/v10/guildScheduledEvent.d.ts | 123 + .../rest/v10/guildScheduledEvent.d.ts.map | 1 + .../rest/v10/guildScheduledEvent.js | 3 + .../rest/v10/guildScheduledEvent.js.map | 1 + .../discord-api-types/rest/v10/index.d.ts | 942 + .../discord-api-types/rest/v10/index.d.ts.map | 1 + .../discord-api-types/rest/v10/index.js | 1249 ++ .../discord-api-types/rest/v10/index.js.map | 1 + .../discord-api-types/rest/v10/index.mjs | 14 + .../rest/v10/interactions.d.ts | 289 + .../rest/v10/interactions.d.ts.map | 1 + .../rest/v10/interactions.js | 3 + .../rest/v10/interactions.js.map | 1 + .../discord-api-types/rest/v10/invite.d.ts | 25 + .../rest/v10/invite.d.ts.map | 1 + .../discord-api-types/rest/v10/invite.js | 3 + .../discord-api-types/rest/v10/invite.js.map | 1 + .../rest/v10/monetization.d.ts | 126 + .../rest/v10/monetization.d.ts.map | 1 + .../rest/v10/monetization.js | 12 + .../rest/v10/monetization.js.map | 1 + .../discord-api-types/rest/v10/oauth2.d.ts | 184 + .../rest/v10/oauth2.d.ts.map | 1 + .../discord-api-types/rest/v10/oauth2.js | 3 + .../discord-api-types/rest/v10/oauth2.js.map | 1 + .../discord-api-types/rest/v10/poll.d.ts | 50 + .../discord-api-types/rest/v10/poll.d.ts.map | 1 + .../discord-api-types/rest/v10/poll.js | 3 + .../discord-api-types/rest/v10/poll.js.map | 1 + .../rest/v10/soundboard.d.ts | 98 + .../rest/v10/soundboard.d.ts.map | 1 + .../discord-api-types/rest/v10/soundboard.js | 3 + .../rest/v10/soundboard.js.map | 1 + .../rest/v10/stageInstance.d.ts | 59 + .../rest/v10/stageInstance.d.ts.map | 1 + .../rest/v10/stageInstance.js | 3 + .../rest/v10/stageInstance.js.map | 1 + .../discord-api-types/rest/v10/sticker.d.ts | 85 + .../rest/v10/sticker.d.ts.map | 1 + .../discord-api-types/rest/v10/sticker.js | 3 + .../discord-api-types/rest/v10/sticker.js.map | 1 + .../discord-api-types/rest/v10/template.d.ts | 63 + .../rest/v10/template.d.ts.map | 1 + .../discord-api-types/rest/v10/template.js | 3 + .../rest/v10/template.js.map | 1 + .../discord-api-types/rest/v10/user.d.ts | 122 + .../discord-api-types/rest/v10/user.d.ts.map | 1 + .../discord-api-types/rest/v10/user.js | 3 + .../discord-api-types/rest/v10/user.js.map | 1 + .../discord-api-types/rest/v10/voice.d.ts | 57 + .../discord-api-types/rest/v10/voice.d.ts.map | 1 + .../discord-api-types/rest/v10/voice.js | 3 + .../discord-api-types/rest/v10/voice.js.map | 1 + .../discord-api-types/rest/v10/webhook.d.ts | 269 + .../rest/v10/webhook.d.ts.map | 1 + .../discord-api-types/rest/v10/webhook.js | 3 + .../discord-api-types/rest/v10/webhook.js.map | 1 + .../discord-api-types/rest/v6/auditLog.d.ts | 17 + .../rest/v6/auditLog.d.ts.map | 1 + .../discord-api-types/rest/v6/auditLog.js | 3 + .../discord-api-types/rest/v6/auditLog.js.map | 1 + .../discord-api-types/rest/v6/channel.d.ts | 268 + .../rest/v6/channel.d.ts.map | 1 + .../discord-api-types/rest/v6/channel.js | 15 + .../discord-api-types/rest/v6/channel.js.map | 1 + .../discord-api-types/rest/v6/emoji.d.ts | 50 + .../discord-api-types/rest/v6/emoji.d.ts.map | 1 + .../discord-api-types/rest/v6/emoji.js | 3 + .../discord-api-types/rest/v6/emoji.js.map | 1 + .../discord-api-types/rest/v6/gateway.d.ts | 14 + .../rest/v6/gateway.d.ts.map | 1 + .../discord-api-types/rest/v6/gateway.js | 3 + .../discord-api-types/rest/v6/gateway.js.map | 1 + .../discord-api-types/rest/v6/guild.d.ts | 465 + .../discord-api-types/rest/v6/guild.d.ts.map | 1 + .../discord-api-types/rest/v6/guild.js | 3 + .../discord-api-types/rest/v6/guild.js.map | 1 + .../discord-api-types/rest/v6/index.d.ts | 348 + .../discord-api-types/rest/v6/index.d.ts.map | 1 + .../discord-api-types/rest/v6/index.js | 499 + .../discord-api-types/rest/v6/index.js.map | 1 + .../discord-api-types/rest/v6/index.mjs | 8 + .../discord-api-types/rest/v6/invite.d.ts | 20 + .../discord-api-types/rest/v6/invite.d.ts.map | 1 + .../discord-api-types/rest/v6/invite.js | 3 + .../discord-api-types/rest/v6/invite.js.map | 1 + .../discord-api-types/rest/v6/oauth2.d.ts | 177 + .../discord-api-types/rest/v6/oauth2.d.ts.map | 1 + .../discord-api-types/rest/v6/oauth2.js | 3 + .../discord-api-types/rest/v6/oauth2.js.map | 1 + .../discord-api-types/rest/v6/user.d.ts | 80 + .../discord-api-types/rest/v6/user.d.ts.map | 1 + .../discord-api-types/rest/v6/user.js | 3 + .../discord-api-types/rest/v6/user.js.map | 1 + .../discord-api-types/rest/v6/voice.d.ts | 8 + .../discord-api-types/rest/v6/voice.d.ts.map | 1 + .../discord-api-types/rest/v6/voice.js | 3 + .../discord-api-types/rest/v6/voice.js.map | 1 + .../discord-api-types/rest/v6/webhook.d.ts | 139 + .../rest/v6/webhook.d.ts.map | 1 + .../discord-api-types/rest/v6/webhook.js | 3 + .../discord-api-types/rest/v6/webhook.js.map | 1 + .../discord-api-types/rest/v8/auditLog.d.ts | 32 + .../rest/v8/auditLog.d.ts.map | 1 + .../discord-api-types/rest/v8/auditLog.js | 3 + .../discord-api-types/rest/v8/auditLog.js.map | 1 + .../discord-api-types/rest/v8/channel.d.ts | 564 + .../rest/v8/channel.d.ts.map | 1 + .../discord-api-types/rest/v8/channel.js | 3 + .../discord-api-types/rest/v8/channel.js.map | 1 + .../discord-api-types/rest/v8/emoji.d.ts | 69 + .../discord-api-types/rest/v8/emoji.d.ts.map | 1 + .../discord-api-types/rest/v8/emoji.js | 3 + .../discord-api-types/rest/v8/emoji.js.map | 1 + .../discord-api-types/rest/v8/gateway.d.ts | 14 + .../rest/v8/gateway.d.ts.map | 1 + .../discord-api-types/rest/v8/gateway.js | 3 + .../discord-api-types/rest/v8/gateway.js.map | 1 + .../discord-api-types/rest/v8/guild.d.ts | 882 + .../discord-api-types/rest/v8/guild.d.ts.map | 1 + .../discord-api-types/rest/v8/guild.js | 3 + .../discord-api-types/rest/v8/guild.js.map | 1 + .../rest/v8/guildScheduledEvent.d.ts | 141 + .../rest/v8/guildScheduledEvent.d.ts.map | 1 + .../rest/v8/guildScheduledEvent.js | 3 + .../rest/v8/guildScheduledEvent.js.map | 1 + .../discord-api-types/rest/v8/index.d.ts | 539 + .../discord-api-types/rest/v8/index.d.ts.map | 1 + .../discord-api-types/rest/v8/index.js | 747 + .../discord-api-types/rest/v8/index.js.map | 1 + .../discord-api-types/rest/v8/index.mjs | 9 + .../rest/v8/interactions.d.ts | 257 + .../rest/v8/interactions.d.ts.map | 1 + .../discord-api-types/rest/v8/interactions.js | 3 + .../rest/v8/interactions.js.map | 1 + .../discord-api-types/rest/v8/invite.d.ts | 32 + .../discord-api-types/rest/v8/invite.d.ts.map | 1 + .../discord-api-types/rest/v8/invite.js | 3 + .../discord-api-types/rest/v8/invite.js.map | 1 + .../discord-api-types/rest/v8/oauth2.d.ts | 213 + .../discord-api-types/rest/v8/oauth2.d.ts.map | 1 + .../discord-api-types/rest/v8/oauth2.js | 3 + .../discord-api-types/rest/v8/oauth2.js.map | 1 + .../rest/v8/stageInstance.d.ts | 63 + .../rest/v8/stageInstance.d.ts.map | 1 + .../rest/v8/stageInstance.js | 3 + .../rest/v8/stageInstance.js.map | 1 + .../discord-api-types/rest/v8/sticker.d.ts | 70 + .../rest/v8/sticker.d.ts.map | 1 + .../discord-api-types/rest/v8/sticker.js | 3 + .../discord-api-types/rest/v8/sticker.js.map | 1 + .../discord-api-types/rest/v8/template.d.ts | 83 + .../rest/v8/template.d.ts.map | 1 + .../discord-api-types/rest/v8/template.js | 3 + .../discord-api-types/rest/v8/template.js.map | 1 + .../discord-api-types/rest/v8/user.d.ts | 109 + .../discord-api-types/rest/v8/user.d.ts.map | 1 + .../discord-api-types/rest/v8/user.js | 3 + .../discord-api-types/rest/v8/user.js.map | 1 + .../discord-api-types/rest/v8/voice.d.ts | 8 + .../discord-api-types/rest/v8/voice.d.ts.map | 1 + .../discord-api-types/rest/v8/voice.js | 3 + .../discord-api-types/rest/v8/voice.js.map | 1 + .../discord-api-types/rest/v8/webhook.d.ts | 283 + .../rest/v8/webhook.d.ts.map | 1 + .../discord-api-types/rest/v8/webhook.js | 3 + .../discord-api-types/rest/v8/webhook.js.map | 1 + .../rest/v9/application.d.ts | 27 + .../rest/v9/application.d.ts.map | 1 + .../discord-api-types/rest/v9/application.js | 3 + .../rest/v9/application.js.map | 1 + .../discord-api-types/rest/v9/auditLog.d.ts | 31 + .../rest/v9/auditLog.d.ts.map | 1 + .../discord-api-types/rest/v9/auditLog.js | 3 + .../discord-api-types/rest/v9/auditLog.js.map | 1 + .../rest/v9/autoModeration.d.ts | 68 + .../rest/v9/autoModeration.d.ts.map | 1 + .../rest/v9/autoModeration.js | 3 + .../rest/v9/autoModeration.js.map | 1 + .../discord-api-types/rest/v9/channel.d.ts | 728 + .../rest/v9/channel.d.ts.map | 1 + .../discord-api-types/rest/v9/channel.js | 12 + .../discord-api-types/rest/v9/channel.js.map | 1 + .../discord-api-types/rest/v9/emoji.d.ts | 85 + .../discord-api-types/rest/v9/emoji.d.ts.map | 1 + .../discord-api-types/rest/v9/emoji.js | 3 + .../discord-api-types/rest/v9/emoji.js.map | 1 + .../discord-api-types/rest/v9/gateway.d.ts | 10 + .../rest/v9/gateway.d.ts.map | 1 + .../discord-api-types/rest/v9/gateway.js | 3 + .../discord-api-types/rest/v9/gateway.js.map | 1 + .../discord-api-types/rest/v9/guild.d.ts | 869 + .../discord-api-types/rest/v9/guild.d.ts.map | 1 + .../discord-api-types/rest/v9/guild.js | 3 + .../discord-api-types/rest/v9/guild.js.map | 1 + .../rest/v9/guildScheduledEvent.d.ts | 123 + .../rest/v9/guildScheduledEvent.d.ts.map | 1 + .../rest/v9/guildScheduledEvent.js | 3 + .../rest/v9/guildScheduledEvent.js.map | 1 + .../discord-api-types/rest/v9/index.d.ts | 944 + .../discord-api-types/rest/v9/index.d.ts.map | 1 + .../discord-api-types/rest/v9/index.js | 1256 ++ .../discord-api-types/rest/v9/index.js.map | 1 + .../discord-api-types/rest/v9/index.mjs | 14 + .../rest/v9/interactions.d.ts | 289 + .../rest/v9/interactions.d.ts.map | 1 + .../discord-api-types/rest/v9/interactions.js | 3 + .../rest/v9/interactions.js.map | 1 + .../discord-api-types/rest/v9/invite.d.ts | 25 + .../discord-api-types/rest/v9/invite.d.ts.map | 1 + .../discord-api-types/rest/v9/invite.js | 3 + .../discord-api-types/rest/v9/invite.js.map | 1 + .../rest/v9/monetization.d.ts | 126 + .../rest/v9/monetization.d.ts.map | 1 + .../discord-api-types/rest/v9/monetization.js | 12 + .../rest/v9/monetization.js.map | 1 + .../discord-api-types/rest/v9/oauth2.d.ts | 184 + .../discord-api-types/rest/v9/oauth2.d.ts.map | 1 + .../discord-api-types/rest/v9/oauth2.js | 3 + .../discord-api-types/rest/v9/oauth2.js.map | 1 + .../discord-api-types/rest/v9/poll.d.ts | 50 + .../discord-api-types/rest/v9/poll.d.ts.map | 1 + .../discord-api-types/rest/v9/poll.js | 3 + .../discord-api-types/rest/v9/poll.js.map | 1 + .../discord-api-types/rest/v9/soundboard.d.ts | 98 + .../rest/v9/soundboard.d.ts.map | 1 + .../discord-api-types/rest/v9/soundboard.js | 3 + .../rest/v9/soundboard.js.map | 1 + .../rest/v9/stageInstance.d.ts | 59 + .../rest/v9/stageInstance.d.ts.map | 1 + .../rest/v9/stageInstance.js | 3 + .../rest/v9/stageInstance.js.map | 1 + .../discord-api-types/rest/v9/sticker.d.ts | 85 + .../rest/v9/sticker.d.ts.map | 1 + .../discord-api-types/rest/v9/sticker.js | 3 + .../discord-api-types/rest/v9/sticker.js.map | 1 + .../discord-api-types/rest/v9/template.d.ts | 63 + .../rest/v9/template.d.ts.map | 1 + .../discord-api-types/rest/v9/template.js | 3 + .../discord-api-types/rest/v9/template.js.map | 1 + .../discord-api-types/rest/v9/user.d.ts | 122 + .../discord-api-types/rest/v9/user.d.ts.map | 1 + .../discord-api-types/rest/v9/user.js | 3 + .../discord-api-types/rest/v9/user.js.map | 1 + .../discord-api-types/rest/v9/voice.d.ts | 57 + .../discord-api-types/rest/v9/voice.d.ts.map | 1 + .../discord-api-types/rest/v9/voice.js | 3 + .../discord-api-types/rest/v9/voice.js.map | 1 + .../discord-api-types/rest/v9/webhook.d.ts | 269 + .../rest/v9/webhook.d.ts.map | 1 + .../discord-api-types/rest/v9/webhook.js | 3 + .../discord-api-types/rest/v9/webhook.js.map | 1 + .../discord-api-types/rpc/common.d.ts | 483 + .../discord-api-types/rpc/common.d.ts.map | 1 + .../discord-api-types/rpc/common.js | 240 + .../discord-api-types/rpc/common.js.map | 1 + .../discord-api-types/rpc/index.d.ts | 2 + .../discord-api-types/rpc/index.d.ts.map | 1 + .../discord-api-types/rpc/index.js | 20 + .../discord-api-types/rpc/index.js.map | 1 + .../discord-api-types/rpc/index.mjs | 13 + .../discord-api-types/rpc/v10.d.ts | 2154 ++ .../discord-api-types/rpc/v10.d.ts.map | 1 + .../node_modules/discord-api-types/rpc/v10.js | 299 + .../discord-api-types/rpc/v10.js.map | 1 + .../discord-api-types/rpc/v10.mjs | 13 + .../discord-api-types/rpc/v8.d.ts | 2 + .../discord-api-types/rpc/v8.d.ts.map | 1 + .../node_modules/discord-api-types/rpc/v8.js | 18 + .../discord-api-types/rpc/v8.js.map | 1 + .../node_modules/discord-api-types/rpc/v8.mjs | 10 + .../discord-api-types/rpc/v9.d.ts | 2 + .../discord-api-types/rpc/v9.d.ts.map | 1 + .../node_modules/discord-api-types/rpc/v9.js | 18 + .../discord-api-types/rpc/v9.js.map | 1 + .../node_modules/discord-api-types/rpc/v9.mjs | 10 + .../discord-api-types/utils/index.d.ts | 2 + .../discord-api-types/utils/index.d.ts.map | 1 + .../discord-api-types/utils/index.js | 20 + .../discord-api-types/utils/index.js.map | 1 + .../discord-api-types/utils/index.mjs | 16 + .../discord-api-types/utils/internals.d.ts | 34 + .../utils/internals.d.ts.map | 1 + .../discord-api-types/utils/internals.js | 13 + .../discord-api-types/utils/internals.js.map | 1 + .../discord-api-types/utils/v10.d.ts | 93 + .../discord-api-types/utils/v10.d.ts.map | 1 + .../discord-api-types/utils/v10.js | 147 + .../discord-api-types/utils/v10.js.map | 1 + .../discord-api-types/utils/v10.mjs | 16 + .../discord-api-types/utils/v8.d.ts | 66 + .../discord-api-types/utils/v8.d.ts.map | 1 + .../discord-api-types/utils/v8.js | 96 + .../discord-api-types/utils/v8.js.map | 1 + .../discord-api-types/utils/v8.mjs | 11 + .../discord-api-types/utils/v9.d.ts | 93 + .../discord-api-types/utils/v9.d.ts.map | 1 + .../discord-api-types/utils/v9.js | 147 + .../discord-api-types/utils/v9.js.map | 1 + .../discord-api-types/utils/v9.mjs | 16 + .../node_modules/discord-api-types/v10.d.ts | 8 + .../discord-api-types/v10.d.ts.map | 1 + .../node_modules/discord-api-types/v10.js | 25 + .../node_modules/discord-api-types/v10.js.map | 1 + .../node_modules/discord-api-types/v10.mjs | 117 + .../node_modules/discord-api-types/v6.d.ts | 5 + .../discord-api-types/v6.d.ts.map | 1 + .../node_modules/discord-api-types/v6.js | 21 + .../node_modules/discord-api-types/v6.js.map | 1 + .../node_modules/discord-api-types/v6.mjs | 43 + .../node_modules/discord-api-types/v8.d.ts | 7 + .../discord-api-types/v8.d.ts.map | 1 + .../node_modules/discord-api-types/v8.js | 24 + .../node_modules/discord-api-types/v8.js.map | 1 + .../node_modules/discord-api-types/v8.mjs | 71 + .../node_modules/discord-api-types/v9.d.ts | 8 + .../discord-api-types/v9.d.ts.map | 1 + .../node_modules/discord-api-types/v9.js | 25 + .../node_modules/discord-api-types/v9.js.map | 1 + .../node_modules/discord-api-types/v9.mjs | 114 + .../discord-api-types/voice/index.d.ts | 2 + .../discord-api-types/voice/index.d.ts.map | 1 + .../discord-api-types/voice/index.js | 20 + .../discord-api-types/voice/index.js.map | 1 + .../discord-api-types/voice/index.mjs | 6 + .../discord-api-types/voice/v4.d.ts | 112 + .../discord-api-types/voice/v4.d.ts.map | 1 + .../discord-api-types/voice/v4.js | 117 + .../discord-api-types/voice/v4.js.map | 1 + .../discord-api-types/voice/v4.mjs | 6 + .../node_modules/@discordjs/builders | 1 + .../node_modules/@discordjs/collection | 1 + .../node_modules/@discordjs/formatters | 1 + .../node_modules/@discordjs/rest | 1 + .../node_modules/@discordjs/util | 1 + .../node_modules/@discordjs/ws | 1 + .../node_modules/@sapphire/snowflake | 1 + .../node_modules/discord-api-types | 1 + .../node_modules/discord.js/LICENSE | 191 + .../node_modules/discord.js/README.md | 144 + .../node_modules/discord.js/package.json | 105 + .../discord.js/src/client/BaseClient.js | 120 + .../discord.js/src/client/Client.js | 631 + .../discord.js/src/client/WebhookClient.js | 103 + .../discord.js/src/client/actions/Action.js | 120 + .../src/client/actions/ActionsManager.js | 84 + .../ApplicationCommandPermissionsUpdate.js | 34 + .../actions/AutoModerationActionExecution.js | 26 + .../actions/AutoModerationRuleCreate.js | 27 + .../actions/AutoModerationRuleDelete.js | 31 + .../actions/AutoModerationRuleUpdate.js | 29 + .../src/client/actions/ChannelCreate.js | 23 + .../src/client/actions/ChannelDelete.js | 23 + .../src/client/actions/ChannelUpdate.js | 42 + .../src/client/actions/EntitlementCreate.js | 23 + .../src/client/actions/EntitlementDelete.js | 27 + .../src/client/actions/EntitlementUpdate.js | 25 + .../actions/GuildAuditLogEntryCreate.js | 29 + .../src/client/actions/GuildBanAdd.js | 20 + .../src/client/actions/GuildBanRemove.js | 25 + .../actions/GuildChannelsPositionUpdate.js | 21 + .../src/client/actions/GuildDelete.js | 44 + .../src/client/actions/GuildEmojiCreate.js | 20 + .../src/client/actions/GuildEmojiDelete.js | 19 + .../src/client/actions/GuildEmojiUpdate.js | 20 + .../src/client/actions/GuildEmojisUpdate.js | 34 + .../client/actions/GuildIntegrationsUpdate.js | 19 + .../src/client/actions/GuildMemberRemove.js | 31 + .../src/client/actions/GuildMemberUpdate.js | 44 + .../src/client/actions/GuildRoleCreate.js | 25 + .../src/client/actions/GuildRoleDelete.js | 29 + .../src/client/actions/GuildRoleUpdate.js | 39 + .../actions/GuildRolesPositionUpdate.js | 21 + .../actions/GuildScheduledEventCreate.js | 27 + .../actions/GuildScheduledEventDelete.js | 31 + .../actions/GuildScheduledEventUpdate.js | 30 + .../actions/GuildScheduledEventUserAdd.js | 32 + .../actions/GuildScheduledEventUserRemove.js | 32 + .../src/client/actions/GuildStickerCreate.js | 20 + .../src/client/actions/GuildStickerDelete.js | 19 + .../src/client/actions/GuildStickerUpdate.js | 20 + .../src/client/actions/GuildStickersUpdate.js | 34 + .../src/client/actions/GuildUpdate.js | 33 + .../src/client/actions/InteractionCreate.js | 101 + .../src/client/actions/InviteCreate.js | 27 + .../src/client/actions/InviteDelete.js | 29 + .../src/client/actions/MessageCreate.js | 41 + .../src/client/actions/MessageDelete.js | 32 + .../src/client/actions/MessageDeleteBulk.js | 47 + .../src/client/actions/MessagePollVoteAdd.js | 33 + .../client/actions/MessagePollVoteRemove.js | 33 + .../src/client/actions/MessageReactionAdd.js | 70 + .../client/actions/MessageReactionRemove.js | 50 + .../actions/MessageReactionRemoveAll.js | 33 + .../actions/MessageReactionRemoveEmoji.js | 28 + .../src/client/actions/MessageUpdate.js | 26 + .../src/client/actions/PresenceUpdate.js | 45 + .../src/client/actions/StageInstanceCreate.js | 28 + .../src/client/actions/StageInstanceDelete.js | 31 + .../src/client/actions/StageInstanceUpdate.js | 30 + .../src/client/actions/ThreadCreate.js | 24 + .../src/client/actions/ThreadDelete.js | 26 + .../src/client/actions/ThreadListSync.js | 60 + .../src/client/actions/ThreadMemberUpdate.js | 30 + .../src/client/actions/ThreadMembersUpdate.js | 47 + .../src/client/actions/TypingStart.js | 29 + .../src/client/actions/UserUpdate.js | 36 + .../src/client/actions/VoiceStateUpdate.js | 43 + .../src/client/actions/WebhooksUpdate.js | 37 + .../src/client/voice/ClientVoiceManager.js | 44 + .../src/client/websocket/WebSocketManager.js | 387 + .../src/client/websocket/WebSocketShard.js | 234 + .../APPLICATION_COMMAND_PERMISSIONS_UPDATE.js | 5 + .../AUTO_MODERATION_ACTION_EXECUTION.js | 5 + .../handlers/AUTO_MODERATION_RULE_CREATE.js | 5 + .../handlers/AUTO_MODERATION_RULE_DELETE.js | 5 + .../handlers/AUTO_MODERATION_RULE_UPDATE.js | 5 + .../websocket/handlers/CHANNEL_CREATE.js | 5 + .../websocket/handlers/CHANNEL_DELETE.js | 5 + .../websocket/handlers/CHANNEL_PINS_UPDATE.js | 22 + .../websocket/handlers/CHANNEL_UPDATE.js | 16 + .../websocket/handlers/ENTITLEMENT_CREATE.js | 5 + .../websocket/handlers/ENTITLEMENT_DELETE.js | 5 + .../websocket/handlers/ENTITLEMENT_UPDATE.js | 5 + .../handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js | 5 + .../websocket/handlers/GUILD_BAN_ADD.js | 5 + .../websocket/handlers/GUILD_BAN_REMOVE.js | 5 + .../client/websocket/handlers/GUILD_CREATE.js | 33 + .../client/websocket/handlers/GUILD_DELETE.js | 5 + .../websocket/handlers/GUILD_EMOJIS_UPDATE.js | 5 + .../handlers/GUILD_INTEGRATIONS_UPDATE.js | 5 + .../websocket/handlers/GUILD_MEMBERS_CHUNK.js | 39 + .../websocket/handlers/GUILD_MEMBER_ADD.js | 20 + .../websocket/handlers/GUILD_MEMBER_REMOVE.js | 5 + .../websocket/handlers/GUILD_MEMBER_UPDATE.js | 5 + .../websocket/handlers/GUILD_ROLE_CREATE.js | 5 + .../websocket/handlers/GUILD_ROLE_DELETE.js | 5 + .../websocket/handlers/GUILD_ROLE_UPDATE.js | 5 + .../handlers/GUILD_SCHEDULED_EVENT_CREATE.js | 5 + .../handlers/GUILD_SCHEDULED_EVENT_DELETE.js | 5 + .../handlers/GUILD_SCHEDULED_EVENT_UPDATE.js | 5 + .../GUILD_SCHEDULED_EVENT_USER_ADD.js | 5 + .../GUILD_SCHEDULED_EVENT_USER_REMOVE.js | 5 + .../handlers/GUILD_STICKERS_UPDATE.js | 5 + .../client/websocket/handlers/GUILD_UPDATE.js | 5 + .../websocket/handlers/INTERACTION_CREATE.js | 5 + .../websocket/handlers/INVITE_CREATE.js | 5 + .../websocket/handlers/INVITE_DELETE.js | 5 + .../websocket/handlers/MESSAGE_CREATE.js | 5 + .../websocket/handlers/MESSAGE_DELETE.js | 5 + .../websocket/handlers/MESSAGE_DELETE_BULK.js | 5 + .../handlers/MESSAGE_POLL_VOTE_ADD.js | 5 + .../handlers/MESSAGE_POLL_VOTE_REMOVE.js | 5 + .../handlers/MESSAGE_REACTION_ADD.js | 5 + .../handlers/MESSAGE_REACTION_REMOVE.js | 5 + .../handlers/MESSAGE_REACTION_REMOVE_ALL.js | 5 + .../handlers/MESSAGE_REACTION_REMOVE_EMOJI.js | 5 + .../websocket/handlers/MESSAGE_UPDATE.js | 16 + .../websocket/handlers/PRESENCE_UPDATE.js | 5 + .../src/client/websocket/handlers/READY.js | 27 + .../src/client/websocket/handlers/RESUMED.js | 14 + .../handlers/STAGE_INSTANCE_CREATE.js | 5 + .../handlers/STAGE_INSTANCE_DELETE.js | 5 + .../handlers/STAGE_INSTANCE_UPDATE.js | 5 + .../websocket/handlers/SUBSCRIPTION_CREATE.js | 14 + .../websocket/handlers/SUBSCRIPTION_DELETE.js | 16 + .../websocket/handlers/SUBSCRIPTION_UPDATE.js | 16 + .../websocket/handlers/THREAD_CREATE.js | 5 + .../websocket/handlers/THREAD_DELETE.js | 5 + .../websocket/handlers/THREAD_LIST_SYNC.js | 5 + .../handlers/THREAD_MEMBERS_UPDATE.js | 5 + .../handlers/THREAD_MEMBER_UPDATE.js | 5 + .../websocket/handlers/THREAD_UPDATE.js | 16 + .../client/websocket/handlers/TYPING_START.js | 5 + .../client/websocket/handlers/USER_UPDATE.js | 5 + .../handlers/VOICE_CHANNEL_EFFECT_SEND.js | 16 + .../websocket/handlers/VOICE_SERVER_UPDATE.js | 6 + .../websocket/handlers/VOICE_STATE_UPDATE.js | 5 + .../websocket/handlers/WEBHOOKS_UPDATE.js | 5 + .../src/client/websocket/handlers/index.js | 73 + .../discord.js/src/errors/DJSError.js | 48 + .../discord.js/src/errors/ErrorCodes.js | 347 + .../discord.js/src/errors/Messages.js | 179 + .../discord.js/src/errors/index.js | 5 + .../node_modules/discord.js/src/index.js | 238 + .../src/managers/ApplicationCommandManager.js | 268 + .../ApplicationCommandPermissionsManager.js | 428 + .../src/managers/ApplicationEmojiManager.js | 142 + .../src/managers/AutoModerationRuleManager.js | 292 + .../src/managers/BaseGuildEmojiManager.js | 85 + .../discord.js/src/managers/BaseManager.js | 19 + .../discord.js/src/managers/CachedManager.js | 64 + .../managers/CategoryChannelChildManager.js | 79 + .../discord.js/src/managers/ChannelManager.js | 128 + .../src/managers/DMMessageManager.js | 17 + .../discord.js/src/managers/DataManager.js | 61 + .../src/managers/EntitlementManager.js | 174 + .../GuildApplicationCommandManager.js | 28 + .../src/managers/GuildBanManager.js | 249 + .../src/managers/GuildChannelManager.js | 519 + .../src/managers/GuildEmojiManager.js | 174 + .../src/managers/GuildEmojiRoleManager.js | 118 + .../src/managers/GuildForumThreadManager.js | 83 + .../src/managers/GuildInviteManager.js | 215 + .../discord.js/src/managers/GuildManager.js | 333 + .../src/managers/GuildMemberManager.js | 560 + .../src/managers/GuildMemberRoleManager.js | 208 + .../src/managers/GuildMessageManager.js | 17 + .../managers/GuildScheduledEventManager.js | 315 + .../src/managers/GuildStickerManager.js | 182 + .../src/managers/GuildTextThreadManager.js | 91 + .../discord.js/src/managers/MessageManager.js | 301 + .../managers/PartialGroupDMMessageManager.js | 17 + .../managers/PermissionOverwriteManager.js | 166 + .../src/managers/PresenceManager.js | 58 + .../src/managers/ReactionManager.js | 68 + .../src/managers/ReactionUserManager.js | 78 + .../discord.js/src/managers/RoleManager.js | 374 + .../src/managers/StageInstanceManager.js | 159 + .../src/managers/SubscriptionManager.js | 81 + .../discord.js/src/managers/ThreadManager.js | 193 + .../src/managers/ThreadMemberManager.js | 204 + .../discord.js/src/managers/UserManager.js | 146 + .../src/managers/VoiceStateManager.js | 59 + .../discord.js/src/sharding/Shard.js | 482 + .../src/sharding/ShardClientUtil.js | 292 + .../src/sharding/ShardingManager.js | 331 + .../discord.js/src/structures/ActionRow.js | 46 + .../src/structures/ActionRowBuilder.js | 35 + .../src/structures/AnonymousGuild.js | 97 + .../src/structures/ApplicationCommand.js | 621 + .../src/structures/ApplicationEmoji.js | 118 + .../ApplicationRoleConnectionMetadata.js | 46 + .../discord.js/src/structures/Attachment.js | 163 + .../src/structures/AttachmentBuilder.js | 111 + .../AutoModerationActionExecution.js | 116 + .../src/structures/AutoModerationRule.js | 288 + .../src/structures/AutocompleteInteraction.js | 102 + .../discord.js/src/structures/Base.js | 43 + .../discord.js/src/structures/BaseChannel.js | 171 + .../discord.js/src/structures/BaseGuild.js | 119 + .../src/structures/BaseGuildEmoji.js | 75 + .../src/structures/BaseGuildTextChannel.js | 196 + .../src/structures/BaseGuildVoiceChannel.js | 234 + .../src/structures/BaseInteraction.js | 333 + .../src/structures/BaseSelectMenuComponent.js | 56 + .../src/structures/ButtonBuilder.js | 44 + .../src/structures/ButtonComponent.js | 65 + .../src/structures/ButtonInteraction.js | 11 + .../src/structures/CategoryChannel.js | 45 + .../structures/ChannelSelectMenuBuilder.js | 31 + .../structures/ChannelSelectMenuComponent.js | 20 + .../ChannelSelectMenuInteraction.js | 33 + .../structures/ChatInputCommandInteraction.js | 42 + .../src/structures/ClientApplication.js | 404 + .../src/structures/ClientPresence.js | 84 + .../discord.js/src/structures/ClientUser.js | 206 + .../src/structures/CommandInteraction.js | 162 + .../CommandInteractionOptionResolver.js | 308 + .../discord.js/src/structures/Component.js | 47 + .../ContextMenuCommandInteraction.js | 65 + .../discord.js/src/structures/DMChannel.js | 129 + .../src/structures/DirectoryChannel.js | 36 + .../discord.js/src/structures/Embed.js | 237 + .../discord.js/src/structures/EmbedBuilder.js | 50 + .../discord.js/src/structures/Emoji.js | 115 + .../discord.js/src/structures/Entitlement.js | 179 + .../discord.js/src/structures/ForumChannel.js | 31 + .../discord.js/src/structures/Guild.js | 1489 ++ .../src/structures/GuildAuditLogs.js | 91 + .../src/structures/GuildAuditLogsEntry.js | 511 + .../discord.js/src/structures/GuildBan.js | 59 + .../discord.js/src/structures/GuildChannel.js | 475 + .../discord.js/src/structures/GuildEmoji.js | 148 + .../discord.js/src/structures/GuildMember.js | 548 + .../src/structures/GuildOnboarding.js | 64 + .../src/structures/GuildOnboardingPrompt.js | 78 + .../structures/GuildOnboardingPromptOption.js | 86 + .../discord.js/src/structures/GuildPreview.js | 193 + .../src/structures/GuildPreviewEmoji.js | 27 + .../src/structures/GuildScheduledEvent.js | 534 + .../src/structures/GuildTemplate.js | 241 + .../discord.js/src/structures/Integration.js | 220 + .../src/structures/IntegrationApplication.js | 85 + .../src/structures/InteractionCallback.js | 74 + .../structures/InteractionCallbackResource.js | 52 + .../structures/InteractionCallbackResponse.js | 33 + .../src/structures/InteractionCollector.js | 269 + .../src/structures/InteractionResponse.js | 102 + .../src/structures/InteractionWebhook.js | 59 + .../discord.js/src/structures/Invite.js | 329 + .../discord.js/src/structures/InviteGuild.js | 22 + .../src/structures/InviteStageInstance.js | 87 + .../discord.js/src/structures/MediaChannel.js | 11 + .../MentionableSelectMenuBuilder.js | 32 + .../MentionableSelectMenuComponent.js | 11 + .../MentionableSelectMenuInteraction.js | 71 + .../discord.js/src/structures/Message.js | 1127 + .../src/structures/MessageCollector.js | 146 + .../structures/MessageComponentInteraction.js | 108 + .../MessageContextMenuCommandInteraction.js | 20 + .../src/structures/MessageMentions.js | 297 + .../src/structures/MessagePayload.js | 344 + .../src/structures/MessageReaction.js | 200 + .../discord.js/src/structures/ModalBuilder.js | 36 + .../src/structures/ModalSubmitFields.js | 55 + .../src/structures/ModalSubmitInteraction.js | 126 + .../discord.js/src/structures/NewsChannel.js | 32 + .../discord.js/src/structures/OAuth2Guild.js | 28 + .../src/structures/PartialGroupDMChannel.js | 131 + .../src/structures/PermissionOverwrites.js | 199 + .../discord.js/src/structures/Poll.js | 109 + .../discord.js/src/structures/PollAnswer.js | 89 + .../discord.js/src/structures/Presence.js | 385 + .../src/structures/ReactionCollector.js | 229 + .../src/structures/ReactionEmoji.js | 31 + .../discord.js/src/structures/Role.js | 467 + .../src/structures/RoleSelectMenuBuilder.js | 31 + .../src/structures/RoleSelectMenuComponent.js | 11 + .../structures/RoleSelectMenuInteraction.js | 33 + .../discord.js/src/structures/SKU.js | 52 + .../src/structures/SelectMenuBuilder.js | 26 + .../src/structures/SelectMenuComponent.js | 26 + .../src/structures/SelectMenuInteraction.js | 26 + .../src/structures/SelectMenuOptionBuilder.js | 26 + .../discord.js/src/structures/StageChannel.js | 112 + .../src/structures/StageInstance.js | 167 + .../discord.js/src/structures/Sticker.js | 268 + .../discord.js/src/structures/StickerPack.js | 95 + .../src/structures/StringSelectMenuBuilder.js | 79 + .../structures/StringSelectMenuComponent.js | 20 + .../structures/StringSelectMenuInteraction.js | 21 + .../StringSelectMenuOptionBuilder.js | 49 + .../discord.js/src/structures/Subscription.js | 117 + .../discord.js/src/structures/Team.js | 117 + .../discord.js/src/structures/TeamMember.js | 79 + .../discord.js/src/structures/TextChannel.js | 33 + .../src/structures/TextInputBuilder.js | 31 + .../src/structures/TextInputComponent.js | 29 + .../src/structures/ThreadChannel.js | 612 + .../discord.js/src/structures/ThreadMember.js | 119 + .../src/structures/ThreadOnlyChannel.js | 249 + .../discord.js/src/structures/Typing.js | 74 + .../discord.js/src/structures/User.js | 411 + .../UserContextMenuCommandInteraction.js | 29 + .../src/structures/UserSelectMenuBuilder.js | 31 + .../src/structures/UserSelectMenuComponent.js | 11 + .../structures/UserSelectMenuInteraction.js | 51 + .../discord.js/src/structures/VoiceChannel.js | 96 + .../src/structures/VoiceChannelEffect.js | 69 + .../discord.js/src/structures/VoiceRegion.js | 46 + .../discord.js/src/structures/VoiceState.js | 312 + .../discord.js/src/structures/Webhook.js | 480 + .../src/structures/WelcomeChannel.js | 60 + .../src/structures/WelcomeScreen.js | 49 + .../discord.js/src/structures/Widget.js | 97 + .../discord.js/src/structures/WidgetMember.js | 99 + .../src/structures/interfaces/Application.js | 158 + .../src/structures/interfaces/Collector.js | 335 + .../interfaces/InteractionResponses.js | 475 + .../structures/interfaces/TextBasedChannel.js | 442 + .../discord.js/src/util/APITypes.js | 611 + .../src/util/ActivityFlagsBitField.js | 26 + .../src/util/ApplicationFlagsBitField.js | 41 + .../src/util/AttachmentFlagsBitField.js | 26 + .../discord.js/src/util/BitField.js | 178 + .../src/util/ChannelFlagsBitField.js | 41 + .../discord.js/src/util/Channels.js | 161 + .../discord.js/src/util/Colors.js | 73 + .../discord.js/src/util/Components.js | 154 + .../discord.js/src/util/Constants.js | 267 + .../discord.js/src/util/DataResolver.js | 141 + .../node_modules/discord.js/src/util/Enums.js | 13 + .../discord.js/src/util/Events.js | 180 + .../discord.js/src/util/Formatters.js | 413 + .../src/util/GuildMemberFlagsBitField.js | 41 + .../discord.js/src/util/IntentsBitField.js | 34 + .../discord.js/src/util/LimitedCollection.js | 68 + .../src/util/MessageFlagsBitField.js | 41 + .../discord.js/src/util/Options.js | 239 + .../discord.js/src/util/Partials.js | 44 + .../src/util/PermissionsBitField.js | 104 + .../discord.js/src/util/RoleFlagsBitField.js | 26 + .../discord.js/src/util/SKUFlagsBitField.js | 26 + .../discord.js/src/util/ShardEvents.js | 29 + .../discord.js/src/util/Status.js | 33 + .../discord.js/src/util/Sweepers.js | 487 + .../discord.js/src/util/Symbols.js | 3 + .../src/util/SystemChannelFlagsBitField.js | 43 + .../src/util/ThreadMemberFlagsBitField.js | 31 + .../discord.js/src/util/Transformers.js | 96 + .../discord.js/src/util/UserFlagsBitField.js | 32 + .../node_modules/discord.js/src/util/Util.js | 558 + .../src/util/WebSocketShardEvents.js | 25 + .../discord.js/typings/index.d.mts | 7415 +++++++ .../discord.js/typings/index.d.ts | 7415 +++++++ .../discord.js/typings/index.test-d.ts | 2782 +++ .../discord.js/typings/rawDataTypes.d.mts | 211 + .../discord.js/typings/rawDataTypes.d.ts | 211 + .../discord.js/typings/tsdoc-metadata.json | 11 + .../node_modules/fast-deep-equal | 1 + .../node_modules/lodash.snakecase | 1 + .../discord.js@14.18.0/node_modules/tslib | 1 + .../discord.js@14.18.0/node_modules/undici | 1 + .../node_modules/@sinclair/typebox | 1 + .../node_modules/cookie | 1 + .../node_modules/elysia/LICENSE | 7 + .../node_modules/elysia/README.md | 27 + .../node_modules/elysia/bunfig.toml | 2 + .../elysia/dist/adapter/bun/handler.d.ts | 5 + .../elysia/dist/adapter/bun/handler.mjs | 26 + .../elysia/dist/adapter/bun/index.d.ts | 2 + .../elysia/dist/adapter/bun/index.mjs | 251 + .../elysia/dist/adapter/index.d.ts | 1 + .../elysia/dist/adapter/index.mjs | 0 .../elysia/dist/adapter/types.d.ts | 107 + .../elysia/dist/adapter/types.mjs | 0 .../dist/adapter/web-standard/handler.d.ts | 11 + .../dist/adapter/web-standard/handler.mjs | 721 + .../dist/adapter/web-standard/index.d.ts | 2 + .../dist/adapter/web-standard/index.mjs | 130 + .../node_modules/elysia/dist/bun/index.d.ts | 1792 ++ .../node_modules/elysia/dist/bun/index.js | 327 + .../node_modules/elysia/dist/bun/index.js.map | 29 + .../elysia/dist/cjs/adapter/bun/handler.js | 49 + .../elysia/dist/cjs/adapter/bun/index.js | 264 + .../elysia/dist/cjs/adapter/index.js | 16 + .../elysia/dist/cjs/adapter/types.js | 16 + .../dist/cjs/adapter/web-standard/handler.js | 753 + .../dist/cjs/adapter/web-standard/index.js | 149 + .../node_modules/elysia/dist/cjs/compose.d.ts | 40 + .../node_modules/elysia/dist/cjs/compose.js | 1543 ++ .../node_modules/elysia/dist/cjs/context.d.ts | 134 + .../node_modules/elysia/dist/cjs/context.js | 16 + .../node_modules/elysia/dist/cjs/cookies.d.ts | 153 + .../node_modules/elysia/dist/cjs/cookies.js | 229 + .../node_modules/elysia/dist/cjs/deuri.d.ts | 12 + .../node_modules/elysia/dist/cjs/deuri.js | 308 + .../elysia/dist/cjs/dynamic-handle.d.ts | 15 + .../elysia/dist/cjs/dynamic-handle.js | 381 + .../node_modules/elysia/dist/cjs/error.d.ts | 190 + .../node_modules/elysia/dist/cjs/error.js | 230 + .../elysia/dist/cjs/fast-querystring.d.ts | 41 + .../elysia/dist/cjs/fast-querystring.js | 169 + .../node_modules/elysia/dist/cjs/formats.d.ts | 79 + .../node_modules/elysia/dist/cjs/formats.js | 170 + .../node_modules/elysia/dist/cjs/index.d.ts | 1792 ++ .../node_modules/elysia/dist/cjs/index.js | 2113 ++ .../elysia/dist/cjs/manifest.d.ts | 0 .../node_modules/elysia/dist/cjs/manifest.js | 1 + .../node_modules/elysia/dist/cjs/sucrose.d.ts | 86 + .../node_modules/elysia/dist/cjs/sucrose.js | 401 + .../node_modules/elysia/dist/cjs/trace.d.ts | 134 + .../node_modules/elysia/dist/cjs/trace.js | 171 + .../elysia/dist/cjs/type-system.d.ts | 90 + .../elysia/dist/cjs/type-system.js | 483 + .../node_modules/elysia/dist/cjs/types.d.ts | 849 + .../node_modules/elysia/dist/cjs/types.js | 16 + .../elysia/dist/cjs/universal/env.js | 29 + .../elysia/dist/cjs/universal/file.js | 167 + .../elysia/dist/cjs/universal/index.js | 31 + .../elysia/dist/cjs/universal/request.js | 169 + .../elysia/dist/cjs/universal/server.js | 16 + .../elysia/dist/cjs/universal/types.js | 44 + .../elysia/dist/cjs/universal/utils.js | 31 + .../node_modules/elysia/dist/cjs/utils.d.ts | 201 + .../node_modules/elysia/dist/cjs/utils.js | 1274 ++ .../node_modules/elysia/dist/cjs/ws/bun.d.ts | 410 + .../node_modules/elysia/dist/cjs/ws/bun.js | 16 + .../elysia/dist/cjs/ws/index.d.ts | 75 + .../node_modules/elysia/dist/cjs/ws/index.js | 212 + .../elysia/dist/cjs/ws/types.d.ts | 63 + .../node_modules/elysia/dist/cjs/ws/types.js | 16 + .../node_modules/elysia/dist/compose.d.ts | 40 + .../node_modules/elysia/dist/compose.mjs | 1528 ++ .../node_modules/elysia/dist/context.d.ts | 134 + .../node_modules/elysia/dist/context.mjs | 0 .../node_modules/elysia/dist/cookies.d.ts | 153 + .../node_modules/elysia/dist/cookies.mjs | 202 + .../node_modules/elysia/dist/deuri.d.ts | 12 + .../node_modules/elysia/dist/deuri.mjs | 282 + .../elysia/dist/dynamic-handle.d.ts | 15 + .../elysia/dist/dynamic-handle.mjs | 361 + .../node_modules/elysia/dist/error.d.ts | 190 + .../node_modules/elysia/dist/error.mjs | 197 + .../elysia/dist/fast-querystring.d.ts | 41 + .../elysia/dist/fast-querystring.mjs | 144 + .../node_modules/elysia/dist/formats.d.ts | 79 + .../node_modules/elysia/dist/formats.mjs | 146 + .../node_modules/elysia/dist/index.d.ts | 1792 ++ .../node_modules/elysia/dist/index.mjs | 2123 ++ .../node_modules/elysia/dist/manifest.d.ts | 0 .../node_modules/elysia/dist/manifest.mjs | 0 .../node_modules/elysia/dist/sucrose.d.ts | 86 + .../node_modules/elysia/dist/sucrose.mjs | 365 + .../node_modules/elysia/dist/trace.d.ts | 134 + .../node_modules/elysia/dist/trace.mjs | 146 + .../node_modules/elysia/dist/type-system.d.ts | 90 + .../node_modules/elysia/dist/type-system.mjs | 460 + .../node_modules/elysia/dist/types.d.ts | 849 + .../node_modules/elysia/dist/types.mjs | 0 .../elysia/dist/universal/env.d.ts | 1 + .../elysia/dist/universal/env.mjs | 5 + .../elysia/dist/universal/file.d.ts | 89 + .../elysia/dist/universal/file.mjs | 130 + .../elysia/dist/universal/index.d.ts | 3 + .../elysia/dist/universal/index.mjs | 6 + .../elysia/dist/universal/request.d.ts | 29 + .../elysia/dist/universal/request.mjs | 145 + .../elysia/dist/universal/server.d.ts | 305 + .../elysia/dist/universal/server.mjs | 0 .../elysia/dist/universal/types.d.ts | 110 + .../elysia/dist/universal/types.mjs | 19 + .../elysia/dist/universal/utils.d.ts | 2 + .../elysia/dist/universal/utils.mjs | 6 + .../node_modules/elysia/dist/utils.d.ts | 201 + .../node_modules/elysia/dist/utils.mjs | 1209 ++ .../node_modules/elysia/dist/ws/bun.d.ts | 410 + .../node_modules/elysia/dist/ws/bun.mjs | 0 .../node_modules/elysia/dist/ws/index.d.ts | 75 + .../node_modules/elysia/dist/ws/index.mjs | 185 + .../node_modules/elysia/dist/ws/types.d.ts | 63 + .../node_modules/elysia/dist/ws/types.mjs | 0 .../node_modules/elysia/package.json | 194 + .../node_modules/memoirist | 1 + .../node_modules/fast-deep-equal/LICENSE | 21 + .../node_modules/fast-deep-equal/README.md | 96 + .../fast-deep-equal/es6/index.d.ts | 2 + .../node_modules/fast-deep-equal/es6/index.js | 72 + .../fast-deep-equal/es6/react.d.ts | 2 + .../node_modules/fast-deep-equal/es6/react.js | 79 + .../node_modules/fast-deep-equal/index.d.ts | 4 + .../node_modules/fast-deep-equal/index.js | 46 + .../node_modules/fast-deep-equal/package.json | 61 + .../node_modules/fast-deep-equal/react.d.ts | 2 + .../node_modules/fast-deep-equal/react.js | 53 + node_modules/.pnpm/lock.yaml | 264 + .../node_modules/lodash.snakecase/LICENSE | 47 + .../node_modules/lodash.snakecase/README.md | 18 + .../node_modules/lodash.snakecase/index.js | 435 + .../lodash.snakecase/package.json | 17 + .../node_modules/lodash/LICENSE | 47 + .../node_modules/lodash/README.md | 39 + .../node_modules/lodash/_DataView.js | 7 + .../node_modules/lodash/_Hash.js | 32 + .../node_modules/lodash/_LazyWrapper.js | 28 + .../node_modules/lodash/_ListCache.js | 32 + .../node_modules/lodash/_LodashWrapper.js | 22 + .../node_modules/lodash/_Map.js | 7 + .../node_modules/lodash/_MapCache.js | 32 + .../node_modules/lodash/_Promise.js | 7 + .../node_modules/lodash/_Set.js | 7 + .../node_modules/lodash/_SetCache.js | 27 + .../node_modules/lodash/_Stack.js | 27 + .../node_modules/lodash/_Symbol.js | 6 + .../node_modules/lodash/_Uint8Array.js | 6 + .../node_modules/lodash/_WeakMap.js | 7 + .../node_modules/lodash/_apply.js | 21 + .../node_modules/lodash/_arrayAggregator.js | 22 + .../node_modules/lodash/_arrayEach.js | 22 + .../node_modules/lodash/_arrayEachRight.js | 21 + .../node_modules/lodash/_arrayEvery.js | 23 + .../node_modules/lodash/_arrayFilter.js | 25 + .../node_modules/lodash/_arrayIncludes.js | 17 + .../node_modules/lodash/_arrayIncludesWith.js | 22 + .../node_modules/lodash/_arrayLikeKeys.js | 49 + .../node_modules/lodash/_arrayMap.js | 21 + .../node_modules/lodash/_arrayPush.js | 20 + .../node_modules/lodash/_arrayReduce.js | 26 + .../node_modules/lodash/_arrayReduceRight.js | 24 + .../node_modules/lodash/_arraySample.js | 15 + .../node_modules/lodash/_arraySampleSize.js | 17 + .../node_modules/lodash/_arrayShuffle.js | 15 + .../node_modules/lodash/_arraySome.js | 23 + .../node_modules/lodash/_asciiSize.js | 12 + .../node_modules/lodash/_asciiToArray.js | 12 + .../node_modules/lodash/_asciiWords.js | 15 + .../node_modules/lodash/_assignMergeValue.js | 20 + .../node_modules/lodash/_assignValue.js | 28 + .../node_modules/lodash/_assocIndexOf.js | 21 + .../node_modules/lodash/_baseAggregator.js | 21 + .../node_modules/lodash/_baseAssign.js | 17 + .../node_modules/lodash/_baseAssignIn.js | 17 + .../node_modules/lodash/_baseAssignValue.js | 25 + .../node_modules/lodash/_baseAt.js | 23 + .../node_modules/lodash/_baseClamp.js | 22 + .../node_modules/lodash/_baseClone.js | 166 + .../node_modules/lodash/_baseConforms.js | 18 + .../node_modules/lodash/_baseConformsTo.js | 27 + .../node_modules/lodash/_baseCreate.js | 30 + .../node_modules/lodash/_baseDelay.js | 21 + .../node_modules/lodash/_baseDifference.js | 67 + .../node_modules/lodash/_baseEach.js | 14 + .../node_modules/lodash/_baseEachRight.js | 14 + .../node_modules/lodash/_baseEvery.js | 21 + .../node_modules/lodash/_baseExtremum.js | 32 + .../node_modules/lodash/_baseFill.js | 32 + .../node_modules/lodash/_baseFilter.js | 21 + .../node_modules/lodash/_baseFindIndex.js | 24 + .../node_modules/lodash/_baseFindKey.js | 23 + .../node_modules/lodash/_baseFlatten.js | 38 + .../node_modules/lodash/_baseFor.js | 16 + .../node_modules/lodash/_baseForOwn.js | 16 + .../node_modules/lodash/_baseForOwnRight.js | 16 + .../node_modules/lodash/_baseForRight.js | 15 + .../node_modules/lodash/_baseFunctions.js | 19 + .../node_modules/lodash/_baseGet.js | 24 + .../node_modules/lodash/_baseGetAllKeys.js | 20 + .../node_modules/lodash/_baseGetTag.js | 28 + .../node_modules/lodash/_baseGt.js | 14 + .../node_modules/lodash/_baseHas.js | 19 + .../node_modules/lodash/_baseHasIn.js | 13 + .../node_modules/lodash/_baseInRange.js | 18 + .../node_modules/lodash/_baseIndexOf.js | 20 + .../node_modules/lodash/_baseIndexOfWith.js | 23 + .../node_modules/lodash/_baseIntersection.js | 74 + .../node_modules/lodash/_baseInverter.js | 21 + .../node_modules/lodash/_baseInvoke.js | 24 + .../node_modules/lodash/_baseIsArguments.js | 18 + .../node_modules/lodash/_baseIsArrayBuffer.js | 17 + .../node_modules/lodash/_baseIsDate.js | 18 + .../node_modules/lodash/_baseIsEqual.js | 28 + .../node_modules/lodash/_baseIsEqualDeep.js | 83 + .../node_modules/lodash/_baseIsMap.js | 18 + .../node_modules/lodash/_baseIsMatch.js | 62 + .../node_modules/lodash/_baseIsNaN.js | 12 + .../node_modules/lodash/_baseIsNative.js | 47 + .../node_modules/lodash/_baseIsRegExp.js | 18 + .../node_modules/lodash/_baseIsSet.js | 18 + .../node_modules/lodash/_baseIsTypedArray.js | 60 + .../node_modules/lodash/_baseIteratee.js | 31 + .../node_modules/lodash/_baseKeys.js | 30 + .../node_modules/lodash/_baseKeysIn.js | 33 + .../node_modules/lodash/_baseLodash.js | 10 + .../node_modules/lodash/_baseLt.js | 14 + .../node_modules/lodash/_baseMap.js | 22 + .../node_modules/lodash/_baseMatches.js | 22 + .../lodash/_baseMatchesProperty.js | 33 + .../node_modules/lodash/_baseMean.js | 20 + .../node_modules/lodash/_baseMerge.js | 42 + .../node_modules/lodash/_baseMergeDeep.js | 94 + .../node_modules/lodash/_baseNth.js | 20 + .../node_modules/lodash/_baseOrderBy.js | 49 + .../node_modules/lodash/_basePick.js | 19 + .../node_modules/lodash/_basePickBy.js | 30 + .../node_modules/lodash/_baseProperty.js | 14 + .../node_modules/lodash/_basePropertyDeep.js | 16 + .../node_modules/lodash/_basePropertyOf.js | 14 + .../node_modules/lodash/_basePullAll.js | 51 + .../node_modules/lodash/_basePullAt.js | 37 + .../node_modules/lodash/_baseRandom.js | 18 + .../node_modules/lodash/_baseRange.js | 28 + .../node_modules/lodash/_baseReduce.js | 23 + .../node_modules/lodash/_baseRepeat.js | 35 + .../node_modules/lodash/_baseRest.js | 17 + .../node_modules/lodash/_baseSample.js | 15 + .../node_modules/lodash/_baseSampleSize.js | 18 + .../node_modules/lodash/_baseSet.js | 51 + .../node_modules/lodash/_baseSetData.js | 17 + .../node_modules/lodash/_baseSetToString.js | 22 + .../node_modules/lodash/_baseShuffle.js | 15 + .../node_modules/lodash/_baseSlice.js | 31 + .../node_modules/lodash/_baseSome.js | 22 + .../node_modules/lodash/_baseSortBy.js | 21 + .../node_modules/lodash/_baseSortedIndex.js | 42 + .../node_modules/lodash/_baseSortedIndexBy.js | 67 + .../node_modules/lodash/_baseSortedUniq.js | 30 + .../node_modules/lodash/_baseSum.js | 24 + .../node_modules/lodash/_baseTimes.js | 20 + .../node_modules/lodash/_baseToNumber.js | 24 + .../node_modules/lodash/_baseToPairs.js | 18 + .../node_modules/lodash/_baseToString.js | 37 + .../node_modules/lodash/_baseTrim.js | 19 + .../node_modules/lodash/_baseUnary.js | 14 + .../node_modules/lodash/_baseUniq.js | 72 + .../node_modules/lodash/_baseUnset.js | 20 + .../node_modules/lodash/_baseUpdate.js | 18 + .../node_modules/lodash/_baseValues.js | 19 + .../node_modules/lodash/_baseWhile.js | 26 + .../node_modules/lodash/_baseWrapperValue.js | 25 + .../node_modules/lodash/_baseXor.js | 36 + .../node_modules/lodash/_baseZipObject.js | 23 + .../node_modules/lodash/_cacheHas.js | 13 + .../lodash/_castArrayLikeObject.js | 14 + .../node_modules/lodash/_castFunction.js | 14 + .../node_modules/lodash/_castPath.js | 21 + .../node_modules/lodash/_castRest.js | 14 + .../node_modules/lodash/_castSlice.js | 18 + .../node_modules/lodash/_charsEndIndex.js | 19 + .../node_modules/lodash/_charsStartIndex.js | 20 + .../node_modules/lodash/_cloneArrayBuffer.js | 16 + .../node_modules/lodash/_cloneBuffer.js | 35 + .../node_modules/lodash/_cloneDataView.js | 16 + .../node_modules/lodash/_cloneRegExp.js | 17 + .../node_modules/lodash/_cloneSymbol.js | 18 + .../node_modules/lodash/_cloneTypedArray.js | 16 + .../node_modules/lodash/_compareAscending.js | 41 + .../node_modules/lodash/_compareMultiple.js | 44 + .../node_modules/lodash/_composeArgs.js | 39 + .../node_modules/lodash/_composeArgsRight.js | 41 + .../node_modules/lodash/_copyArray.js | 20 + .../node_modules/lodash/_copyObject.js | 40 + .../node_modules/lodash/_copySymbols.js | 16 + .../node_modules/lodash/_copySymbolsIn.js | 16 + .../node_modules/lodash/_coreJsData.js | 6 + .../node_modules/lodash/_countHolders.js | 21 + .../node_modules/lodash/_createAggregator.js | 23 + .../node_modules/lodash/_createAssigner.js | 37 + .../node_modules/lodash/_createBaseEach.js | 32 + .../node_modules/lodash/_createBaseFor.js | 25 + .../node_modules/lodash/_createBind.js | 28 + .../node_modules/lodash/_createCaseFirst.js | 33 + .../node_modules/lodash/_createCompounder.js | 24 + .../node_modules/lodash/_createCtor.js | 37 + .../node_modules/lodash/_createCurry.js | 46 + .../node_modules/lodash/_createFind.js | 25 + .../node_modules/lodash/_createFlow.js | 78 + .../node_modules/lodash/_createHybrid.js | 92 + .../node_modules/lodash/_createInverter.js | 17 + .../lodash/_createMathOperation.js | 38 + .../node_modules/lodash/_createOver.js | 27 + .../node_modules/lodash/_createPadding.js | 33 + .../node_modules/lodash/_createPartial.js | 43 + .../node_modules/lodash/_createRange.js | 30 + .../node_modules/lodash/_createRecurry.js | 56 + .../lodash/_createRelationalOperation.js | 20 + .../node_modules/lodash/_createRound.js | 35 + .../node_modules/lodash/_createSet.js | 19 + .../node_modules/lodash/_createToPairs.js | 30 + .../node_modules/lodash/_createWrap.js | 106 + .../lodash/_customDefaultsAssignIn.js | 29 + .../lodash/_customDefaultsMerge.js | 28 + .../node_modules/lodash/_customOmitClone.js | 16 + .../node_modules/lodash/_deburrLetter.js | 71 + .../node_modules/lodash/_defineProperty.js | 11 + .../node_modules/lodash/_equalArrays.js | 84 + .../node_modules/lodash/_equalByTag.js | 112 + .../node_modules/lodash/_equalObjects.js | 90 + .../node_modules/lodash/_escapeHtmlChar.js | 21 + .../node_modules/lodash/_escapeStringChar.js | 22 + .../node_modules/lodash/_flatRest.js | 16 + .../node_modules/lodash/_freeGlobal.js | 4 + .../node_modules/lodash/_getAllKeys.js | 16 + .../node_modules/lodash/_getAllKeysIn.js | 17 + .../node_modules/lodash/_getData.js | 15 + .../node_modules/lodash/_getFuncName.js | 31 + .../node_modules/lodash/_getHolder.js | 13 + .../node_modules/lodash/_getMapData.js | 18 + .../node_modules/lodash/_getMatchData.js | 24 + .../node_modules/lodash/_getNative.js | 17 + .../node_modules/lodash/_getPrototype.js | 6 + .../node_modules/lodash/_getRawTag.js | 46 + .../node_modules/lodash/_getSymbols.js | 30 + .../node_modules/lodash/_getSymbolsIn.js | 25 + .../node_modules/lodash/_getTag.js | 58 + .../node_modules/lodash/_getValue.js | 13 + .../node_modules/lodash/_getView.js | 33 + .../node_modules/lodash/_getWrapDetails.js | 17 + .../node_modules/lodash/_hasPath.js | 39 + .../node_modules/lodash/_hasUnicode.js | 26 + .../node_modules/lodash/_hasUnicodeWord.js | 15 + .../node_modules/lodash/_hashClear.js | 15 + .../node_modules/lodash/_hashDelete.js | 17 + .../node_modules/lodash/_hashGet.js | 30 + .../node_modules/lodash/_hashHas.js | 23 + .../node_modules/lodash/_hashSet.js | 23 + .../node_modules/lodash/_initCloneArray.js | 26 + .../node_modules/lodash/_initCloneByTag.js | 77 + .../node_modules/lodash/_initCloneObject.js | 18 + .../node_modules/lodash/_insertWrapDetails.js | 23 + .../node_modules/lodash/_isFlattenable.js | 20 + .../node_modules/lodash/_isIndex.js | 25 + .../node_modules/lodash/_isIterateeCall.js | 30 + .../node_modules/lodash/_isKey.js | 29 + .../node_modules/lodash/_isKeyable.js | 15 + .../node_modules/lodash/_isLaziable.js | 28 + .../node_modules/lodash/_isMaskable.js | 14 + .../node_modules/lodash/_isMasked.js | 20 + .../node_modules/lodash/_isPrototype.js | 18 + .../lodash/_isStrictComparable.js | 15 + .../node_modules/lodash/_iteratorToArray.js | 18 + .../node_modules/lodash/_lazyClone.js | 23 + .../node_modules/lodash/_lazyReverse.js | 23 + .../node_modules/lodash/_lazyValue.js | 69 + .../node_modules/lodash/_listCacheClear.js | 13 + .../node_modules/lodash/_listCacheDelete.js | 35 + .../node_modules/lodash/_listCacheGet.js | 19 + .../node_modules/lodash/_listCacheHas.js | 16 + .../node_modules/lodash/_listCacheSet.js | 26 + .../node_modules/lodash/_mapCacheClear.js | 21 + .../node_modules/lodash/_mapCacheDelete.js | 18 + .../node_modules/lodash/_mapCacheGet.js | 16 + .../node_modules/lodash/_mapCacheHas.js | 16 + .../node_modules/lodash/_mapCacheSet.js | 22 + .../node_modules/lodash/_mapToArray.js | 18 + .../lodash/_matchesStrictComparable.js | 20 + .../node_modules/lodash/_memoizeCapped.js | 26 + .../node_modules/lodash/_mergeData.js | 90 + .../node_modules/lodash/_metaMap.js | 6 + .../node_modules/lodash/_nativeCreate.js | 6 + .../node_modules/lodash/_nativeKeys.js | 6 + .../node_modules/lodash/_nativeKeysIn.js | 20 + .../node_modules/lodash/_nodeUtil.js | 30 + .../node_modules/lodash/_objectToString.js | 22 + .../node_modules/lodash/_overArg.js | 15 + .../node_modules/lodash/_overRest.js | 36 + .../node_modules/lodash/_parent.js | 16 + .../node_modules/lodash/_reEscape.js | 4 + .../node_modules/lodash/_reEvaluate.js | 4 + .../node_modules/lodash/_reInterpolate.js | 4 + .../node_modules/lodash/_realNames.js | 4 + .../node_modules/lodash/_reorder.js | 29 + .../node_modules/lodash/_replaceHolders.js | 29 + .../node_modules/lodash/_root.js | 9 + .../node_modules/lodash/_safeGet.js | 21 + .../node_modules/lodash/_setCacheAdd.js | 19 + .../node_modules/lodash/_setCacheHas.js | 14 + .../node_modules/lodash/_setData.js | 20 + .../node_modules/lodash/_setToArray.js | 18 + .../node_modules/lodash/_setToPairs.js | 18 + .../node_modules/lodash/_setToString.js | 14 + .../node_modules/lodash/_setWrapToString.js | 21 + .../node_modules/lodash/_shortOut.js | 37 + .../node_modules/lodash/_shuffleSelf.js | 28 + .../node_modules/lodash/_stackClear.js | 15 + .../node_modules/lodash/_stackDelete.js | 18 + .../node_modules/lodash/_stackGet.js | 14 + .../node_modules/lodash/_stackHas.js | 14 + .../node_modules/lodash/_stackSet.js | 34 + .../node_modules/lodash/_strictIndexOf.js | 23 + .../node_modules/lodash/_strictLastIndexOf.js | 21 + .../node_modules/lodash/_stringSize.js | 18 + .../node_modules/lodash/_stringToArray.js | 18 + .../node_modules/lodash/_stringToPath.js | 27 + .../node_modules/lodash/_toKey.js | 21 + .../node_modules/lodash/_toSource.js | 26 + .../node_modules/lodash/_trimmedEndIndex.js | 19 + .../node_modules/lodash/_unescapeHtmlChar.js | 21 + .../node_modules/lodash/_unicodeSize.js | 44 + .../node_modules/lodash/_unicodeToArray.js | 40 + .../node_modules/lodash/_unicodeWords.js | 69 + .../node_modules/lodash/_updateWrapDetails.js | 46 + .../node_modules/lodash/_wrapperClone.js | 23 + .../lodash@4.17.21/node_modules/lodash/add.js | 22 + .../node_modules/lodash/after.js | 42 + .../node_modules/lodash/array.js | 67 + .../lodash@4.17.21/node_modules/lodash/ary.js | 29 + .../node_modules/lodash/assign.js | 58 + .../node_modules/lodash/assignIn.js | 40 + .../node_modules/lodash/assignInWith.js | 38 + .../node_modules/lodash/assignWith.js | 37 + .../lodash@4.17.21/node_modules/lodash/at.js | 23 + .../node_modules/lodash/attempt.js | 35 + .../node_modules/lodash/before.js | 40 + .../node_modules/lodash/bind.js | 57 + .../node_modules/lodash/bindAll.js | 41 + .../node_modules/lodash/bindKey.js | 68 + .../node_modules/lodash/camelCase.js | 29 + .../node_modules/lodash/capitalize.js | 23 + .../node_modules/lodash/castArray.js | 44 + .../node_modules/lodash/ceil.js | 26 + .../node_modules/lodash/chain.js | 38 + .../node_modules/lodash/chunk.js | 50 + .../node_modules/lodash/clamp.js | 39 + .../node_modules/lodash/clone.js | 36 + .../node_modules/lodash/cloneDeep.js | 29 + .../node_modules/lodash/cloneDeepWith.js | 40 + .../node_modules/lodash/cloneWith.js | 42 + .../node_modules/lodash/collection.js | 30 + .../node_modules/lodash/commit.js | 33 + .../node_modules/lodash/compact.js | 31 + .../node_modules/lodash/concat.js | 43 + .../node_modules/lodash/cond.js | 60 + .../node_modules/lodash/conforms.js | 35 + .../node_modules/lodash/conformsTo.js | 32 + .../node_modules/lodash/constant.js | 26 + .../node_modules/lodash/core.js | 3877 ++++ .../node_modules/lodash/core.min.js | 29 + .../node_modules/lodash/countBy.js | 40 + .../node_modules/lodash/create.js | 43 + .../node_modules/lodash/curry.js | 57 + .../node_modules/lodash/curryRight.js | 54 + .../node_modules/lodash/date.js | 3 + .../node_modules/lodash/debounce.js | 191 + .../node_modules/lodash/deburr.js | 45 + .../node_modules/lodash/defaultTo.js | 25 + .../node_modules/lodash/defaults.js | 64 + .../node_modules/lodash/defaultsDeep.js | 30 + .../node_modules/lodash/defer.js | 26 + .../node_modules/lodash/delay.js | 28 + .../node_modules/lodash/difference.js | 33 + .../node_modules/lodash/differenceBy.js | 44 + .../node_modules/lodash/differenceWith.js | 40 + .../node_modules/lodash/divide.js | 22 + .../node_modules/lodash/drop.js | 38 + .../node_modules/lodash/dropRight.js | 39 + .../node_modules/lodash/dropRightWhile.js | 45 + .../node_modules/lodash/dropWhile.js | 45 + .../node_modules/lodash/each.js | 1 + .../node_modules/lodash/eachRight.js | 1 + .../node_modules/lodash/endsWith.js | 43 + .../node_modules/lodash/entries.js | 1 + .../node_modules/lodash/entriesIn.js | 1 + .../lodash@4.17.21/node_modules/lodash/eq.js | 37 + .../node_modules/lodash/escape.js | 43 + .../node_modules/lodash/escapeRegExp.js | 32 + .../node_modules/lodash/every.js | 56 + .../node_modules/lodash/extend.js | 1 + .../node_modules/lodash/extendWith.js | 1 + .../node_modules/lodash/fill.js | 45 + .../node_modules/lodash/filter.js | 52 + .../node_modules/lodash/find.js | 42 + .../node_modules/lodash/findIndex.js | 55 + .../node_modules/lodash/findKey.js | 44 + .../node_modules/lodash/findLast.js | 25 + .../node_modules/lodash/findLastIndex.js | 59 + .../node_modules/lodash/findLastKey.js | 44 + .../node_modules/lodash/first.js | 1 + .../node_modules/lodash/flake.lock | 40 + .../node_modules/lodash/flake.nix | 20 + .../node_modules/lodash/flatMap.js | 29 + .../node_modules/lodash/flatMapDeep.js | 31 + .../node_modules/lodash/flatMapDepth.js | 31 + .../node_modules/lodash/flatten.js | 22 + .../node_modules/lodash/flattenDeep.js | 25 + .../node_modules/lodash/flattenDepth.js | 33 + .../node_modules/lodash/flip.js | 28 + .../node_modules/lodash/floor.js | 26 + .../node_modules/lodash/flow.js | 27 + .../node_modules/lodash/flowRight.js | 26 + .../node_modules/lodash/forEach.js | 41 + .../node_modules/lodash/forEachRight.js | 31 + .../node_modules/lodash/forIn.js | 39 + .../node_modules/lodash/forInRight.js | 37 + .../node_modules/lodash/forOwn.js | 36 + .../node_modules/lodash/forOwnRight.js | 34 + .../lodash@4.17.21/node_modules/lodash/fp.js | 2 + .../node_modules/lodash/fp/F.js | 1 + .../node_modules/lodash/fp/T.js | 1 + .../node_modules/lodash/fp/__.js | 1 + .../node_modules/lodash/fp/_baseConvert.js | 569 + .../node_modules/lodash/fp/_convertBrowser.js | 18 + .../node_modules/lodash/fp/_falseOptions.js | 7 + .../node_modules/lodash/fp/_mapping.js | 358 + .../node_modules/lodash/fp/_util.js | 16 + .../node_modules/lodash/fp/add.js | 5 + .../node_modules/lodash/fp/after.js | 5 + .../node_modules/lodash/fp/all.js | 1 + .../node_modules/lodash/fp/allPass.js | 1 + .../node_modules/lodash/fp/always.js | 1 + .../node_modules/lodash/fp/any.js | 1 + .../node_modules/lodash/fp/anyPass.js | 1 + .../node_modules/lodash/fp/apply.js | 1 + .../node_modules/lodash/fp/array.js | 2 + .../node_modules/lodash/fp/ary.js | 5 + .../node_modules/lodash/fp/assign.js | 5 + .../node_modules/lodash/fp/assignAll.js | 5 + .../node_modules/lodash/fp/assignAllWith.js | 5 + .../node_modules/lodash/fp/assignIn.js | 5 + .../node_modules/lodash/fp/assignInAll.js | 5 + .../node_modules/lodash/fp/assignInAllWith.js | 5 + .../node_modules/lodash/fp/assignInWith.js | 5 + .../node_modules/lodash/fp/assignWith.js | 5 + .../node_modules/lodash/fp/assoc.js | 1 + .../node_modules/lodash/fp/assocPath.js | 1 + .../node_modules/lodash/fp/at.js | 5 + .../node_modules/lodash/fp/attempt.js | 5 + .../node_modules/lodash/fp/before.js | 5 + .../node_modules/lodash/fp/bind.js | 5 + .../node_modules/lodash/fp/bindAll.js | 5 + .../node_modules/lodash/fp/bindKey.js | 5 + .../node_modules/lodash/fp/camelCase.js | 5 + .../node_modules/lodash/fp/capitalize.js | 5 + .../node_modules/lodash/fp/castArray.js | 5 + .../node_modules/lodash/fp/ceil.js | 5 + .../node_modules/lodash/fp/chain.js | 5 + .../node_modules/lodash/fp/chunk.js | 5 + .../node_modules/lodash/fp/clamp.js | 5 + .../node_modules/lodash/fp/clone.js | 5 + .../node_modules/lodash/fp/cloneDeep.js | 5 + .../node_modules/lodash/fp/cloneDeepWith.js | 5 + .../node_modules/lodash/fp/cloneWith.js | 5 + .../node_modules/lodash/fp/collection.js | 2 + .../node_modules/lodash/fp/commit.js | 5 + .../node_modules/lodash/fp/compact.js | 5 + .../node_modules/lodash/fp/complement.js | 1 + .../node_modules/lodash/fp/compose.js | 1 + .../node_modules/lodash/fp/concat.js | 5 + .../node_modules/lodash/fp/cond.js | 5 + .../node_modules/lodash/fp/conforms.js | 1 + .../node_modules/lodash/fp/conformsTo.js | 5 + .../node_modules/lodash/fp/constant.js | 5 + .../node_modules/lodash/fp/contains.js | 1 + .../node_modules/lodash/fp/convert.js | 18 + .../node_modules/lodash/fp/countBy.js | 5 + .../node_modules/lodash/fp/create.js | 5 + .../node_modules/lodash/fp/curry.js | 5 + .../node_modules/lodash/fp/curryN.js | 5 + .../node_modules/lodash/fp/curryRight.js | 5 + .../node_modules/lodash/fp/curryRightN.js | 5 + .../node_modules/lodash/fp/date.js | 2 + .../node_modules/lodash/fp/debounce.js | 5 + .../node_modules/lodash/fp/deburr.js | 5 + .../node_modules/lodash/fp/defaultTo.js | 5 + .../node_modules/lodash/fp/defaults.js | 5 + .../node_modules/lodash/fp/defaultsAll.js | 5 + .../node_modules/lodash/fp/defaultsDeep.js | 5 + .../node_modules/lodash/fp/defaultsDeepAll.js | 5 + .../node_modules/lodash/fp/defer.js | 5 + .../node_modules/lodash/fp/delay.js | 5 + .../node_modules/lodash/fp/difference.js | 5 + .../node_modules/lodash/fp/differenceBy.js | 5 + .../node_modules/lodash/fp/differenceWith.js | 5 + .../node_modules/lodash/fp/dissoc.js | 1 + .../node_modules/lodash/fp/dissocPath.js | 1 + .../node_modules/lodash/fp/divide.js | 5 + .../node_modules/lodash/fp/drop.js | 5 + .../node_modules/lodash/fp/dropLast.js | 1 + .../node_modules/lodash/fp/dropLastWhile.js | 1 + .../node_modules/lodash/fp/dropRight.js | 5 + .../node_modules/lodash/fp/dropRightWhile.js | 5 + .../node_modules/lodash/fp/dropWhile.js | 5 + .../node_modules/lodash/fp/each.js | 1 + .../node_modules/lodash/fp/eachRight.js | 1 + .../node_modules/lodash/fp/endsWith.js | 5 + .../node_modules/lodash/fp/entries.js | 1 + .../node_modules/lodash/fp/entriesIn.js | 1 + .../node_modules/lodash/fp/eq.js | 5 + .../node_modules/lodash/fp/equals.js | 1 + .../node_modules/lodash/fp/escape.js | 5 + .../node_modules/lodash/fp/escapeRegExp.js | 5 + .../node_modules/lodash/fp/every.js | 5 + .../node_modules/lodash/fp/extend.js | 1 + .../node_modules/lodash/fp/extendAll.js | 1 + .../node_modules/lodash/fp/extendAllWith.js | 1 + .../node_modules/lodash/fp/extendWith.js | 1 + .../node_modules/lodash/fp/fill.js | 5 + .../node_modules/lodash/fp/filter.js | 5 + .../node_modules/lodash/fp/find.js | 5 + .../node_modules/lodash/fp/findFrom.js | 5 + .../node_modules/lodash/fp/findIndex.js | 5 + .../node_modules/lodash/fp/findIndexFrom.js | 5 + .../node_modules/lodash/fp/findKey.js | 5 + .../node_modules/lodash/fp/findLast.js | 5 + .../node_modules/lodash/fp/findLastFrom.js | 5 + .../node_modules/lodash/fp/findLastIndex.js | 5 + .../lodash/fp/findLastIndexFrom.js | 5 + .../node_modules/lodash/fp/findLastKey.js | 5 + .../node_modules/lodash/fp/first.js | 1 + .../node_modules/lodash/fp/flatMap.js | 5 + .../node_modules/lodash/fp/flatMapDeep.js | 5 + .../node_modules/lodash/fp/flatMapDepth.js | 5 + .../node_modules/lodash/fp/flatten.js | 5 + .../node_modules/lodash/fp/flattenDeep.js | 5 + .../node_modules/lodash/fp/flattenDepth.js | 5 + .../node_modules/lodash/fp/flip.js | 5 + .../node_modules/lodash/fp/floor.js | 5 + .../node_modules/lodash/fp/flow.js | 5 + .../node_modules/lodash/fp/flowRight.js | 5 + .../node_modules/lodash/fp/forEach.js | 5 + .../node_modules/lodash/fp/forEachRight.js | 5 + .../node_modules/lodash/fp/forIn.js | 5 + .../node_modules/lodash/fp/forInRight.js | 5 + .../node_modules/lodash/fp/forOwn.js | 5 + .../node_modules/lodash/fp/forOwnRight.js | 5 + .../node_modules/lodash/fp/fromPairs.js | 5 + .../node_modules/lodash/fp/function.js | 2 + .../node_modules/lodash/fp/functions.js | 5 + .../node_modules/lodash/fp/functionsIn.js | 5 + .../node_modules/lodash/fp/get.js | 5 + .../node_modules/lodash/fp/getOr.js | 5 + .../node_modules/lodash/fp/groupBy.js | 5 + .../node_modules/lodash/fp/gt.js | 5 + .../node_modules/lodash/fp/gte.js | 5 + .../node_modules/lodash/fp/has.js | 5 + .../node_modules/lodash/fp/hasIn.js | 5 + .../node_modules/lodash/fp/head.js | 5 + .../node_modules/lodash/fp/identical.js | 1 + .../node_modules/lodash/fp/identity.js | 5 + .../node_modules/lodash/fp/inRange.js | 5 + .../node_modules/lodash/fp/includes.js | 5 + .../node_modules/lodash/fp/includesFrom.js | 5 + .../node_modules/lodash/fp/indexBy.js | 1 + .../node_modules/lodash/fp/indexOf.js | 5 + .../node_modules/lodash/fp/indexOfFrom.js | 5 + .../node_modules/lodash/fp/init.js | 1 + .../node_modules/lodash/fp/initial.js | 5 + .../node_modules/lodash/fp/intersection.js | 5 + .../node_modules/lodash/fp/intersectionBy.js | 5 + .../lodash/fp/intersectionWith.js | 5 + .../node_modules/lodash/fp/invert.js | 5 + .../node_modules/lodash/fp/invertBy.js | 5 + .../node_modules/lodash/fp/invertObj.js | 1 + .../node_modules/lodash/fp/invoke.js | 5 + .../node_modules/lodash/fp/invokeArgs.js | 5 + .../node_modules/lodash/fp/invokeArgsMap.js | 5 + .../node_modules/lodash/fp/invokeMap.js | 5 + .../node_modules/lodash/fp/isArguments.js | 5 + .../node_modules/lodash/fp/isArray.js | 5 + .../node_modules/lodash/fp/isArrayBuffer.js | 5 + .../node_modules/lodash/fp/isArrayLike.js | 5 + .../lodash/fp/isArrayLikeObject.js | 5 + .../node_modules/lodash/fp/isBoolean.js | 5 + .../node_modules/lodash/fp/isBuffer.js | 5 + .../node_modules/lodash/fp/isDate.js | 5 + .../node_modules/lodash/fp/isElement.js | 5 + .../node_modules/lodash/fp/isEmpty.js | 5 + .../node_modules/lodash/fp/isEqual.js | 5 + .../node_modules/lodash/fp/isEqualWith.js | 5 + .../node_modules/lodash/fp/isError.js | 5 + .../node_modules/lodash/fp/isFinite.js | 5 + .../node_modules/lodash/fp/isFunction.js | 5 + .../node_modules/lodash/fp/isInteger.js | 5 + .../node_modules/lodash/fp/isLength.js | 5 + .../node_modules/lodash/fp/isMap.js | 5 + .../node_modules/lodash/fp/isMatch.js | 5 + .../node_modules/lodash/fp/isMatchWith.js | 5 + .../node_modules/lodash/fp/isNaN.js | 5 + .../node_modules/lodash/fp/isNative.js | 5 + .../node_modules/lodash/fp/isNil.js | 5 + .../node_modules/lodash/fp/isNull.js | 5 + .../node_modules/lodash/fp/isNumber.js | 5 + .../node_modules/lodash/fp/isObject.js | 5 + .../node_modules/lodash/fp/isObjectLike.js | 5 + .../node_modules/lodash/fp/isPlainObject.js | 5 + .../node_modules/lodash/fp/isRegExp.js | 5 + .../node_modules/lodash/fp/isSafeInteger.js | 5 + .../node_modules/lodash/fp/isSet.js | 5 + .../node_modules/lodash/fp/isString.js | 5 + .../node_modules/lodash/fp/isSymbol.js | 5 + .../node_modules/lodash/fp/isTypedArray.js | 5 + .../node_modules/lodash/fp/isUndefined.js | 5 + .../node_modules/lodash/fp/isWeakMap.js | 5 + .../node_modules/lodash/fp/isWeakSet.js | 5 + .../node_modules/lodash/fp/iteratee.js | 5 + .../node_modules/lodash/fp/join.js | 5 + .../node_modules/lodash/fp/juxt.js | 1 + .../node_modules/lodash/fp/kebabCase.js | 5 + .../node_modules/lodash/fp/keyBy.js | 5 + .../node_modules/lodash/fp/keys.js | 5 + .../node_modules/lodash/fp/keysIn.js | 5 + .../node_modules/lodash/fp/lang.js | 2 + .../node_modules/lodash/fp/last.js | 5 + .../node_modules/lodash/fp/lastIndexOf.js | 5 + .../node_modules/lodash/fp/lastIndexOfFrom.js | 5 + .../node_modules/lodash/fp/lowerCase.js | 5 + .../node_modules/lodash/fp/lowerFirst.js | 5 + .../node_modules/lodash/fp/lt.js | 5 + .../node_modules/lodash/fp/lte.js | 5 + .../node_modules/lodash/fp/map.js | 5 + .../node_modules/lodash/fp/mapKeys.js | 5 + .../node_modules/lodash/fp/mapValues.js | 5 + .../node_modules/lodash/fp/matches.js | 1 + .../node_modules/lodash/fp/matchesProperty.js | 5 + .../node_modules/lodash/fp/math.js | 2 + .../node_modules/lodash/fp/max.js | 5 + .../node_modules/lodash/fp/maxBy.js | 5 + .../node_modules/lodash/fp/mean.js | 5 + .../node_modules/lodash/fp/meanBy.js | 5 + .../node_modules/lodash/fp/memoize.js | 5 + .../node_modules/lodash/fp/merge.js | 5 + .../node_modules/lodash/fp/mergeAll.js | 5 + .../node_modules/lodash/fp/mergeAllWith.js | 5 + .../node_modules/lodash/fp/mergeWith.js | 5 + .../node_modules/lodash/fp/method.js | 5 + .../node_modules/lodash/fp/methodOf.js | 5 + .../node_modules/lodash/fp/min.js | 5 + .../node_modules/lodash/fp/minBy.js | 5 + .../node_modules/lodash/fp/mixin.js | 5 + .../node_modules/lodash/fp/multiply.js | 5 + .../node_modules/lodash/fp/nAry.js | 1 + .../node_modules/lodash/fp/negate.js | 5 + .../node_modules/lodash/fp/next.js | 5 + .../node_modules/lodash/fp/noop.js | 5 + .../node_modules/lodash/fp/now.js | 5 + .../node_modules/lodash/fp/nth.js | 5 + .../node_modules/lodash/fp/nthArg.js | 5 + .../node_modules/lodash/fp/number.js | 2 + .../node_modules/lodash/fp/object.js | 2 + .../node_modules/lodash/fp/omit.js | 5 + .../node_modules/lodash/fp/omitAll.js | 1 + .../node_modules/lodash/fp/omitBy.js | 5 + .../node_modules/lodash/fp/once.js | 5 + .../node_modules/lodash/fp/orderBy.js | 5 + .../node_modules/lodash/fp/over.js | 5 + .../node_modules/lodash/fp/overArgs.js | 5 + .../node_modules/lodash/fp/overEvery.js | 5 + .../node_modules/lodash/fp/overSome.js | 5 + .../node_modules/lodash/fp/pad.js | 5 + .../node_modules/lodash/fp/padChars.js | 5 + .../node_modules/lodash/fp/padCharsEnd.js | 5 + .../node_modules/lodash/fp/padCharsStart.js | 5 + .../node_modules/lodash/fp/padEnd.js | 5 + .../node_modules/lodash/fp/padStart.js | 5 + .../node_modules/lodash/fp/parseInt.js | 5 + .../node_modules/lodash/fp/partial.js | 5 + .../node_modules/lodash/fp/partialRight.js | 5 + .../node_modules/lodash/fp/partition.js | 5 + .../node_modules/lodash/fp/path.js | 1 + .../node_modules/lodash/fp/pathEq.js | 1 + .../node_modules/lodash/fp/pathOr.js | 1 + .../node_modules/lodash/fp/paths.js | 1 + .../node_modules/lodash/fp/pick.js | 5 + .../node_modules/lodash/fp/pickAll.js | 1 + .../node_modules/lodash/fp/pickBy.js | 5 + .../node_modules/lodash/fp/pipe.js | 1 + .../node_modules/lodash/fp/placeholder.js | 6 + .../node_modules/lodash/fp/plant.js | 5 + .../node_modules/lodash/fp/pluck.js | 1 + .../node_modules/lodash/fp/prop.js | 1 + .../node_modules/lodash/fp/propEq.js | 1 + .../node_modules/lodash/fp/propOr.js | 1 + .../node_modules/lodash/fp/property.js | 1 + .../node_modules/lodash/fp/propertyOf.js | 5 + .../node_modules/lodash/fp/props.js | 1 + .../node_modules/lodash/fp/pull.js | 5 + .../node_modules/lodash/fp/pullAll.js | 5 + .../node_modules/lodash/fp/pullAllBy.js | 5 + .../node_modules/lodash/fp/pullAllWith.js | 5 + .../node_modules/lodash/fp/pullAt.js | 5 + .../node_modules/lodash/fp/random.js | 5 + .../node_modules/lodash/fp/range.js | 5 + .../node_modules/lodash/fp/rangeRight.js | 5 + .../node_modules/lodash/fp/rangeStep.js | 5 + .../node_modules/lodash/fp/rangeStepRight.js | 5 + .../node_modules/lodash/fp/rearg.js | 5 + .../node_modules/lodash/fp/reduce.js | 5 + .../node_modules/lodash/fp/reduceRight.js | 5 + .../node_modules/lodash/fp/reject.js | 5 + .../node_modules/lodash/fp/remove.js | 5 + .../node_modules/lodash/fp/repeat.js | 5 + .../node_modules/lodash/fp/replace.js | 5 + .../node_modules/lodash/fp/rest.js | 5 + .../node_modules/lodash/fp/restFrom.js | 5 + .../node_modules/lodash/fp/result.js | 5 + .../node_modules/lodash/fp/reverse.js | 5 + .../node_modules/lodash/fp/round.js | 5 + .../node_modules/lodash/fp/sample.js | 5 + .../node_modules/lodash/fp/sampleSize.js | 5 + .../node_modules/lodash/fp/seq.js | 2 + .../node_modules/lodash/fp/set.js | 5 + .../node_modules/lodash/fp/setWith.js | 5 + .../node_modules/lodash/fp/shuffle.js | 5 + .../node_modules/lodash/fp/size.js | 5 + .../node_modules/lodash/fp/slice.js | 5 + .../node_modules/lodash/fp/snakeCase.js | 5 + .../node_modules/lodash/fp/some.js | 5 + .../node_modules/lodash/fp/sortBy.js | 5 + .../node_modules/lodash/fp/sortedIndex.js | 5 + .../node_modules/lodash/fp/sortedIndexBy.js | 5 + .../node_modules/lodash/fp/sortedIndexOf.js | 5 + .../node_modules/lodash/fp/sortedLastIndex.js | 5 + .../lodash/fp/sortedLastIndexBy.js | 5 + .../lodash/fp/sortedLastIndexOf.js | 5 + .../node_modules/lodash/fp/sortedUniq.js | 5 + .../node_modules/lodash/fp/sortedUniqBy.js | 5 + .../node_modules/lodash/fp/split.js | 5 + .../node_modules/lodash/fp/spread.js | 5 + .../node_modules/lodash/fp/spreadFrom.js | 5 + .../node_modules/lodash/fp/startCase.js | 5 + .../node_modules/lodash/fp/startsWith.js | 5 + .../node_modules/lodash/fp/string.js | 2 + .../node_modules/lodash/fp/stubArray.js | 5 + .../node_modules/lodash/fp/stubFalse.js | 5 + .../node_modules/lodash/fp/stubObject.js | 5 + .../node_modules/lodash/fp/stubString.js | 5 + .../node_modules/lodash/fp/stubTrue.js | 5 + .../node_modules/lodash/fp/subtract.js | 5 + .../node_modules/lodash/fp/sum.js | 5 + .../node_modules/lodash/fp/sumBy.js | 5 + .../lodash/fp/symmetricDifference.js | 1 + .../lodash/fp/symmetricDifferenceBy.js | 1 + .../lodash/fp/symmetricDifferenceWith.js | 1 + .../node_modules/lodash/fp/tail.js | 5 + .../node_modules/lodash/fp/take.js | 5 + .../node_modules/lodash/fp/takeLast.js | 1 + .../node_modules/lodash/fp/takeLastWhile.js | 1 + .../node_modules/lodash/fp/takeRight.js | 5 + .../node_modules/lodash/fp/takeRightWhile.js | 5 + .../node_modules/lodash/fp/takeWhile.js | 5 + .../node_modules/lodash/fp/tap.js | 5 + .../node_modules/lodash/fp/template.js | 5 + .../lodash/fp/templateSettings.js | 5 + .../node_modules/lodash/fp/throttle.js | 5 + .../node_modules/lodash/fp/thru.js | 5 + .../node_modules/lodash/fp/times.js | 5 + .../node_modules/lodash/fp/toArray.js | 5 + .../node_modules/lodash/fp/toFinite.js | 5 + .../node_modules/lodash/fp/toInteger.js | 5 + .../node_modules/lodash/fp/toIterator.js | 5 + .../node_modules/lodash/fp/toJSON.js | 5 + .../node_modules/lodash/fp/toLength.js | 5 + .../node_modules/lodash/fp/toLower.js | 5 + .../node_modules/lodash/fp/toNumber.js | 5 + .../node_modules/lodash/fp/toPairs.js | 5 + .../node_modules/lodash/fp/toPairsIn.js | 5 + .../node_modules/lodash/fp/toPath.js | 5 + .../node_modules/lodash/fp/toPlainObject.js | 5 + .../node_modules/lodash/fp/toSafeInteger.js | 5 + .../node_modules/lodash/fp/toString.js | 5 + .../node_modules/lodash/fp/toUpper.js | 5 + .../node_modules/lodash/fp/transform.js | 5 + .../node_modules/lodash/fp/trim.js | 5 + .../node_modules/lodash/fp/trimChars.js | 5 + .../node_modules/lodash/fp/trimCharsEnd.js | 5 + .../node_modules/lodash/fp/trimCharsStart.js | 5 + .../node_modules/lodash/fp/trimEnd.js | 5 + .../node_modules/lodash/fp/trimStart.js | 5 + .../node_modules/lodash/fp/truncate.js | 5 + .../node_modules/lodash/fp/unapply.js | 1 + .../node_modules/lodash/fp/unary.js | 5 + .../node_modules/lodash/fp/unescape.js | 5 + .../node_modules/lodash/fp/union.js | 5 + .../node_modules/lodash/fp/unionBy.js | 5 + .../node_modules/lodash/fp/unionWith.js | 5 + .../node_modules/lodash/fp/uniq.js | 5 + .../node_modules/lodash/fp/uniqBy.js | 5 + .../node_modules/lodash/fp/uniqWith.js | 5 + .../node_modules/lodash/fp/uniqueId.js | 5 + .../node_modules/lodash/fp/unnest.js | 1 + .../node_modules/lodash/fp/unset.js | 5 + .../node_modules/lodash/fp/unzip.js | 5 + .../node_modules/lodash/fp/unzipWith.js | 5 + .../node_modules/lodash/fp/update.js | 5 + .../node_modules/lodash/fp/updateWith.js | 5 + .../node_modules/lodash/fp/upperCase.js | 5 + .../node_modules/lodash/fp/upperFirst.js | 5 + .../node_modules/lodash/fp/useWith.js | 1 + .../node_modules/lodash/fp/util.js | 2 + .../node_modules/lodash/fp/value.js | 5 + .../node_modules/lodash/fp/valueOf.js | 5 + .../node_modules/lodash/fp/values.js | 5 + .../node_modules/lodash/fp/valuesIn.js | 5 + .../node_modules/lodash/fp/where.js | 1 + .../node_modules/lodash/fp/whereEq.js | 1 + .../node_modules/lodash/fp/without.js | 5 + .../node_modules/lodash/fp/words.js | 5 + .../node_modules/lodash/fp/wrap.js | 5 + .../node_modules/lodash/fp/wrapperAt.js | 5 + .../node_modules/lodash/fp/wrapperChain.js | 5 + .../node_modules/lodash/fp/wrapperLodash.js | 5 + .../node_modules/lodash/fp/wrapperReverse.js | 5 + .../node_modules/lodash/fp/wrapperValue.js | 5 + .../node_modules/lodash/fp/xor.js | 5 + .../node_modules/lodash/fp/xorBy.js | 5 + .../node_modules/lodash/fp/xorWith.js | 5 + .../node_modules/lodash/fp/zip.js | 5 + .../node_modules/lodash/fp/zipAll.js | 5 + .../node_modules/lodash/fp/zipObj.js | 1 + .../node_modules/lodash/fp/zipObject.js | 5 + .../node_modules/lodash/fp/zipObjectDeep.js | 5 + .../node_modules/lodash/fp/zipWith.js | 5 + .../node_modules/lodash/fromPairs.js | 28 + .../node_modules/lodash/function.js | 25 + .../node_modules/lodash/functions.js | 31 + .../node_modules/lodash/functionsIn.js | 31 + .../lodash@4.17.21/node_modules/lodash/get.js | 33 + .../node_modules/lodash/groupBy.js | 41 + .../lodash@4.17.21/node_modules/lodash/gt.js | 29 + .../lodash@4.17.21/node_modules/lodash/gte.js | 30 + .../lodash@4.17.21/node_modules/lodash/has.js | 35 + .../node_modules/lodash/hasIn.js | 34 + .../node_modules/lodash/head.js | 23 + .../node_modules/lodash/identity.js | 21 + .../node_modules/lodash/inRange.js | 55 + .../node_modules/lodash/includes.js | 53 + .../node_modules/lodash/index.js | 1 + .../node_modules/lodash/indexOf.js | 42 + .../node_modules/lodash/initial.js | 22 + .../node_modules/lodash/intersection.js | 30 + .../node_modules/lodash/intersectionBy.js | 45 + .../node_modules/lodash/intersectionWith.js | 41 + .../node_modules/lodash/invert.js | 42 + .../node_modules/lodash/invertBy.js | 56 + .../node_modules/lodash/invoke.js | 24 + .../node_modules/lodash/invokeMap.js | 41 + .../node_modules/lodash/isArguments.js | 36 + .../node_modules/lodash/isArray.js | 26 + .../node_modules/lodash/isArrayBuffer.js | 27 + .../node_modules/lodash/isArrayLike.js | 33 + .../node_modules/lodash/isArrayLikeObject.js | 33 + .../node_modules/lodash/isBoolean.js | 29 + .../node_modules/lodash/isBuffer.js | 38 + .../node_modules/lodash/isDate.js | 27 + .../node_modules/lodash/isElement.js | 25 + .../node_modules/lodash/isEmpty.js | 77 + .../node_modules/lodash/isEqual.js | 35 + .../node_modules/lodash/isEqualWith.js | 41 + .../node_modules/lodash/isError.js | 36 + .../node_modules/lodash/isFinite.js | 36 + .../node_modules/lodash/isFunction.js | 37 + .../node_modules/lodash/isInteger.js | 33 + .../node_modules/lodash/isLength.js | 35 + .../node_modules/lodash/isMap.js | 27 + .../node_modules/lodash/isMatch.js | 36 + .../node_modules/lodash/isMatchWith.js | 41 + .../node_modules/lodash/isNaN.js | 38 + .../node_modules/lodash/isNative.js | 40 + .../node_modules/lodash/isNil.js | 25 + .../node_modules/lodash/isNull.js | 22 + .../node_modules/lodash/isNumber.js | 38 + .../node_modules/lodash/isObject.js | 31 + .../node_modules/lodash/isObjectLike.js | 29 + .../node_modules/lodash/isPlainObject.js | 62 + .../node_modules/lodash/isRegExp.js | 27 + .../node_modules/lodash/isSafeInteger.js | 37 + .../node_modules/lodash/isSet.js | 27 + .../node_modules/lodash/isString.js | 30 + .../node_modules/lodash/isSymbol.js | 29 + .../node_modules/lodash/isTypedArray.js | 27 + .../node_modules/lodash/isUndefined.js | 22 + .../node_modules/lodash/isWeakMap.js | 28 + .../node_modules/lodash/isWeakSet.js | 28 + .../node_modules/lodash/iteratee.js | 53 + .../node_modules/lodash/join.js | 26 + .../node_modules/lodash/kebabCase.js | 28 + .../node_modules/lodash/keyBy.js | 36 + .../node_modules/lodash/keys.js | 37 + .../node_modules/lodash/keysIn.js | 32 + .../node_modules/lodash/lang.js | 58 + .../node_modules/lodash/last.js | 20 + .../node_modules/lodash/lastIndexOf.js | 46 + .../node_modules/lodash/lodash.js | 17209 ++++++++++++++++ .../node_modules/lodash/lodash.min.js | 140 + .../node_modules/lodash/lowerCase.js | 27 + .../node_modules/lodash/lowerFirst.js | 22 + .../lodash@4.17.21/node_modules/lodash/lt.js | 29 + .../lodash@4.17.21/node_modules/lodash/lte.js | 30 + .../lodash@4.17.21/node_modules/lodash/map.js | 53 + .../node_modules/lodash/mapKeys.js | 36 + .../node_modules/lodash/mapValues.js | 43 + .../node_modules/lodash/matches.js | 46 + .../node_modules/lodash/matchesProperty.js | 44 + .../node_modules/lodash/math.js | 17 + .../lodash@4.17.21/node_modules/lodash/max.js | 29 + .../node_modules/lodash/maxBy.js | 34 + .../node_modules/lodash/mean.js | 22 + .../node_modules/lodash/meanBy.js | 31 + .../node_modules/lodash/memoize.js | 73 + .../node_modules/lodash/merge.js | 39 + .../node_modules/lodash/mergeWith.js | 39 + .../node_modules/lodash/method.js | 34 + .../node_modules/lodash/methodOf.js | 33 + .../lodash@4.17.21/node_modules/lodash/min.js | 29 + .../node_modules/lodash/minBy.js | 34 + .../node_modules/lodash/mixin.js | 74 + .../node_modules/lodash/multiply.js | 22 + .../node_modules/lodash/negate.js | 40 + .../node_modules/lodash/next.js | 35 + .../node_modules/lodash/noop.js | 17 + .../lodash@4.17.21/node_modules/lodash/now.js | 23 + .../lodash@4.17.21/node_modules/lodash/nth.js | 29 + .../node_modules/lodash/nthArg.js | 32 + .../node_modules/lodash/number.js | 5 + .../node_modules/lodash/object.js | 49 + .../node_modules/lodash/omit.js | 57 + .../node_modules/lodash/omitBy.js | 29 + .../node_modules/lodash/once.js | 25 + .../node_modules/lodash/orderBy.js | 47 + .../node_modules/lodash/over.js | 24 + .../node_modules/lodash/overArgs.js | 61 + .../node_modules/lodash/overEvery.js | 34 + .../node_modules/lodash/overSome.js | 37 + .../node_modules/lodash/package.json | 17 + .../lodash@4.17.21/node_modules/lodash/pad.js | 49 + .../node_modules/lodash/padEnd.js | 39 + .../node_modules/lodash/padStart.js | 39 + .../node_modules/lodash/parseInt.js | 43 + .../node_modules/lodash/partial.js | 50 + .../node_modules/lodash/partialRight.js | 49 + .../node_modules/lodash/partition.js | 43 + .../node_modules/lodash/pick.js | 25 + .../node_modules/lodash/pickBy.js | 37 + .../node_modules/lodash/plant.js | 48 + .../node_modules/lodash/property.js | 32 + .../node_modules/lodash/propertyOf.js | 30 + .../node_modules/lodash/pull.js | 29 + .../node_modules/lodash/pullAll.js | 29 + .../node_modules/lodash/pullAllBy.js | 33 + .../node_modules/lodash/pullAllWith.js | 32 + .../node_modules/lodash/pullAt.js | 43 + .../node_modules/lodash/random.js | 82 + .../node_modules/lodash/range.js | 46 + .../node_modules/lodash/rangeRight.js | 41 + .../node_modules/lodash/rearg.js | 33 + .../node_modules/lodash/reduce.js | 51 + .../node_modules/lodash/reduceRight.js | 36 + .../node_modules/lodash/reject.js | 46 + .../node_modules/lodash/release.md | 48 + .../node_modules/lodash/remove.js | 53 + .../node_modules/lodash/repeat.js | 37 + .../node_modules/lodash/replace.js | 29 + .../node_modules/lodash/rest.js | 40 + .../node_modules/lodash/result.js | 56 + .../node_modules/lodash/reverse.js | 34 + .../node_modules/lodash/round.js | 26 + .../node_modules/lodash/sample.js | 24 + .../node_modules/lodash/sampleSize.js | 37 + .../lodash@4.17.21/node_modules/lodash/seq.js | 16 + .../lodash@4.17.21/node_modules/lodash/set.js | 35 + .../node_modules/lodash/setWith.js | 32 + .../node_modules/lodash/shuffle.js | 25 + .../node_modules/lodash/size.js | 46 + .../node_modules/lodash/slice.js | 37 + .../node_modules/lodash/snakeCase.js | 28 + .../node_modules/lodash/some.js | 51 + .../node_modules/lodash/sortBy.js | 48 + .../node_modules/lodash/sortedIndex.js | 24 + .../node_modules/lodash/sortedIndexBy.js | 33 + .../node_modules/lodash/sortedIndexOf.js | 31 + .../node_modules/lodash/sortedLastIndex.js | 25 + .../node_modules/lodash/sortedLastIndexBy.js | 33 + .../node_modules/lodash/sortedLastIndexOf.js | 31 + .../node_modules/lodash/sortedUniq.js | 24 + .../node_modules/lodash/sortedUniqBy.js | 26 + .../node_modules/lodash/split.js | 52 + .../node_modules/lodash/spread.js | 63 + .../node_modules/lodash/startCase.js | 29 + .../node_modules/lodash/startsWith.js | 39 + .../node_modules/lodash/string.js | 33 + .../node_modules/lodash/stubArray.js | 23 + .../node_modules/lodash/stubFalse.js | 18 + .../node_modules/lodash/stubObject.js | 23 + .../node_modules/lodash/stubString.js | 18 + .../node_modules/lodash/stubTrue.js | 18 + .../node_modules/lodash/subtract.js | 22 + .../lodash@4.17.21/node_modules/lodash/sum.js | 24 + .../node_modules/lodash/sumBy.js | 33 + .../node_modules/lodash/tail.js | 22 + .../node_modules/lodash/take.js | 37 + .../node_modules/lodash/takeRight.js | 39 + .../node_modules/lodash/takeRightWhile.js | 45 + .../node_modules/lodash/takeWhile.js | 45 + .../lodash@4.17.21/node_modules/lodash/tap.js | 29 + .../node_modules/lodash/template.js | 272 + .../node_modules/lodash/templateSettings.js | 67 + .../node_modules/lodash/throttle.js | 69 + .../node_modules/lodash/thru.js | 28 + .../node_modules/lodash/times.js | 51 + .../node_modules/lodash/toArray.js | 58 + .../node_modules/lodash/toFinite.js | 42 + .../node_modules/lodash/toInteger.js | 36 + .../node_modules/lodash/toIterator.js | 23 + .../node_modules/lodash/toJSON.js | 1 + .../node_modules/lodash/toLength.js | 38 + .../node_modules/lodash/toLower.js | 28 + .../node_modules/lodash/toNumber.js | 64 + .../node_modules/lodash/toPairs.js | 30 + .../node_modules/lodash/toPairsIn.js | 30 + .../node_modules/lodash/toPath.js | 33 + .../node_modules/lodash/toPlainObject.js | 32 + .../node_modules/lodash/toSafeInteger.js | 37 + .../node_modules/lodash/toString.js | 28 + .../node_modules/lodash/toUpper.js | 28 + .../node_modules/lodash/transform.js | 65 + .../node_modules/lodash/trim.js | 47 + .../node_modules/lodash/trimEnd.js | 41 + .../node_modules/lodash/trimStart.js | 43 + .../node_modules/lodash/truncate.js | 111 + .../node_modules/lodash/unary.js | 22 + .../node_modules/lodash/unescape.js | 34 + .../node_modules/lodash/union.js | 26 + .../node_modules/lodash/unionBy.js | 39 + .../node_modules/lodash/unionWith.js | 34 + .../node_modules/lodash/uniq.js | 25 + .../node_modules/lodash/uniqBy.js | 31 + .../node_modules/lodash/uniqWith.js | 28 + .../node_modules/lodash/uniqueId.js | 28 + .../node_modules/lodash/unset.js | 34 + .../node_modules/lodash/unzip.js | 45 + .../node_modules/lodash/unzipWith.js | 39 + .../node_modules/lodash/update.js | 35 + .../node_modules/lodash/updateWith.js | 33 + .../node_modules/lodash/upperCase.js | 27 + .../node_modules/lodash/upperFirst.js | 22 + .../node_modules/lodash/util.js | 34 + .../node_modules/lodash/value.js | 1 + .../node_modules/lodash/valueOf.js | 1 + .../node_modules/lodash/values.js | 34 + .../node_modules/lodash/valuesIn.js | 32 + .../node_modules/lodash/without.js | 31 + .../node_modules/lodash/words.js | 35 + .../node_modules/lodash/wrap.js | 30 + .../node_modules/lodash/wrapperAt.js | 48 + .../node_modules/lodash/wrapperChain.js | 34 + .../node_modules/lodash/wrapperLodash.js | 147 + .../node_modules/lodash/wrapperReverse.js | 44 + .../node_modules/lodash/wrapperValue.js | 21 + .../lodash@4.17.21/node_modules/lodash/xor.js | 28 + .../node_modules/lodash/xorBy.js | 39 + .../node_modules/lodash/xorWith.js | 34 + .../lodash@4.17.21/node_modules/lodash/zip.js | 22 + .../node_modules/lodash/zipObject.js | 24 + .../node_modules/lodash/zipObjectDeep.js | 23 + .../node_modules/lodash/zipWith.js | 32 + .../magic-bytes.js/.gitattributes | 1 + .../.github/workflows/build-and-test.yml | 39 + .../.github/workflows/static-webapp.yml | 48 + .../magic-bytes.js/.prettierignore | 1 + .../node_modules/magic-bytes.js/LICENSE | 21 + .../node_modules/magic-bytes.js/README.md | 109 + .../magic-bytes.js/commitlint.config.js | 1 + .../magic-bytes.js/dist/index.d.ts | 7 + .../magic-bytes.js/dist/index.d.ts.map | 1 + .../node_modules/magic-bytes.js/dist/index.js | 60 + .../magic-bytes.js/dist/index.spec.d.ts | 2 + .../magic-bytes.js/dist/index.spec.d.ts.map | 1 + .../dist/model/pattern-tree.d.ts | 4 + .../dist/model/pattern-tree.d.ts.map | 1 + .../magic-bytes.js/dist/model/pattern-tree.js | 1155 ++ .../magic-bytes.js/dist/model/toHex.d.ts | 3 + .../magic-bytes.js/dist/model/toHex.d.ts.map | 1 + .../magic-bytes.js/dist/model/toHex.js | 8 + .../magic-bytes.js/dist/model/tree.d.ts | 30 + .../magic-bytes.js/dist/model/tree.d.ts.map | 1 + .../magic-bytes.js/dist/model/tree.js | 70 + .../magic-bytes.js/dist/model/tree.spec.d.ts | 2 + .../dist/model/tree.spec.d.ts.map | 1 + .../magic-bytes.js/jest.config.js | 5 + .../node_modules/magic-bytes.js/package.json | 72 + .../node_modules/magic-bytes.js/tsconfig.json | 78 + .../node_modules/memoirist/LICENSE | 8 + .../node_modules/memoirist/README.md | 4 + .../memoirist/dist/bun/index.d.ts | 43 + .../node_modules/memoirist/dist/bun/index.js | 4 + .../memoirist/dist/bun/index.js.map | 10 + .../memoirist/dist/cjs/index.d.ts | 43 + .../node_modules/memoirist/dist/cjs/index.js | 298 + .../node_modules/memoirist/dist/index.d.ts | 43 + .../node_modules/memoirist/dist/index.mjs | 273 + .../node_modules/memoirist/package.json | 56 + .../node_modules/memoirist/src/index.ts | 395 + .../.pnpm/node_modules/@discordjs/builders | 1 + .../.pnpm/node_modules/@discordjs/collection | 1 + .../.pnpm/node_modules/@discordjs/formatters | 1 + .../.pnpm/node_modules/@discordjs/rest | 1 + .../.pnpm/node_modules/@discordjs/util | 1 + node_modules/.pnpm/node_modules/@discordjs/ws | 1 + .../.pnpm/node_modules/@sapphire/async-queue | 1 + .../.pnpm/node_modules/@sapphire/shapeshift | 1 + .../.pnpm/node_modules/@sapphire/snowflake | 1 + .../.pnpm/node_modules/@sinclair/typebox | 1 + node_modules/.pnpm/node_modules/@types/node | 1 + node_modules/.pnpm/node_modules/@types/ws | 1 + .../@vladfrangu/async_event_emitter | 1 + node_modules/.pnpm/node_modules/cookie | 1 + .../.pnpm/node_modules/discord-api-types | 1 + .../.pnpm/node_modules/fast-deep-equal | 1 + node_modules/.pnpm/node_modules/lodash | 1 + .../.pnpm/node_modules/lodash.snakecase | 1 + .../.pnpm/node_modules/magic-bytes.js | 1 + node_modules/.pnpm/node_modules/memoirist | 1 + node_modules/.pnpm/node_modules/ts-mixer | 1 + node_modules/.pnpm/node_modules/tslib | 1 + node_modules/.pnpm/node_modules/undici | 1 + node_modules/.pnpm/node_modules/undici-types | 1 + node_modules/.pnpm/node_modules/ws | 1 + .../node_modules/ts-mixer/CHANGELOG.md | 120 + .../node_modules/ts-mixer/LICENSE | 21 + .../node_modules/ts-mixer/README.md | 270 + .../ts-mixer/dist/cjs/decorator.js | 109 + .../node_modules/ts-mixer/dist/cjs/index.js | 12 + .../ts-mixer/dist/cjs/mixin-tracking.js | 42 + .../node_modules/ts-mixer/dist/cjs/mixins.js | 82 + .../node_modules/ts-mixer/dist/cjs/proxy.js | 82 + .../ts-mixer/dist/cjs/settings.js | 9 + .../node_modules/ts-mixer/dist/cjs/types.js | 2 + .../node_modules/ts-mixer/dist/cjs/util.js | 85 + .../ts-mixer/dist/esm/decorator.d.ts | 18 + .../node_modules/ts-mixer/dist/esm/index.d.ts | 4 + .../node_modules/ts-mixer/dist/esm/index.js | 366 + .../ts-mixer/dist/esm/index.min.js | 1 + .../ts-mixer/dist/esm/mixin-tracking.d.ts | 4 + .../ts-mixer/dist/esm/mixins.d.ts | 16 + .../node_modules/ts-mixer/dist/esm/proxy.d.ts | 16 + .../ts-mixer/dist/esm/settings.d.ts | 7 + .../node_modules/ts-mixer/dist/esm/types.d.ts | 13 + .../node_modules/ts-mixer/dist/esm/util.d.ts | 27 + .../ts-mixer/dist/types/decorator.d.ts | 18 + .../ts-mixer/dist/types/index.d.ts | 4 + .../ts-mixer/dist/types/mixin-tracking.d.ts | 4 + .../ts-mixer/dist/types/mixins.d.ts | 16 + .../ts-mixer/dist/types/proxy.d.ts | 16 + .../ts-mixer/dist/types/settings.d.ts | 7 + .../ts-mixer/dist/types/types.d.ts | 13 + .../ts-mixer/dist/types/util.d.ts | 27 + .../node_modules/ts-mixer/package.json | 63 + .../node_modules/tslib/CopyrightNotice.txt | 15 + .../node_modules/tslib/LICENSE.txt | 12 + .../tslib@2.8.1/node_modules/tslib/README.md | 164 + .../node_modules/tslib/SECURITY.md | 41 + .../node_modules/tslib/modules/index.d.ts | 38 + .../node_modules/tslib/modules/index.js | 70 + .../node_modules/tslib/modules/package.json | 3 + .../node_modules/tslib/package.json | 47 + .../tslib@2.8.1/node_modules/tslib/tslib.d.ts | 460 + .../node_modules/tslib/tslib.es6.html | 1 + .../node_modules/tslib/tslib.es6.js | 402 + .../node_modules/tslib/tslib.es6.mjs | 401 + .../tslib@2.8.1/node_modules/tslib/tslib.html | 1 + .../tslib@2.8.1/node_modules/tslib/tslib.js | 484 + .../node_modules/undici-types/LICENSE | 21 + .../node_modules/undici-types/README.md | 6 + .../node_modules/undici-types/agent.d.ts | 31 + .../node_modules/undici-types/api.d.ts | 43 + .../undici-types/balanced-pool.d.ts | 29 + .../node_modules/undici-types/cache.d.ts | 36 + .../node_modules/undici-types/client.d.ts | 108 + .../node_modules/undici-types/connector.d.ts | 34 + .../undici-types/content-type.d.ts | 21 + .../node_modules/undici-types/cookies.d.ts | 28 + .../undici-types/diagnostics-channel.d.ts | 66 + .../node_modules/undici-types/dispatcher.d.ts | 256 + .../undici-types/env-http-proxy-agent.d.ts | 21 + .../node_modules/undici-types/errors.d.ts | 149 + .../undici-types/eventsource.d.ts | 61 + .../node_modules/undici-types/fetch.d.ts | 209 + .../node_modules/undici-types/file.d.ts | 39 + .../node_modules/undici-types/filereader.d.ts | 54 + .../node_modules/undici-types/formdata.d.ts | 108 + .../undici-types/global-dispatcher.d.ts | 9 + .../undici-types/global-origin.d.ts | 7 + .../node_modules/undici-types/handlers.d.ts | 15 + .../node_modules/undici-types/header.d.ts | 4 + .../node_modules/undici-types/index.d.ts | 71 + .../undici-types/interceptors.d.ts | 17 + .../node_modules/undici-types/mock-agent.d.ts | 50 + .../undici-types/mock-client.d.ts | 25 + .../undici-types/mock-errors.d.ts | 12 + .../undici-types/mock-interceptor.d.ts | 93 + .../node_modules/undici-types/mock-pool.d.ts | 25 + .../node_modules/undici-types/package.json | 55 + .../node_modules/undici-types/patch.d.ts | 33 + .../node_modules/undici-types/pool-stats.d.ts | 19 + .../node_modules/undici-types/pool.d.ts | 39 + .../undici-types/proxy-agent.d.ts | 28 + .../node_modules/undici-types/readable.d.ts | 65 + .../undici-types/retry-agent.d.ts | 8 + .../undici-types/retry-handler.d.ts | 116 + .../node_modules/undici-types/util.d.ts | 18 + .../node_modules/undici-types/webidl.d.ts | 228 + .../node_modules/undici-types/websocket.d.ts | 150 + .../undici@6.21.1/node_modules/undici/LICENSE | 21 + .../node_modules/undici/README.md | 467 + .../undici/docs/docs/api/Agent.md | 80 + .../undici/docs/docs/api/BalancedPool.md | 99 + .../undici/docs/docs/api/CacheStorage.md | 30 + .../undici/docs/docs/api/Client.md | 274 + .../undici/docs/docs/api/Connector.md | 115 + .../undici/docs/docs/api/ContentType.md | 57 + .../undici/docs/docs/api/Cookies.md | 101 + .../undici/docs/docs/api/Debug.md | 62 + .../docs/docs/api/DiagnosticsChannel.md | 204 + .../docs/docs/api/DispatchInterceptor.md | 60 + .../undici/docs/docs/api/Dispatcher.md | 1347 ++ .../undici/docs/docs/api/EnvHttpProxyAgent.md | 162 + .../undici/docs/docs/api/Errors.md | 48 + .../undici/docs/docs/api/EventSource.md | 45 + .../undici/docs/docs/api/Fetch.md | 52 + .../undici/docs/docs/api/MockAgent.md | 540 + .../undici/docs/docs/api/MockClient.md | 77 + .../undici/docs/docs/api/MockErrors.md | 12 + .../undici/docs/docs/api/MockPool.md | 547 + .../node_modules/undici/docs/docs/api/Pool.md | 84 + .../undici/docs/docs/api/PoolStats.md | 35 + .../undici/docs/docs/api/ProxyAgent.md | 130 + .../undici/docs/docs/api/RedirectHandler.md | 96 + .../undici/docs/docs/api/RetryAgent.md | 45 + .../undici/docs/docs/api/RetryHandler.md | 117 + .../node_modules/undici/docs/docs/api/Util.md | 25 + .../undici/docs/docs/api/WebSocket.md | 43 + .../undici/docs/docs/api/api-lifecycle.md | 91 + .../docs/best-practices/client-certificate.md | 64 + .../docs/best-practices/mocking-request.md | 136 + .../undici/docs/docs/best-practices/proxy.md | 127 + .../docs/docs/best-practices/writing-tests.md | 20 + .../node_modules/undici/index-fetch.js | 32 + .../node_modules/undici/index.d.ts | 3 + .../node_modules/undici/index.js | 169 + .../undici/lib/api/abort-signal.js | 57 + .../undici/lib/api/api-connect.js | 108 + .../undici/lib/api/api-pipeline.js | 251 + .../undici/lib/api/api-request.js | 214 + .../node_modules/undici/lib/api/api-stream.js | 220 + .../undici/lib/api/api-upgrade.js | 108 + .../node_modules/undici/lib/api/index.js | 7 + .../node_modules/undici/lib/api/readable.js | 385 + .../node_modules/undici/lib/api/util.js | 93 + .../node_modules/undici/lib/core/connect.js | 240 + .../node_modules/undici/lib/core/constants.js | 118 + .../undici/lib/core/diagnostics.js | 202 + .../node_modules/undici/lib/core/errors.js | 244 + .../node_modules/undici/lib/core/request.js | 395 + .../node_modules/undici/lib/core/symbols.js | 67 + .../node_modules/undici/lib/core/tree.js | 152 + .../node_modules/undici/lib/core/util.js | 719 + .../undici/lib/dispatcher/agent.js | 129 + .../undici/lib/dispatcher/balanced-pool.js | 209 + .../undici/lib/dispatcher/client-h1.js | 1370 ++ .../undici/lib/dispatcher/client-h2.js | 744 + .../undici/lib/dispatcher/client.js | 622 + .../undici/lib/dispatcher/dispatcher-base.js | 190 + .../undici/lib/dispatcher/dispatcher.js | 65 + .../lib/dispatcher/env-http-proxy-agent.js | 160 + .../undici/lib/dispatcher/fixed-queue.js | 117 + .../undici/lib/dispatcher/pool-base.js | 194 + .../undici/lib/dispatcher/pool-stats.js | 34 + .../undici/lib/dispatcher/pool.js | 93 + .../undici/lib/dispatcher/proxy-agent.js | 192 + .../undici/lib/dispatcher/retry-agent.js | 35 + .../node_modules/undici/lib/global.js | 32 + .../undici/lib/handler/decorator-handler.js | 44 + .../undici/lib/handler/redirect-handler.js | 232 + .../undici/lib/handler/retry-handler.js | 374 + .../undici/lib/interceptor/dns.js | 375 + .../undici/lib/interceptor/dump.js | 123 + .../lib/interceptor/redirect-interceptor.js | 21 + .../undici/lib/interceptor/redirect.js | 24 + .../undici/lib/interceptor/response-error.js | 86 + .../undici/lib/interceptor/retry.js | 19 + .../node_modules/undici/lib/llhttp/.gitkeep | 0 .../undici/lib/llhttp/constants.js | 278 + .../undici/lib/llhttp/llhttp-wasm.js | 5 + .../undici/lib/llhttp/llhttp_simd-wasm.js | 5 + .../node_modules/undici/lib/llhttp/utils.js | 15 + .../undici/lib/mock/mock-agent.js | 160 + .../undici/lib/mock/mock-client.js | 59 + .../undici/lib/mock/mock-errors.js | 17 + .../undici/lib/mock/mock-interceptor.js | 207 + .../node_modules/undici/lib/mock/mock-pool.js | 59 + .../undici/lib/mock/mock-symbols.js | 23 + .../undici/lib/mock/mock-utils.js | 367 + .../mock/pending-interceptors-formatter.js | 43 + .../undici/lib/mock/pluralizer.js | 29 + .../node_modules/undici/lib/util/timers.js | 423 + .../undici/lib/web/cache/cache.js | 859 + .../undici/lib/web/cache/cachestorage.js | 152 + .../undici/lib/web/cache/symbols.js | 5 + .../node_modules/undici/lib/web/cache/util.js | 45 + .../undici/lib/web/cookies/constants.js | 12 + .../undici/lib/web/cookies/index.js | 184 + .../undici/lib/web/cookies/parse.js | 317 + .../undici/lib/web/cookies/util.js | 282 + .../lib/web/eventsource/eventsource-stream.js | 398 + .../undici/lib/web/eventsource/eventsource.js | 480 + .../undici/lib/web/eventsource/util.js | 37 + .../node_modules/undici/lib/web/fetch/LICENSE | 21 + .../node_modules/undici/lib/web/fetch/body.js | 530 + .../undici/lib/web/fetch/constants.js | 124 + .../undici/lib/web/fetch/data-url.js | 744 + .../lib/web/fetch/dispatcher-weakref.js | 46 + .../node_modules/undici/lib/web/fetch/file.js | 126 + .../undici/lib/web/fetch/formdata-parser.js | 474 + .../undici/lib/web/fetch/formdata.js | 252 + .../undici/lib/web/fetch/global.js | 40 + .../undici/lib/web/fetch/headers.js | 687 + .../undici/lib/web/fetch/index.js | 2266 ++ .../undici/lib/web/fetch/request.js | 1037 + .../undici/lib/web/fetch/response.js | 605 + .../undici/lib/web/fetch/symbols.js | 9 + .../node_modules/undici/lib/web/fetch/util.js | 1632 ++ .../undici/lib/web/fetch/webidl.js | 695 + .../undici/lib/web/fileapi/encoding.js | 290 + .../undici/lib/web/fileapi/filereader.js | 344 + .../undici/lib/web/fileapi/progressevent.js | 78 + .../undici/lib/web/fileapi/symbols.js | 10 + .../undici/lib/web/fileapi/util.js | 391 + .../undici/lib/web/websocket/connection.js | 371 + .../undici/lib/web/websocket/constants.js | 66 + .../undici/lib/web/websocket/events.js | 329 + .../undici/lib/web/websocket/frame.js | 96 + .../lib/web/websocket/permessage-deflate.js | 70 + .../undici/lib/web/websocket/receiver.js | 424 + .../undici/lib/web/websocket/sender.js | 104 + .../undici/lib/web/websocket/symbols.js | 12 + .../undici/lib/web/websocket/util.js | 314 + .../undici/lib/web/websocket/websocket.js | 588 + .../node_modules/undici/package.json | 160 + .../undici/scripts/strip-comments.js | 8 + .../node_modules/undici/types/README.md | 6 + .../node_modules/undici/types/agent.d.ts | 31 + .../node_modules/undici/types/api.d.ts | 43 + .../undici/types/balanced-pool.d.ts | 29 + .../node_modules/undici/types/cache.d.ts | 36 + .../node_modules/undici/types/client.d.ts | 108 + .../node_modules/undici/types/connector.d.ts | 34 + .../undici/types/content-type.d.ts | 21 + .../node_modules/undici/types/cookies.d.ts | 28 + .../undici/types/diagnostics-channel.d.ts | 66 + .../node_modules/undici/types/dispatcher.d.ts | 256 + .../undici/types/env-http-proxy-agent.d.ts | 21 + .../node_modules/undici/types/errors.d.ts | 149 + .../undici/types/eventsource.d.ts | 61 + .../node_modules/undici/types/fetch.d.ts | 209 + .../node_modules/undici/types/file.d.ts | 39 + .../node_modules/undici/types/filereader.d.ts | 54 + .../node_modules/undici/types/formdata.d.ts | 108 + .../undici/types/global-dispatcher.d.ts | 9 + .../undici/types/global-origin.d.ts | 7 + .../node_modules/undici/types/handlers.d.ts | 15 + .../node_modules/undici/types/header.d.ts | 4 + .../node_modules/undici/types/index.d.ts | 71 + .../undici/types/interceptors.d.ts | 31 + .../node_modules/undici/types/mock-agent.d.ts | 50 + .../undici/types/mock-client.d.ts | 25 + .../undici/types/mock-errors.d.ts | 12 + .../undici/types/mock-interceptor.d.ts | 93 + .../node_modules/undici/types/mock-pool.d.ts | 25 + .../node_modules/undici/types/patch.d.ts | 33 + .../node_modules/undici/types/pool-stats.d.ts | 19 + .../node_modules/undici/types/pool.d.ts | 39 + .../undici/types/proxy-agent.d.ts | 28 + .../node_modules/undici/types/readable.d.ts | 65 + .../undici/types/retry-agent.d.ts | 8 + .../undici/types/retry-handler.d.ts | 116 + .../node_modules/undici/types/util.d.ts | 18 + .../node_modules/undici/types/webidl.d.ts | 228 + .../node_modules/undici/types/websocket.d.ts | 150 + .../.pnpm/ws@8.18.1/node_modules/ws/LICENSE | 20 + .../.pnpm/ws@8.18.1/node_modules/ws/README.md | 548 + .../ws@8.18.1/node_modules/ws/browser.js | 8 + .../.pnpm/ws@8.18.1/node_modules/ws/index.js | 13 + .../node_modules/ws/lib/buffer-util.js | 131 + .../node_modules/ws/lib/constants.js | 18 + .../node_modules/ws/lib/event-target.js | 292 + .../node_modules/ws/lib/extension.js | 203 + .../ws@8.18.1/node_modules/ws/lib/limiter.js | 55 + .../node_modules/ws/lib/permessage-deflate.js | 514 + .../ws@8.18.1/node_modules/ws/lib/receiver.js | 706 + .../ws@8.18.1/node_modules/ws/lib/sender.js | 602 + .../ws@8.18.1/node_modules/ws/lib/stream.js | 161 + .../node_modules/ws/lib/subprotocol.js | 62 + .../node_modules/ws/lib/validation.js | 152 + .../node_modules/ws/lib/websocket-server.js | 540 + .../node_modules/ws/lib/websocket.js | 1388 ++ .../ws@8.18.1/node_modules/ws/package.json | 69 + .../ws@8.18.1/node_modules/ws/wrapper.mjs | 8 + node_modules/bun-types | 1 + node_modules/discord.js | 1 + node_modules/elysia | 1 + package.json | 16 + pnpm-lock.yaml | 264 + src/boredBot/commands.ts | 17 + src/boredBot/index.ts | 123 + src/diceRoller/index.ts | 53 + src/diceRoller/types.ts | 18 + src/diceRoller/utils/handleRollCommand.ts | 71 + src/diceRoller/utils/parseDiceUserInput.ts | 69 + src/discordBot/index.ts | 65 + src/discordBot/types.ts | 8 + src/index.ts | 10 + tsconfig.json | 103 + wps/compose.yml | 43 + wps/todo.md | 5 + 4576 files changed, 440347 insertions(+) create mode 100644 .devcontainer/devcontainer.json create mode 100644 Dockerfile create mode 100644 Makefile create mode 100644 node_modules/.modules.yaml create mode 100644 node_modules/.pnpm-workspace-state.json create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/README.md create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/package.json create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/formatters create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/util create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@sapphire/shapeshift create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/discord-api-types create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/fast-deep-equal create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/ts-mixer create mode 120000 node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/tslib create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/CHANGELOG.md create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/README.md create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/package.json create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/README.md create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/package.json create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/README.md create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/package.json create mode 120000 node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/discord-api-types create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/collection create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/README.md create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.d.mts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.d.ts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.js create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.js.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.mjs create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/strategies/undiciRequest.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.d.mts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.d.ts create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.js create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.js.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.mjs create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/dist/web.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/rest/package.json create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@discordjs/util create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@sapphire/async-queue create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@sapphire/snowflake create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/@vladfrangu/async_event_emitter create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/discord-api-types create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/magic-bytes.js create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/tslib create mode 120000 node_modules/.pnpm/@discordjs+rest@2.4.3/node_modules/undici create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/README.md create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+util@1.1.1/node_modules/@discordjs/util/package.json create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/collection create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/rest create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/util create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/LICENSE create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/README.md create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.d.mts create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.d.ts create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.js create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.js.map create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.mjs create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/defaultWorker.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.d.mts create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.d.ts create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.js create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.js.map create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.mjs create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@discordjs/ws/package.json create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@sapphire/async-queue create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@types/ws create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/@vladfrangu/async_event_emitter create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/discord-api-types create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/tslib create mode 120000 node_modules/.pnpm/@discordjs+ws@1.2.1/node_modules/ws create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/CHANGELOG.md create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/README.md create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/cjs/index.cjs create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/cjs/index.cjs.map create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/cjs/index.d.cts create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/esm/index.d.mts create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/esm/index.mjs create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/esm/index.mjs.map create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/iife/index.global.js create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/dist/iife/index.global.js.map create mode 100644 node_modules/.pnpm/@sapphire+async-queue@1.5.5/node_modules/@sapphire/async-queue/package.json create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/CHANGELOG.md create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/LICENSE.md create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/README.md create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/UPGRADING-v3-v4.md create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/cjs/index.cjs create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/cjs/index.cjs.map create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/cjs/index.d.cts create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/esm/index.d.mts create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/esm/index.mjs create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/esm/index.mjs.map create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/iife/index.global.js create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/dist/iife/index.global.js.map create mode 100644 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift/package.json create mode 120000 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/fast-deep-equal create mode 120000 node_modules/.pnpm/@sapphire+shapeshift@4.0.0/node_modules/lodash create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/CHANGELOG.md create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/README.md create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/cjs/index.cjs create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/cjs/index.cjs.map create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/cjs/index.d.cts create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/esm/index.d.mts create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/esm/index.mjs create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/esm/index.mjs.map create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/iife/index.global.js create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/dist/iife/index.global.js.map create mode 100644 node_modules/.pnpm/@sapphire+snowflake@3.5.3/node_modules/@sapphire/snowflake/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/compiler/compiler.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/compiler/compiler.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/compiler/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/compiler/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/errors.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/errors.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/function.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/function.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/errors/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/guard.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/guard.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/module.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/module.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/parse.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/parse.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/token.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/token.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/types.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/runtime/types.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/parse.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/parse.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/token.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/token.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/types.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/parser/static/types.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/mapping.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/mapping.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/parser.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/parser.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/syntax.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/syntax/syntax.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/policy.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/policy.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/system.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/system/system.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/any/any.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/any/any.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/any/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/any/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/argument/argument.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/argument/argument.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/argument/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/argument/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/array/array.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/array/array.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/array/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/array/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/async-iterator/async-iterator.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/async-iterator/async-iterator.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/async-iterator/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/async-iterator/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/awaited/awaited.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/awaited/awaited.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/awaited/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/awaited/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/bigint/bigint.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/bigint/bigint.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/bigint/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/bigint/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/boolean/boolean.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/boolean/boolean.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/boolean/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/boolean/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/value.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/clone/value.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/composite/composite.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/composite/composite.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/composite/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/composite/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/computed/computed.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/computed/computed.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/computed/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/computed/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/const/const.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/const/const.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/const/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/const/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor-parameters/constructor-parameters.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor-parameters/constructor-parameters.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor-parameters/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor-parameters/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor/constructor.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor/constructor.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/constructor/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/immutable.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/immutable.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/create/type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/date/date.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/date/date.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/date/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/date/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/discard/discard.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/discard/discard.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/discard/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/discard/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/enum/enum.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/enum/enum.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/enum/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/enum/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/error/error.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/error/error.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/error/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/error/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude-from-template-literal.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude-from-template-literal.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/exclude.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/exclude/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-check.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-check.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-from-mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-from-mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-undefined.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends-undefined.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/extends.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extends/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract-from-template-literal.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract-from-template-literal.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/extract.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/extract/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/function/function.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/function/function.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/function/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/function/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/kind.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/kind.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/value.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/guard/value.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/helpers/helpers.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/helpers/helpers.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/helpers/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/helpers/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-from-mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-from-mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-property-keys.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed-property-keys.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/indexed/indexed.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instance-type/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instance-type/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instance-type/instance-type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instance-type/instance-type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instantiate/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instantiate/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instantiate/instantiate.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/instantiate/instantiate.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/integer/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/integer/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/integer/integer.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/integer/integer.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-create.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-create.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-evaluated.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-evaluated.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect-type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intersect/intersect.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/capitalize.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/capitalize.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/intrinsic-from-mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/intrinsic-from-mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/intrinsic.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/intrinsic.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/lowercase.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/lowercase.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/uncapitalize.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/uncapitalize.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/uppercase.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/intrinsic/uppercase.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/iterator/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/iterator/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/iterator/iterator.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/iterator/iterator.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-property-entries.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-property-entries.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-property-keys.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof-property-keys.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/keyof/keyof.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/literal/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/literal/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/literal/literal.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/literal/literal.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/mapped/mapped.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/compute.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/compute.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/infer.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/infer.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/module.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/module/module.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/never/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/never/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/never/never.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/never/never.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/not/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/not/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/not/not.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/not/not.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/null/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/null/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/null/null.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/null/null.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/number/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/number/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/number/number.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/number/number.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/object/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/object/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/object/object.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/object/object.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit-from-mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit-from-mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/omit/omit.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/optional-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/optional-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/optional.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/optional/optional.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/parameters/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/parameters/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/parameters/parameters.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/parameters/parameters.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/partial-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/partial-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/partial.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/partial/partial.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/patterns/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/patterns/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/patterns/patterns.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/patterns/patterns.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick-from-mapped-key.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick-from-mapped-key.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/pick/pick.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/promise/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/promise/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/promise/promise.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/promise/promise.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly-optional/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly-optional/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly-optional/readonly-optional.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly-optional/readonly-optional.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/readonly-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/readonly-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/readonly.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/readonly/readonly.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/record/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/record/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/record/record.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/record/record.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/recursive/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/recursive/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/recursive/recursive.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/recursive/recursive.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/ref/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/ref/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/ref/ref.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/ref/ref.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/regexp/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/regexp/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/regexp/regexp.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/regexp/regexp.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/format.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/format.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/registry/type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/required-from-mapped-result.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/required-from-mapped-result.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/required.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/required/required.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/rest/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/rest/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/rest/rest.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/rest/rest.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/return-type/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/return-type/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/return-type/return-type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/return-type/return-type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/anyschema.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/anyschema.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/schema.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/schema/schema.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/sets/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/sets/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/sets/set.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/sets/set.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/static/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/static/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/static/static.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/static/static.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/string/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/string/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/string/string.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/string/string.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbol/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbol/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbol/symbol.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbol/symbol.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbols/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbols/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbols/symbols.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/symbols/symbols.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/finite.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/finite.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/generate.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/generate.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/parse.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/parse.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/pattern.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/pattern.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/syntax.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/syntax.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/template-literal.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/template-literal.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/union.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/template-literal/union.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/transform/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/transform/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/transform/transform.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/transform/transform.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/tuple/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/tuple/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/tuple/tuple.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/tuple/tuple.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/javascript.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/javascript.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/json.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/json.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/type/type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/uint8array/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/uint8array/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/uint8array/uint8array.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/uint8array/uint8array.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/undefined/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/undefined/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/undefined/undefined.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/undefined/undefined.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-create.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-create.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-evaluated.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-evaluated.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-type.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union-type.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/union/union.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unknown/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unknown/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unknown/unknown.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unknown/unknown.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unsafe/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unsafe/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unsafe/unsafe.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/unsafe/unsafe.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/void/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/void/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/void/void.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/type/void/void.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/assert/assert.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/assert/assert.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/assert/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/assert/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/cast/cast.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/cast/cast.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/cast/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/cast/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/check/check.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/check/check.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/check/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/check/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clean/clean.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clean/clean.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clean/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clean/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clone/clone.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clone/clone.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clone/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/clone/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/convert/convert.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/convert/convert.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/convert/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/convert/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/create/create.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/create/create.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/create/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/create/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/decode/decode.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/decode/decode.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/decode/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/decode/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/default/default.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/default/default.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/default/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/default/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/delta/delta.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/delta/delta.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/delta/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/delta/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/deref/deref.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/deref/deref.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/deref/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/deref/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/encode/encode.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/encode/encode.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/encode/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/encode/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/equal/equal.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/equal/equal.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/equal/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/equal/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/guard/guard.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/guard/guard.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/guard/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/guard/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/hash/hash.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/hash/hash.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/hash/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/hash/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/mutate/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/mutate/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/mutate/mutate.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/mutate/mutate.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/parse/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/parse/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/parse/parse.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/parse/parse.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/pointer/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/pointer/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/pointer/pointer.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/pointer/pointer.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/decode.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/decode.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/encode.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/encode.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/has.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/has.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/transform/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/value/index.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/value/index.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/value/value.d.ts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/cjs/value/value/value.js create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/compiler/compiler.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/compiler/compiler.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/compiler/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/compiler/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/errors.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/errors.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/function.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/function.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/errors/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/guard.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/guard.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/module.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/module.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/parse.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/parse.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/token.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/token.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/types.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/runtime/types.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/parse.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/parse.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/token.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/token.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/types.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/parser/static/types.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/mapping.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/mapping.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/parser.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/parser.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/syntax.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/syntax/syntax.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/policy.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/policy.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/system.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/system/system.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/any/any.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/any/any.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/any/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/any/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/argument/argument.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/argument/argument.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/argument/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/argument/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/array/array.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/array/array.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/array/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/array/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/async-iterator/async-iterator.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/async-iterator/async-iterator.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/async-iterator/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/async-iterator/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/awaited/awaited.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/awaited/awaited.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/awaited/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/awaited/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/bigint/bigint.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/bigint/bigint.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/bigint/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/bigint/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/boolean/boolean.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/boolean/boolean.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/boolean/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/boolean/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/value.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/clone/value.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/composite/composite.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/composite/composite.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/composite/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/composite/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/computed/computed.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/computed/computed.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/computed/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/computed/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/const/const.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/const/const.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/const/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/const/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor-parameters/constructor-parameters.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor-parameters/constructor-parameters.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor-parameters/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor-parameters/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor/constructor.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor/constructor.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/constructor/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/immutable.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/immutable.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/create/type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/date/date.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/date/date.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/date/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/date/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/discard/discard.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/discard/discard.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/discard/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/discard/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/enum/enum.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/enum/enum.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/enum/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/enum/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/error/error.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/error/error.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/error/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/error/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude-from-template-literal.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude-from-template-literal.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/exclude.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/exclude/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-check.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-check.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-from-mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-from-mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-undefined.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends-undefined.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/extends.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extends/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract-from-template-literal.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract-from-template-literal.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/extract.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/extract/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/function/function.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/function/function.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/function/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/function/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/kind.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/kind.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/value.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/guard/value.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/helpers/helpers.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/helpers/helpers.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/helpers/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/helpers/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-from-mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-from-mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-property-keys.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed-property-keys.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/indexed/indexed.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instance-type/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instance-type/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instance-type/instance-type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instance-type/instance-type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instantiate/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instantiate/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instantiate/instantiate.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/instantiate/instantiate.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/integer/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/integer/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/integer/integer.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/integer/integer.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-create.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-create.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-evaluated.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-evaluated.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect-type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intersect/intersect.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/capitalize.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/capitalize.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/intrinsic-from-mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/intrinsic-from-mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/intrinsic.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/intrinsic.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/lowercase.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/lowercase.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/uncapitalize.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/uncapitalize.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/uppercase.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/intrinsic/uppercase.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/iterator/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/iterator/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/iterator/iterator.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/iterator/iterator.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-property-entries.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-property-entries.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-property-keys.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof-property-keys.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/keyof/keyof.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/literal/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/literal/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/literal/literal.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/literal/literal.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/mapped/mapped.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/compute.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/compute.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/infer.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/infer.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/module.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/module/module.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/never/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/never/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/never/never.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/never/never.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/not/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/not/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/not/not.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/not/not.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/null/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/null/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/null/null.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/null/null.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/number/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/number/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/number/number.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/number/number.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/object/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/object/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/object/object.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/object/object.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit-from-mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit-from-mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/omit/omit.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/optional-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/optional-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/optional.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/optional/optional.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/parameters/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/parameters/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/parameters/parameters.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/parameters/parameters.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/partial-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/partial-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/partial.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/partial/partial.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/patterns/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/patterns/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/patterns/patterns.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/patterns/patterns.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick-from-mapped-key.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick-from-mapped-key.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/pick/pick.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/promise/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/promise/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/promise/promise.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/promise/promise.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly-optional/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly-optional/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly-optional/readonly-optional.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly-optional/readonly-optional.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/readonly-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/readonly-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/readonly.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/readonly/readonly.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/record/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/record/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/record/record.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/record/record.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/recursive/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/recursive/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/recursive/recursive.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/recursive/recursive.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/ref/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/ref/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/ref/ref.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/ref/ref.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/regexp/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/regexp/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/regexp/regexp.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/regexp/regexp.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/format.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/format.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/registry/type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/required-from-mapped-result.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/required-from-mapped-result.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/required.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/required/required.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/rest/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/rest/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/rest/rest.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/rest/rest.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/return-type/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/return-type/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/return-type/return-type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/return-type/return-type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/anyschema.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/anyschema.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/schema.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/schema/schema.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/sets/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/sets/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/sets/set.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/sets/set.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/static/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/static/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/static/static.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/static/static.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/string/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/string/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/string/string.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/string/string.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbol/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbol/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbol/symbol.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbol/symbol.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbols/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbols/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbols/symbols.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/symbols/symbols.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/finite.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/finite.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/generate.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/generate.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/parse.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/parse.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/pattern.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/pattern.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/syntax.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/syntax.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/template-literal.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/template-literal.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/union.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/template-literal/union.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/transform/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/transform/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/transform/transform.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/transform/transform.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/tuple/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/tuple/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/tuple/tuple.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/tuple/tuple.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/javascript.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/javascript.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/json.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/json.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/type/type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/uint8array/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/uint8array/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/uint8array/uint8array.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/uint8array/uint8array.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/undefined/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/undefined/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/undefined/undefined.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/undefined/undefined.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-create.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-create.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-evaluated.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-evaluated.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-type.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union-type.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/union/union.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unknown/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unknown/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unknown/unknown.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unknown/unknown.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unsafe/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unsafe/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unsafe/unsafe.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/unsafe/unsafe.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/void/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/void/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/void/void.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/type/void/void.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/assert/assert.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/assert/assert.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/assert/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/assert/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/cast/cast.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/cast/cast.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/cast/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/cast/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/check/check.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/check/check.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/check/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/check/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clean/clean.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clean/clean.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clean/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clean/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clone/clone.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clone/clone.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clone/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/clone/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/convert/convert.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/convert/convert.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/convert/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/convert/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/create/create.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/create/create.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/create/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/create/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/decode/decode.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/decode/decode.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/decode/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/decode/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/default/default.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/default/default.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/default/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/default/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/delta/delta.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/delta/delta.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/delta/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/delta/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/deref/deref.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/deref/deref.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/deref/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/deref/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/encode/encode.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/encode/encode.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/encode/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/encode/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/equal/equal.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/equal/equal.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/equal/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/equal/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/guard/guard.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/guard/guard.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/guard/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/guard/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/hash/hash.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/hash/hash.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/hash/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/hash/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/mutate/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/mutate/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/mutate/mutate.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/mutate/mutate.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/parse/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/parse/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/parse/parse.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/parse/parse.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/pointer/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/pointer/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/pointer/pointer.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/pointer/pointer.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/decode.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/decode.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/encode.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/encode.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/has.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/has.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/transform/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/value/index.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/value/index.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/value/value.d.mts create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/build/esm/value/value/value.mjs create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/compiler/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/errors/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/license create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/parser/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/readme.md create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/syntax/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/system/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/type/package.json create mode 100644 node_modules/.pnpm/@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox/value/package.json create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/LICENSE create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/README.md create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/assert.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/assert/strict.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/async_hooks.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/buffer.buffer.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/buffer.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/child_process.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/cluster.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/compatibility/disposable.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/compatibility/index.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/compatibility/indexable.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/compatibility/iterators.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/console.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/constants.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/crypto.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/dgram.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/diagnostics_channel.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/dns.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/dns/promises.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/dom-events.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/domain.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/events.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/fs.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/fs/promises.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/globals.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/globals.typedarray.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/http.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/http2.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/https.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/index.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/inspector.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/module.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/net.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/os.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/package.json create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/path.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/perf_hooks.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/process.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/punycode.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/querystring.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/readline.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/readline/promises.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/repl.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/sea.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/sqlite.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/stream.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/stream/consumers.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/stream/promises.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/stream/web.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/string_decoder.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/test.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/timers.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/timers/promises.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/tls.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/trace_events.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/ts5.6/buffer.buffer.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/ts5.6/globals.typedarray.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/ts5.6/index.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/tty.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/url.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/util.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/v8.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/vm.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/wasi.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/worker_threads.d.ts create mode 100644 node_modules/.pnpm/@types+node@22.14.1/node_modules/@types/node/zlib.d.ts create mode 120000 node_modules/.pnpm/@types+node@22.14.1/node_modules/undici-types create mode 120000 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/node create mode 100644 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/ws/LICENSE create mode 100644 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/ws/README.md create mode 100644 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/ws/index.d.mts create mode 100644 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/ws/index.d.ts create mode 100644 node_modules/.pnpm/@types+ws@8.18.1/node_modules/@types/ws/package.json create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/CHANGELOG.md create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/LICENSE.md create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/README.md create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/THIRD_PARTY_LICENSE.md create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.cjs create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.cjs.map create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.d.mts create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.d.ts create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.global.js create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.global.js.map create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.mjs create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/dist/index.mjs.map create mode 100644 node_modules/.pnpm/@vladfrangu+async_event_emitter@2.4.6/node_modules/@vladfrangu/async_event_emitter/package.json create mode 120000 node_modules/.pnpm/bun-types@1.2.9/node_modules/@types/node create mode 120000 node_modules/.pnpm/bun-types@1.2.9/node_modules/@types/ws create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/README.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/bun.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/bun.ns.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/deprecated.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/devserver.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/binary-data.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/cc.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/color.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/console.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/cookie.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/dns.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/fetch.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/ffi.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/file-io.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/file-system-router.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/file.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/glob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/globals.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/hashing.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/html-rewriter.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/http.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/import-meta.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/node-api.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/redis.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/s3.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/semver.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/spawn.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/sql.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/sqlite.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/streams.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/tcp.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/test.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/transpiler.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/udp.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/utils.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/websockets.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/api/workers.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/benchmarks.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bun-flavored-toml.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/css.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/css_modules.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/executables.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/fullstack.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/hmr.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/html.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/index.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/intro.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/loaders.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/macros.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/plugins.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/bundler/vs-esbuild.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/add.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/bun-completions.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/bun-create.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/bun-install.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/bun-upgrade.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/bunx.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/filter.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/init.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/install.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/link.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/outdated.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/patch-commit.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/pm.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/publish.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/remove.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/run.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/test.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/unlink.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/cli/update.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/contributing/upgrading-webkit.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/ecosystem/elysia.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/ecosystem/express.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/ecosystem/hono.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/ecosystem/react.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/ecosystem/stric.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/arraybuffer-to-array.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/arraybuffer-to-blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/arraybuffer-to-buffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/arraybuffer-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/arraybuffer-to-typedarray.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/blob-to-arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/blob-to-dataview.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/blob-to-stream.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/blob-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/blob-to-typedarray.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/buffer-to-arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/buffer-to-blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/buffer-to-readablestream.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/buffer-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/buffer-to-typedarray.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/dataview-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-buffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-dataview.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-readablestream.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/binary/typedarray-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/astro.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/discordjs.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/docker.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/drizzle.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/edgedb.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/elysia.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/express.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/hono.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/mongoose.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/neon-drizzle.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/neon-serverless-postgres.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/nextjs.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/nuxt.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/pm2.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/prisma.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/qwik.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/react.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/remix.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/render.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/sentry.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/solidstart.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/ssr-react.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/stric.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/sveltekit.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/systemd.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/ecosystem/vite.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/html-rewriter/extract-links.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/html-rewriter/extract-social-meta.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/cluster.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/fetch-unix.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/fetch.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/file-uploads.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/hot.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/proxy.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/server.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/simple.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/stream-file.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/stream-iterator.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/stream-node-streams-in-bun.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/http/tls.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add-dev.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add-git.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add-optional.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add-peer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add-tarball.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/add.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/azure-artifacts.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/cicd.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/custom-registry.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/from-npm-install-to-bun-install.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/git-diff-bun-lockfile.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/jfrog-artifactory.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/npm-alias.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/registry-scope.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/trusted.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/workspaces.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/install/yarnlock.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/argv.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/ctrl-c.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/ipc.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/nanoseconds.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/os-signals.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/spawn-stderr.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/spawn-stdout.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/spawn.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/process/stdin.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/buffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/exists.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/json.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/mime.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/stream.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/uint8array.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/read-file/watch.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/cicd.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/codesign-macos-executable.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/define-constant.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/delete-directory.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/delete-file.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/heap-snapshot.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/import-html.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/import-json.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/import-toml.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/read-env.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/set-env.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/shell.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/timezone.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/tsconfig-paths.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/typescript.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/vscode-debugger.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/runtime/web-debugger.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/node-readable-to-arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/node-readable-to-blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/node-readable-to-json.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/node-readable-to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/node-readable-to-uint8array.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-array.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-arraybuffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-buffer.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-json.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-string.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/streams/to-typedarray.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/bail.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/coverage-threshold.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/coverage.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/happy-dom.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/migrate-from-jest.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/mock-clock.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/mock-functions.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/rerun-each.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/run-tests.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/skip-tests.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/snapshot.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/spy-on.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/svelte-test.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/testing-library.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/timeout.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/todo-tests.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/update-snapshots.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/test/watch-mode.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/base64.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/deep-equals.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/deflate.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/detect-bun.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/entrypoint.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/escape-html.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/file-url-to-path.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/gzip.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/hash-a-password.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/import-meta-dir.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/import-meta-file.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/import-meta-path.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/main.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/path-to-file-url.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/sleep.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/version.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/util/which-path-to-executable-bin.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/websocket/compression.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/websocket/context.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/websocket/pubsub.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/websocket/simple.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/append.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/basic.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/blob.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/cat.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/file-cp.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/filesink.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/response.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/stdout.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/stream.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/guides/write-file/unlink.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/index.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/cache.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/index.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/lifecycle.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/lockfile.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/npmrc.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/overrides.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/patch.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/registries.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/install/workspaces.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/installation.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/benchmarking.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/bindgen.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/building-windows.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/contributing.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/internals/build-process-for-ci.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/licensing.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/project/roadmap.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/quickstart.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/autoimport.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/bun-apis.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/bunfig.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/debugger.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/env.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/hot.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/index.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/jsx.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/loaders.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/modules.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/nodejs-apis.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/plugins.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/shell.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/typescript.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/runtime/web-apis.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/configuration.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/coverage.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/discovery.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/dom.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/hot.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/lifecycle.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/mocks.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/reporters.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/runtime-behavior.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/snapshots.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/time.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/test/writing.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/docs/typescript.md create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/extensions.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/fetch.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/ffi.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/globals.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/html-rewriter.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/index.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/jsc.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/overrides.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/package.json create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/redis.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/s3.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/sqlite.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/test.d.ts create mode 100644 node_modules/.pnpm/bun-types@1.2.9/node_modules/bun-types/wasm.d.ts create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/LICENSE create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/README.md create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/dist/index.d.ts create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/dist/index.js create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/dist/index.js.map create mode 100644 node_modules/.pnpm/cookie@1.0.2/node_modules/cookie/package.json create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/LICENSE create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/README.md create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/common.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/common.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/common.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/common.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v10.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v10.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v10.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v10.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v10.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v6.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v6.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v6.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v6.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v6.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v8.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v8.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v8.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v8.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v8.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v9.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v9.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v9.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v9.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/gateway/v9.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/globals.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/globals.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/globals.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/globals.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/globals.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/package.json create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/common.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/common.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/common.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/common.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/entryPoint.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/entryPoint.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/entryPoint.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/entryPoint.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/ping.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/ping.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/ping.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/ping.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/responses.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/responses.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/responses.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/_interactions/responses.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/application.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/application.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/application.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/application.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/autoModeration.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/autoModeration.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/autoModeration.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/autoModeration.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/monetization.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/monetization.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/monetization.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/monetization.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/poll.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/poll.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/poll.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/poll.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/soundboard.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/soundboard.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/soundboard.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/soundboard.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/teams.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/teams.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/teams.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/teams.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v10/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/teams.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/teams.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/teams.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/teams.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v6/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/ping.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/ping.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/ping.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/ping.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/responses.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/responses.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/responses.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/_interactions/responses.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/application.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/application.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/application.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/application.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/teams.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/teams.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/teams.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/teams.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v8/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/entryPoint.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/entryPoint.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/entryPoint.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/entryPoint.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/base.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/base.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/base.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/base.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/ping.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/ping.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/ping.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/ping.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/responses.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/responses.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/responses.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/_interactions/responses.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/application.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/application.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/application.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/application.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/autoModeration.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/autoModeration.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/autoModeration.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/autoModeration.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/monetization.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/monetization.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/monetization.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/monetization.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/permissions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/permissions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/permissions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/permissions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/poll.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/poll.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/poll.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/poll.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/soundboard.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/soundboard.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/soundboard.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/soundboard.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/teams.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/teams.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/teams.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/teams.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/payloads/v9/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/common.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/common.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/common.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/common.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/application.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/application.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/application.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/application.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/autoModeration.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/autoModeration.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/autoModeration.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/autoModeration.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/monetization.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/monetization.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/monetization.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/monetization.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/poll.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/poll.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/poll.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/poll.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/soundboard.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/soundboard.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/soundboard.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/soundboard.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v10/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v6/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v8/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/application.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/application.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/application.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/application.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/auditLog.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/auditLog.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/auditLog.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/auditLog.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/autoModeration.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/autoModeration.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/autoModeration.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/autoModeration.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/channel.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/channel.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/channel.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/channel.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/emoji.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/emoji.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/emoji.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/emoji.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/gateway.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/gateway.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/gateway.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/gateway.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guild.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guild.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guild.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guild.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guildScheduledEvent.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guildScheduledEvent.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/guildScheduledEvent.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/interactions.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/interactions.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/interactions.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/interactions.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/invite.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/invite.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/invite.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/invite.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/monetization.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/monetization.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/monetization.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/monetization.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/oauth2.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/oauth2.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/oauth2.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/oauth2.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/poll.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/poll.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/poll.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/poll.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/soundboard.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/soundboard.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/soundboard.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/soundboard.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/stageInstance.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/stageInstance.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/stageInstance.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/stageInstance.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/sticker.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/sticker.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/sticker.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/sticker.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/template.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/template.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/template.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/template.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/user.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/user.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/user.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/user.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/voice.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/voice.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/voice.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/voice.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/webhook.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/webhook.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/webhook.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rest/v9/webhook.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/common.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/common.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/common.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/common.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v10.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v10.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v10.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v10.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v10.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v8.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v8.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v8.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v8.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v8.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v9.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v9.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v9.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v9.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/rpc/v9.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/internals.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/internals.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/internals.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/internals.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v10.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v10.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v10.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v10.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v10.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v8.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v8.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v8.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v8.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v8.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v9.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v9.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v9.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v9.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/utils/v9.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v10.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v10.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v10.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v10.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v10.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v6.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v6.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v6.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v6.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v6.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v8.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v8.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v8.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v8.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v8.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v9.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v9.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v9.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v9.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/v9.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/index.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/index.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/index.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/index.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/index.mjs create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/v4.d.ts create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/v4.d.ts.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/v4.js create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/v4.js.map create mode 100644 node_modules/.pnpm/discord-api-types@0.37.120/node_modules/discord-api-types/voice/v4.mjs create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/builders create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/collection create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/formatters create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/rest create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/util create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@discordjs/ws create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/@sapphire/snowflake create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord-api-types create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/LICENSE create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/README.md create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/package.json create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/BaseClient.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/Client.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/WebhookClient.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/Action.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ActionsManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ApplicationCommandPermissionsUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/AutoModerationActionExecution.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/AutoModerationRuleCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/AutoModerationRuleDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/AutoModerationRuleUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ChannelCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ChannelDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ChannelUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/EntitlementCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/EntitlementDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/EntitlementUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildAuditLogEntryCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildBanAdd.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildBanRemove.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildChannelsPositionUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildEmojiCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildEmojiDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildEmojiUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildEmojisUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildIntegrationsUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildMemberRemove.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildMemberUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildRoleCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildRoleDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildRoleUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildRolesPositionUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildScheduledEventCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildScheduledEventDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildScheduledEventUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildScheduledEventUserAdd.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildScheduledEventUserRemove.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildStickerCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildStickerDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildStickerUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildStickersUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/GuildUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/InteractionCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/InviteCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/InviteDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageDeleteBulk.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessagePollVoteAdd.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessagePollVoteRemove.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageReactionAdd.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageReactionRemove.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageReactionRemoveAll.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageReactionRemoveEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/MessageUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/PresenceUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/StageInstanceCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/StageInstanceDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/StageInstanceUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ThreadCreate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ThreadDelete.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ThreadListSync.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ThreadMemberUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/ThreadMembersUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/TypingStart.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/UserUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/VoiceStateUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/actions/WebhooksUpdate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/voice/ClientVoiceManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/WebSocketManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/WebSocketShard.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_BAN_ADD.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_BAN_REMOVE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_ADD.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/GUILD_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/INTERACTION_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/INVITE_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/INVITE_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/PRESENCE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/READY.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/RESUMED.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/SUBSCRIPTION_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/SUBSCRIPTION_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/SUBSCRIPTION_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_CREATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_DELETE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_LIST_SYNC.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/THREAD_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/TYPING_START.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/USER_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/VOICE_STATE_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/WEBHOOKS_UPDATE.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/client/websocket/handlers/index.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/errors/DJSError.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/errors/ErrorCodes.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/errors/Messages.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/errors/index.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/index.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ApplicationCommandManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ApplicationCommandPermissionsManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ApplicationEmojiManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/AutoModerationRuleManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/BaseGuildEmojiManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/BaseManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/CachedManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/CategoryChannelChildManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ChannelManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/DMMessageManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/DataManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/EntitlementManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildApplicationCommandManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildBanManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildChannelManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildEmojiManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildEmojiRoleManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildForumThreadManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildInviteManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildMemberManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildMemberRoleManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildMessageManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildScheduledEventManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildStickerManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/GuildTextThreadManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/MessageManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/PartialGroupDMMessageManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/PermissionOverwriteManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/PresenceManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ReactionManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ReactionUserManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/RoleManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/StageInstanceManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/SubscriptionManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ThreadManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/ThreadMemberManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/UserManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/managers/VoiceStateManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/sharding/Shard.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/sharding/ShardClientUtil.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/sharding/ShardingManager.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ActionRow.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ActionRowBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/AnonymousGuild.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ApplicationCommand.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ApplicationEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ApplicationRoleConnectionMetadata.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Attachment.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/AttachmentBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/AutoModerationActionExecution.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/AutoModerationRule.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/AutocompleteInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Base.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseGuild.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseGuildEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseGuildTextChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseGuildVoiceChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/BaseSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ButtonBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ButtonComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ButtonInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/CategoryChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ChannelSelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ChannelSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ChannelSelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ChatInputCommandInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ClientApplication.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ClientPresence.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ClientUser.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/CommandInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/CommandInteractionOptionResolver.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Component.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ContextMenuCommandInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/DMChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/DirectoryChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Embed.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/EmbedBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Emoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Entitlement.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ForumChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Guild.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildAuditLogs.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildAuditLogsEntry.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildBan.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildMember.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildOnboarding.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildOnboardingPrompt.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildOnboardingPromptOption.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildPreview.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildPreviewEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildScheduledEvent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/GuildTemplate.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Integration.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/IntegrationApplication.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionCallback.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionCallbackResource.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionCallbackResponse.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionCollector.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionResponse.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InteractionWebhook.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Invite.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InviteGuild.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/InviteStageInstance.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MediaChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MentionableSelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MentionableSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MentionableSelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Message.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessageCollector.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessageComponentInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessageContextMenuCommandInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessageMentions.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessagePayload.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/MessageReaction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ModalBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ModalSubmitFields.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ModalSubmitInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/NewsChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/OAuth2Guild.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/PartialGroupDMChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/PermissionOverwrites.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Poll.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/PollAnswer.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Presence.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ReactionCollector.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ReactionEmoji.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Role.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/RoleSelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/RoleSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/RoleSelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/SKU.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/SelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/SelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/SelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/SelectMenuOptionBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StageChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StageInstance.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Sticker.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StickerPack.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StringSelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StringSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StringSelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/StringSelectMenuOptionBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Subscription.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Team.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/TeamMember.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/TextChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/TextInputBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/TextInputComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ThreadChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ThreadMember.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/ThreadOnlyChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Typing.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/User.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/UserContextMenuCommandInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/UserSelectMenuBuilder.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/UserSelectMenuComponent.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/UserSelectMenuInteraction.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/VoiceChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/VoiceChannelEffect.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/VoiceRegion.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/VoiceState.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Webhook.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/WelcomeChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/WelcomeScreen.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/Widget.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/WidgetMember.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/interfaces/Application.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/interfaces/Collector.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/interfaces/InteractionResponses.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/structures/interfaces/TextBasedChannel.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/APITypes.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/ActivityFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/ApplicationFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/AttachmentFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/BitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/ChannelFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Channels.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Colors.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Components.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Constants.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/DataResolver.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Enums.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Events.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Formatters.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/GuildMemberFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/IntentsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/LimitedCollection.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/MessageFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Options.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Partials.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/PermissionsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/RoleFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/SKUFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/ShardEvents.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Status.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Sweepers.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Symbols.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/SystemChannelFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/ThreadMemberFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Transformers.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/UserFlagsBitField.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/Util.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/src/util/WebSocketShardEvents.js create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/index.d.mts create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/index.d.ts create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/index.test-d.ts create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/rawDataTypes.d.mts create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/rawDataTypes.d.ts create mode 100644 node_modules/.pnpm/discord.js@14.18.0/node_modules/discord.js/typings/tsdoc-metadata.json create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/fast-deep-equal create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/lodash.snakecase create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/tslib create mode 120000 node_modules/.pnpm/discord.js@14.18.0/node_modules/undici create mode 120000 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/@sinclair/typebox create mode 120000 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/cookie create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/LICENSE create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/README.md create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/bunfig.toml create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/bun/handler.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/bun/handler.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/bun/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/bun/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/types.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/web-standard/handler.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/web-standard/handler.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/web-standard/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/adapter/web-standard/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/bun/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/bun/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/bun/index.js.map create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/bun/handler.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/bun/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/types.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/web-standard/handler.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/adapter/web-standard/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/compose.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/compose.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/context.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/context.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/cookies.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/cookies.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/deuri.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/deuri.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/dynamic-handle.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/dynamic-handle.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/error.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/error.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/fast-querystring.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/fast-querystring.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/formats.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/formats.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/manifest.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/manifest.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/sucrose.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/sucrose.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/trace.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/trace.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/type-system.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/type-system.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/types.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/env.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/file.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/request.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/server.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/types.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/universal/utils.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/utils.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/utils.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/bun.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/bun.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/index.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cjs/ws/types.js create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/compose.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/compose.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/context.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/context.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cookies.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/cookies.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/deuri.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/deuri.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/dynamic-handle.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/dynamic-handle.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/error.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/error.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/fast-querystring.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/fast-querystring.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/formats.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/formats.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/manifest.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/manifest.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/sucrose.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/sucrose.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/trace.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/trace.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/type-system.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/type-system.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/types.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/env.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/env.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/file.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/file.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/request.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/request.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/server.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/server.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/types.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/utils.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/universal/utils.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/utils.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/utils.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/bun.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/bun.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/index.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/index.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/types.d.ts create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/dist/ws/types.mjs create mode 100644 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/elysia/package.json create mode 120000 node_modules/.pnpm/elysia@1.2.25_@sinclair+typebox@0.34.33/node_modules/memoirist create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/LICENSE create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/README.md create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/es6/index.d.ts create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/es6/index.js create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/es6/react.d.ts create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/es6/react.js create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.d.ts create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.js create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/package.json create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/react.d.ts create mode 100644 node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/react.js create mode 100644 node_modules/.pnpm/lock.yaml create mode 100644 node_modules/.pnpm/lodash.snakecase@4.1.1/node_modules/lodash.snakecase/LICENSE create mode 100644 node_modules/.pnpm/lodash.snakecase@4.1.1/node_modules/lodash.snakecase/README.md create mode 100644 node_modules/.pnpm/lodash.snakecase@4.1.1/node_modules/lodash.snakecase/index.js create mode 100644 node_modules/.pnpm/lodash.snakecase@4.1.1/node_modules/lodash.snakecase/package.json create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/LICENSE create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/README.md create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_DataView.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Hash.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_LazyWrapper.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_ListCache.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_LodashWrapper.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Map.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_MapCache.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Promise.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Set.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_SetCache.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Stack.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Symbol.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_Uint8Array.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_WeakMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_apply.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayAggregator.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayEach.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayEachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayEvery.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayFilter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayIncludes.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayIncludesWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayLikeKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayPush.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayReduce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayReduceRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arraySample.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arraySampleSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arrayShuffle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_arraySome.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_asciiSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_asciiToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_asciiWords.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_assignMergeValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_assignValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_assocIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseAggregator.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseAssign.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseAssignIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseAssignValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseClamp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseClone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseConforms.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseConformsTo.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseCreate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseDelay.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseDifference.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseEach.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseEachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseEvery.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseExtremum.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFill.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFilter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFindIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFindKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFlatten.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseForOwn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseForOwnRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseForRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseFunctions.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseGetAllKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseGetTag.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseGt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseHasIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseInRange.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIndexOfWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIntersection.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseInverter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseInvoke.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsArguments.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsArrayBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsDate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsEqual.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsEqualDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsMatch.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsNaN.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsNative.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIsTypedArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseIteratee.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseKeysIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseLodash.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseLt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMatches.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMatchesProperty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMean.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMerge.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseMergeDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseNth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseOrderBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePick.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePickBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseProperty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePropertyDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePropertyOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePullAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_basePullAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseRandom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseRange.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseReduce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseRepeat.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseRest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSample.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSampleSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSetData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSetToString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseShuffle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSlice.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSome.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSortBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSortedIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSortedIndexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSortedUniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseSum.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseTimes.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseToNumber.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseToPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseToString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseTrim.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseUnary.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseUniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseUnset.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseUpdate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseValues.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseWrapperValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseXor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_baseZipObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cacheHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_castArrayLikeObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_castFunction.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_castPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_castRest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_castSlice.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_charsEndIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_charsStartIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneArrayBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneDataView.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneSymbol.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_cloneTypedArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_compareAscending.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_compareMultiple.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_composeArgs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_composeArgsRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_copyArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_copyObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_copySymbols.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_copySymbolsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_coreJsData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_countHolders.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createAggregator.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createAssigner.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createBaseEach.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createBaseFor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createBind.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createCaseFirst.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createCompounder.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createCtor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createCurry.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createFind.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createFlow.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createHybrid.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createInverter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createMathOperation.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createOver.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createPadding.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createPartial.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createRange.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createRecurry.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createRelationalOperation.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createRound.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createToPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_createWrap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_customDefaultsAssignIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_customDefaultsMerge.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_customOmitClone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_deburrLetter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_defineProperty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_equalArrays.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_equalByTag.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_equalObjects.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_escapeHtmlChar.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_escapeStringChar.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_flatRest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_freeGlobal.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getAllKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getAllKeysIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getFuncName.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getHolder.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getMapData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getMatchData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getNative.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getPrototype.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getRawTag.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getSymbols.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getSymbolsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getTag.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getView.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_getWrapDetails.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hasPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hasUnicode.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hasUnicodeWord.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hashClear.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hashDelete.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hashGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hashHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_hashSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_initCloneArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_initCloneByTag.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_initCloneObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_insertWrapDetails.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isFlattenable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isIterateeCall.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isKeyable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isLaziable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isMaskable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isMasked.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isPrototype.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_isStrictComparable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_iteratorToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_lazyClone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_lazyReverse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_lazyValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_listCacheClear.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_listCacheDelete.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_listCacheGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_listCacheHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_listCacheSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapCacheClear.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapCacheDelete.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapCacheGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapCacheHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapCacheSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mapToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_matchesStrictComparable.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_memoizeCapped.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_mergeData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_metaMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_nativeCreate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_nativeKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_nativeKeysIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_nodeUtil.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_objectToString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_overArg.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_overRest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_parent.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_reEscape.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_reEvaluate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_reInterpolate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_realNames.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_reorder.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_replaceHolders.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_root.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_safeGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setCacheAdd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setCacheHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setData.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setToPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setToString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_setWrapToString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_shortOut.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_shuffleSelf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stackClear.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stackDelete.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stackGet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stackHas.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stackSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_strictIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_strictLastIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stringSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stringToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_stringToPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_toKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_toSource.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_trimmedEndIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_unescapeHtmlChar.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_unicodeSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_unicodeToArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_unicodeWords.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_updateWrapDetails.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/_wrapperClone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/add.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/after.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/array.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/ary.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/assign.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/assignIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/assignInWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/assignWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/at.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/attempt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/before.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/bind.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/bindAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/bindKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/camelCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/capitalize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/castArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/ceil.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/chain.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/chunk.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/clamp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/clone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/cloneDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/cloneDeepWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/cloneWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/collection.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/commit.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/compact.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/concat.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/cond.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/conforms.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/conformsTo.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/constant.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/core.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/core.min.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/countBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/create.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/curry.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/curryRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/date.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/debounce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/deburr.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/defaultTo.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/defaults.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/defaultsDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/defer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/delay.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/difference.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/differenceBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/differenceWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/divide.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/drop.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/dropRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/dropRightWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/dropWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/each.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/eachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/endsWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/entries.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/entriesIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/eq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/escape.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/escapeRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/every.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/extend.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/extendWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fill.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/filter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/find.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/findIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/findKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/findLast.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/findLastIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/findLastKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/first.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flake.lock create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flake.nix create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flatMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flatMapDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flatMapDepth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flatten.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flattenDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flattenDepth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/floor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flow.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/flowRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forEach.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forEachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forInRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forOwn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/forOwnRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/F.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/T.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/__.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/_baseConvert.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/_convertBrowser.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/_falseOptions.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/_mapping.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/_util.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/add.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/after.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/all.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/allPass.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/always.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/any.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/anyPass.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/apply.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/array.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/ary.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assign.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignInAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignInAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignInWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assignWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assoc.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/assocPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/at.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/attempt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/before.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/bind.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/bindAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/bindKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/camelCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/capitalize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/castArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/ceil.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/chain.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/chunk.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/clamp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/clone.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/cloneDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/cloneDeepWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/cloneWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/collection.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/commit.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/compact.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/complement.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/compose.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/concat.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/cond.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/conforms.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/conformsTo.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/constant.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/contains.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/convert.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/countBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/create.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/curry.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/curryN.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/curryRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/curryRightN.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/date.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/debounce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/deburr.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defaultTo.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defaults.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defaultsAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defaultsDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defaultsDeepAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/defer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/delay.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/difference.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/differenceBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/differenceWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dissoc.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dissocPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/divide.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/drop.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dropLast.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dropLastWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dropRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dropRightWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/dropWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/each.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/eachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/endsWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/entries.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/entriesIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/eq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/equals.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/escape.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/escapeRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/every.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/extend.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/extendAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/extendAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/extendWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/fill.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/filter.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/find.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findIndexFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findLast.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findLastFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findLastIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findLastIndexFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/findLastKey.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/first.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flatMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flatMapDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flatMapDepth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flatten.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flattenDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flattenDepth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/floor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flow.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/flowRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forEach.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forEachRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forInRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forOwn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/forOwnRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/fromPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/function.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/functions.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/functionsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/get.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/getOr.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/groupBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/gt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/gte.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/has.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/hasIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/head.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/identical.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/identity.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/inRange.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/includes.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/includesFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/indexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/indexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/indexOfFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/init.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/initial.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/intersection.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/intersectionBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/intersectionWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invert.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invertBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invertObj.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invoke.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invokeArgs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invokeArgsMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/invokeMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isArguments.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isArrayBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isArrayLike.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isArrayLikeObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isBoolean.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isDate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isElement.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isEmpty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isEqual.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isEqualWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isError.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isFinite.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isFunction.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isLength.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isMatch.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isMatchWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isNaN.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isNative.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isNil.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isNull.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isNumber.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isObjectLike.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isPlainObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isSafeInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isSymbol.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isTypedArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isUndefined.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isWeakMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/isWeakSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/iteratee.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/join.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/juxt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/kebabCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/keyBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/keys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/keysIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lang.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/last.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lastIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lastIndexOfFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lowerCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lowerFirst.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/lte.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/map.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mapKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mapValues.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/matches.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/matchesProperty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/math.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/max.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/maxBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mean.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/meanBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/memoize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/merge.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mergeAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mergeAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mergeWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/method.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/methodOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/min.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/minBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/mixin.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/multiply.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/nAry.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/negate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/next.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/noop.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/now.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/nth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/nthArg.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/number.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/object.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/omit.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/omitAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/omitBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/once.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/orderBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/over.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/overArgs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/overEvery.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/overSome.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pad.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/padChars.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/padCharsEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/padCharsStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/padEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/padStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/parseInt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/partial.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/partialRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/partition.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/path.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pathEq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pathOr.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/paths.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pick.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pickAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pickBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pipe.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/placeholder.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/plant.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pluck.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/prop.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/propEq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/propOr.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/property.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/propertyOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/props.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pull.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pullAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pullAllBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pullAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/pullAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/random.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/range.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/rangeRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/rangeStep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/rangeStepRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/rearg.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/reduce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/reduceRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/reject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/remove.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/repeat.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/replace.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/rest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/restFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/result.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/reverse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/round.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sample.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sampleSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/seq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/set.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/setWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/shuffle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/size.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/slice.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/snakeCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/some.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedIndexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedLastIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedLastIndexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedLastIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedUniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sortedUniqBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/split.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/spread.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/spreadFrom.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/startCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/startsWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/string.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/stubArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/stubFalse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/stubObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/stubString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/stubTrue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/subtract.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sum.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/sumBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/symmetricDifference.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/symmetricDifferenceBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/symmetricDifferenceWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/tail.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/take.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/takeLast.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/takeLastWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/takeRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/takeRightWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/takeWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/tap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/template.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/templateSettings.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/throttle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/thru.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/times.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toFinite.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toIterator.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toJSON.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toLength.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toLower.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toNumber.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toPairsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toPlainObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toSafeInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/toUpper.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/transform.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trim.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trimChars.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trimCharsEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trimCharsStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trimEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/trimStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/truncate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unapply.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unary.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unescape.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/union.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unionBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unionWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/uniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/uniqBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/uniqWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/uniqueId.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unnest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unset.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unzip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/unzipWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/update.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/updateWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/upperCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/upperFirst.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/useWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/util.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/value.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/valueOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/values.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/valuesIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/where.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/whereEq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/without.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/words.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrapperAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrapperChain.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrapperLodash.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrapperReverse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/wrapperValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/xor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/xorBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/xorWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zipAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zipObj.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zipObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zipObjectDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fp/zipWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/fromPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/function.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/functions.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/functionsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/get.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/groupBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/gt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/gte.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/has.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/hasIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/head.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/identity.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/inRange.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/includes.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/index.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/indexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/initial.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/intersection.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/intersectionBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/intersectionWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/invert.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/invertBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/invoke.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/invokeMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isArguments.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isArrayBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isArrayLike.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isArrayLikeObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isBoolean.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isBuffer.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isDate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isElement.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isEmpty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isEqual.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isEqualWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isError.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isFinite.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isFunction.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isLength.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isMatch.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isMatchWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isNaN.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isNative.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isNil.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isNull.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isNumber.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isObjectLike.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isPlainObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isRegExp.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isSafeInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isSymbol.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isTypedArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isUndefined.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isWeakMap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/isWeakSet.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/iteratee.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/join.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/kebabCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/keyBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/keys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/keysIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lang.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/last.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lastIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lodash.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lodash.min.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lowerCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lowerFirst.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/lte.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/map.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/mapKeys.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/mapValues.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/matches.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/matchesProperty.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/math.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/max.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/maxBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/mean.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/meanBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/memoize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/merge.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/mergeWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/method.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/methodOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/min.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/minBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/mixin.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/multiply.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/negate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/next.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/noop.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/now.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/nth.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/nthArg.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/number.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/object.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/omit.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/omitBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/once.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/orderBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/over.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/overArgs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/overEvery.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/overSome.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/package.json create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pad.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/padEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/padStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/parseInt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/partial.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/partialRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/partition.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pick.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pickBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/plant.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/property.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/propertyOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pull.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pullAll.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pullAllBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pullAllWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/pullAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/random.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/range.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/rangeRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/rearg.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/reduce.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/reduceRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/reject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/release.md create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/remove.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/repeat.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/replace.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/rest.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/result.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/reverse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/round.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sample.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sampleSize.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/seq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/set.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/setWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/shuffle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/size.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/slice.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/snakeCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/some.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedIndexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedLastIndex.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedLastIndexBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedLastIndexOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedUniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sortedUniqBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/split.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/spread.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/startCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/startsWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/string.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/stubArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/stubFalse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/stubObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/stubString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/stubTrue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/subtract.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sum.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/sumBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/tail.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/take.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/takeRight.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/takeRightWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/takeWhile.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/tap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/template.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/templateSettings.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/throttle.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/thru.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/times.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toArray.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toFinite.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toIterator.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toJSON.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toLength.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toLower.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toNumber.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toPairs.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toPairsIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toPath.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toPlainObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toSafeInteger.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toString.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/toUpper.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/transform.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/trim.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/trimEnd.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/trimStart.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/truncate.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unary.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unescape.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/union.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unionBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unionWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/uniq.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/uniqBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/uniqWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/uniqueId.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unset.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unzip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/unzipWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/update.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/updateWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/upperCase.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/upperFirst.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/util.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/value.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/valueOf.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/values.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/valuesIn.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/without.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/words.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrap.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrapperAt.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrapperChain.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrapperLodash.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrapperReverse.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/wrapperValue.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/xor.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/xorBy.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/xorWith.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/zip.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/zipObject.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/zipObjectDeep.js create mode 100644 node_modules/.pnpm/lodash@4.17.21/node_modules/lodash/zipWith.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/.gitattributes create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/.github/workflows/build-and-test.yml create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/.github/workflows/static-webapp.yml create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/.prettierignore create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/LICENSE create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/README.md create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/commitlint.config.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/index.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/index.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/index.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/index.spec.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/index.spec.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/pattern-tree.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/pattern-tree.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/pattern-tree.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/toHex.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/toHex.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/toHex.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/tree.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/tree.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/tree.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/tree.spec.d.ts create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/dist/model/tree.spec.d.ts.map create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/jest.config.js create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/package.json create mode 100644 node_modules/.pnpm/magic-bytes.js@1.10.0/node_modules/magic-bytes.js/tsconfig.json create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/LICENSE create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/README.md create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/bun/index.d.ts create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/bun/index.js create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/bun/index.js.map create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/cjs/index.d.ts create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/cjs/index.js create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/index.d.ts create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/dist/index.mjs create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/package.json create mode 100644 node_modules/.pnpm/memoirist@0.3.0/node_modules/memoirist/src/index.ts create mode 120000 node_modules/.pnpm/node_modules/@discordjs/builders create mode 120000 node_modules/.pnpm/node_modules/@discordjs/collection create mode 120000 node_modules/.pnpm/node_modules/@discordjs/formatters create mode 120000 node_modules/.pnpm/node_modules/@discordjs/rest create mode 120000 node_modules/.pnpm/node_modules/@discordjs/util create mode 120000 node_modules/.pnpm/node_modules/@discordjs/ws create mode 120000 node_modules/.pnpm/node_modules/@sapphire/async-queue create mode 120000 node_modules/.pnpm/node_modules/@sapphire/shapeshift create mode 120000 node_modules/.pnpm/node_modules/@sapphire/snowflake create mode 120000 node_modules/.pnpm/node_modules/@sinclair/typebox create mode 120000 node_modules/.pnpm/node_modules/@types/node create mode 120000 node_modules/.pnpm/node_modules/@types/ws create mode 120000 node_modules/.pnpm/node_modules/@vladfrangu/async_event_emitter create mode 120000 node_modules/.pnpm/node_modules/cookie create mode 120000 node_modules/.pnpm/node_modules/discord-api-types create mode 120000 node_modules/.pnpm/node_modules/fast-deep-equal create mode 120000 node_modules/.pnpm/node_modules/lodash create mode 120000 node_modules/.pnpm/node_modules/lodash.snakecase create mode 120000 node_modules/.pnpm/node_modules/magic-bytes.js create mode 120000 node_modules/.pnpm/node_modules/memoirist create mode 120000 node_modules/.pnpm/node_modules/ts-mixer create mode 120000 node_modules/.pnpm/node_modules/tslib create mode 120000 node_modules/.pnpm/node_modules/undici create mode 120000 node_modules/.pnpm/node_modules/undici-types create mode 120000 node_modules/.pnpm/node_modules/ws create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/CHANGELOG.md create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/LICENSE create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/README.md create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/decorator.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/index.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/mixin-tracking.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/mixins.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/proxy.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/settings.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/types.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/cjs/util.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/decorator.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/index.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/index.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/index.min.js create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/mixin-tracking.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/mixins.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/proxy.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/settings.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/types.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/esm/util.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/decorator.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/index.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/mixin-tracking.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/mixins.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/proxy.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/settings.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/types.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/dist/types/util.d.ts create mode 100644 node_modules/.pnpm/ts-mixer@6.0.4/node_modules/ts-mixer/package.json create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/CopyrightNotice.txt create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/LICENSE.txt create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/README.md create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/SECURITY.md create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/modules/index.d.ts create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/modules/index.js create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/modules/package.json create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/package.json create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.d.ts create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.html create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.js create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.es6.mjs create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.html create mode 100644 node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.js create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/LICENSE create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/README.md create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/agent.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/api.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/balanced-pool.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cache.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/client.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/connector.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/content-type.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cookies.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/diagnostics-channel.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/dispatcher.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/env-http-proxy-agent.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/errors.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/eventsource.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/fetch.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/file.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/filereader.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/formdata.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-dispatcher.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-origin.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/handlers.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/header.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/index.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/interceptors.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-agent.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-client.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-errors.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-interceptor.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-pool.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/package.json create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/patch.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool-stats.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/proxy-agent.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/readable.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-agent.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-handler.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/util.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/webidl.d.ts create mode 100644 node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/websocket.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/LICENSE create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/README.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Agent.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/BalancedPool.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/CacheStorage.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Client.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Connector.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/ContentType.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Cookies.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Debug.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/DiagnosticsChannel.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/DispatchInterceptor.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Dispatcher.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/EnvHttpProxyAgent.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Errors.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/EventSource.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Fetch.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/MockAgent.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/MockClient.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/MockErrors.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/MockPool.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Pool.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/PoolStats.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/ProxyAgent.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/RedirectHandler.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/RetryAgent.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/RetryHandler.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/Util.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/WebSocket.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/api/api-lifecycle.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/best-practices/client-certificate.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/best-practices/mocking-request.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/best-practices/proxy.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/docs/docs/best-practices/writing-tests.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/index-fetch.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/index.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/index.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/abort-signal.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/api-connect.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/api-pipeline.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/api-request.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/api-stream.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/api-upgrade.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/index.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/readable.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/api/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/connect.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/constants.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/diagnostics.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/errors.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/request.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/tree.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/core/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/agent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/balanced-pool.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/client-h1.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/client-h2.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/client.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/dispatcher-base.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/dispatcher.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/fixed-queue.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/pool-base.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/pool-stats.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/pool.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/proxy-agent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/dispatcher/retry-agent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/global.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/handler/decorator-handler.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/handler/redirect-handler.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/handler/retry-handler.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/dns.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/dump.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/redirect-interceptor.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/redirect.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/response-error.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/interceptor/retry.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/llhttp/.gitkeep create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/llhttp/constants.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/llhttp/llhttp-wasm.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/llhttp/utils.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-agent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-client.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-errors.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-interceptor.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-pool.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/mock-utils.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/pending-interceptors-formatter.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/mock/pluralizer.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/util/timers.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cache/cache.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cache/cachestorage.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cache/symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cache/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cookies/constants.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cookies/index.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cookies/parse.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/cookies/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/eventsource/eventsource-stream.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/eventsource/eventsource.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/eventsource/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/LICENSE create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/body.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/constants.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/data-url.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/dispatcher-weakref.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/file.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/formdata-parser.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/formdata.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/global.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/headers.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/index.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/request.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/response.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fetch/webidl.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fileapi/encoding.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fileapi/filereader.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fileapi/progressevent.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fileapi/symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/fileapi/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/connection.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/constants.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/events.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/frame.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/permessage-deflate.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/receiver.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/sender.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/symbols.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/util.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/lib/web/websocket/websocket.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/package.json create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/scripts/strip-comments.js create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/README.md create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/agent.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/api.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/balanced-pool.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/cache.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/client.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/connector.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/content-type.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/cookies.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/diagnostics-channel.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/dispatcher.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/env-http-proxy-agent.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/errors.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/eventsource.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/fetch.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/file.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/filereader.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/formdata.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/global-dispatcher.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/global-origin.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/handlers.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/header.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/index.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/interceptors.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/mock-agent.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/mock-client.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/mock-errors.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/mock-interceptor.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/mock-pool.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/patch.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/pool-stats.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/pool.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/proxy-agent.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/readable.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/retry-agent.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/retry-handler.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/util.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/webidl.d.ts create mode 100644 node_modules/.pnpm/undici@6.21.1/node_modules/undici/types/websocket.d.ts create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/LICENSE create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/README.md create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/browser.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/index.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/buffer-util.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/constants.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/event-target.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/extension.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/limiter.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/permessage-deflate.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/receiver.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/sender.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/stream.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/subprotocol.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/validation.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/websocket-server.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/lib/websocket.js create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/package.json create mode 100644 node_modules/.pnpm/ws@8.18.1/node_modules/ws/wrapper.mjs create mode 120000 node_modules/bun-types create mode 120000 node_modules/discord.js create mode 120000 node_modules/elysia create mode 100644 package.json create mode 100644 pnpm-lock.yaml create mode 100644 src/boredBot/commands.ts create mode 100644 src/boredBot/index.ts create mode 100644 src/diceRoller/index.ts create mode 100644 src/diceRoller/types.ts create mode 100644 src/diceRoller/utils/handleRollCommand.ts create mode 100644 src/diceRoller/utils/parseDiceUserInput.ts create mode 100644 src/discordBot/index.ts create mode 100644 src/discordBot/types.ts create mode 100644 src/index.ts create mode 100644 tsconfig.json create mode 100644 wps/compose.yml create mode 100644 wps/todo.md diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 0000000..4ab91c1 --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,22 @@ +{ + "name": "Bun Development Container", + "image": "ghcr.io/nhaef/devcontainer-bun:latest", + "features": { + "ghcr.io/devcontainers/features/common-utils:2": { + "installZsh": true, + "installOhMyZsh": true, + "configureZshAsDefaultShell": true + } + }, + "customizations": { + "vscode": { + "extensions": [ + "ms-vscode.cpptools", + "ms-python.python", + "esbenp.prettier-vscode" + ] + } + }, + "remoteUser": "vscode", + "postCreateCommand": "sudo chown -R vscode:vscode /workspaces/DiscordBots && sudo chown -R vscode:vscode /workspaces/DiscordBots/node_modules || true" +} diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..8cd355e --- /dev/null +++ b/Dockerfile @@ -0,0 +1,32 @@ +FROM oven/bun AS build + +WORKDIR /app + +COPY package.json package.json +COPY bun.lock bun.lock + +RUN bun install + +COPY ./src ./src + +ENV NODE_ENV=production + +RUN bun build \ + --compile \ + --minify-whitespace \ + --minify-syntax \ + --target bun \ + --outfile server \ + ./src/index.ts + +FROM gcr.io/distroless/base + +WORKDIR /app + +COPY --from=build /app/server server + +ENV NODE_ENV=production + +CMD ["./server"] + +EXPOSE 3000 diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..e38d297 --- /dev/null +++ b/Makefile @@ -0,0 +1,22 @@ +# Makefile + +BW_PROJECT_NAME=BoredGods.dev +BW_PROJECT_ID=9d72d613-8d1f-4455-8676-b2c10167aa94 +BW_DOMAIN=https://vault.bitwarden.eu + +run: + @if ! command -v bws >/dev/null 2>&1; then \ + echo "Error: bws is not installed."; \ + exit 1; \ + fi + + @if [ -z "$$BWS_ACCESS_TOKEN" ]; then \ + echo "Error: BWS_ACCESS_TOKEN environment variable is not set."; \ + exit 1; \ + fi + + @bws config server-base $(BW_DOMAIN) + @echo "Set EU connection $(BW_DOMAIN)" + + @echo "Starting app with project ${BW_PROJECT_NAME}" + @bws run --project-id $(BW_PROJECT_ID) -- bun src/index.ts diff --git a/node_modules/.modules.yaml b/node_modules/.modules.yaml new file mode 100644 index 0000000..caec233 --- /dev/null +++ b/node_modules/.modules.yaml @@ -0,0 +1,70 @@ +hoistPattern: + - '*' +hoistedDependencies: + '@discordjs/builders@1.10.1': + '@discordjs/builders': private + '@discordjs/collection@1.5.3': + '@discordjs/collection': private + '@discordjs/formatters@0.6.0': + '@discordjs/formatters': private + '@discordjs/rest@2.4.3': + '@discordjs/rest': private + '@discordjs/util@1.1.1': + '@discordjs/util': private + '@discordjs/ws@1.2.1': + '@discordjs/ws': private + '@sapphire/async-queue@1.5.5': + '@sapphire/async-queue': private + '@sapphire/shapeshift@4.0.0': + '@sapphire/shapeshift': private + '@sapphire/snowflake@3.5.3': + '@sapphire/snowflake': private + '@sinclair/typebox@0.34.33': + '@sinclair/typebox': private + '@types/node@22.14.1': + '@types/node': private + '@types/ws@8.18.1': + '@types/ws': private + '@vladfrangu/async_event_emitter@2.4.6': + '@vladfrangu/async_event_emitter': private + cookie@1.0.2: + cookie: private + discord-api-types@0.37.120: + discord-api-types: private + fast-deep-equal@3.1.3: + fast-deep-equal: private + lodash.snakecase@4.1.1: + lodash.snakecase: private + lodash@4.17.21: + lodash: private + magic-bytes.js@1.10.0: + magic-bytes.js: private + memoirist@0.3.0: + memoirist: private + ts-mixer@6.0.4: + ts-mixer: private + tslib@2.8.1: + tslib: private + undici-types@6.21.0: + undici-types: private + undici@6.21.1: + undici: private + ws@8.18.1: + ws: private +included: + dependencies: true + devDependencies: true + optionalDependencies: true +injectedDeps: {} +layoutVersion: 5 +nodeLinker: isolated +packageManager: pnpm@10.8.0 +pendingBuilds: [] +prunedAt: Sat, 03 May 2025 09:46:29 GMT +publicHoistPattern: [] +registries: + default: https://registry.npmjs.org/ +skipped: [] +storeDir: /Users/jensbech-sorensen/Library/pnpm/store/v10 +virtualStoreDir: .pnpm +virtualStoreDirMaxLength: 120 diff --git a/node_modules/.pnpm-workspace-state.json b/node_modules/.pnpm-workspace-state.json new file mode 100644 index 0000000..9e8d8b5 --- /dev/null +++ b/node_modules/.pnpm-workspace-state.json @@ -0,0 +1,25 @@ +{ + "lastValidatedTimestamp": 1746265589700, + "projects": {}, + "pnpmfileExists": false, + "settings": { + "autoInstallPeers": true, + "dedupeDirectDeps": false, + "dedupeInjectedDeps": true, + "dedupePeerDependents": true, + "dev": true, + "excludeLinksFromLockfile": false, + "hoistPattern": [ + "*" + ], + "hoistWorkspacePackages": true, + "injectWorkspacePackages": false, + "linkWorkspacePackages": false, + "nodeLinker": "isolated", + "optional": true, + "preferWorkspacePackages": false, + "production": true, + "publicHoistPattern": [] + }, + "filteredInstall": false +} diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/LICENSE b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/LICENSE new file mode 100644 index 0000000..cbe9c65 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/LICENSE @@ -0,0 +1,191 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + Copyright 2021 Noel Buechler + Copyright 2021 Vlad Frangu + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/README.md b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/README.md new file mode 100644 index 0000000..dc88b7f --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/README.md @@ -0,0 +1,72 @@ +
+
+

+ discord.js +

+
+

+ Discord server + npm version + npm downloads + Build status + Code coverage +

+

+ Vercel + Cloudflare Workers +

+
+ +## About + +`@discordjs/builders` is a utility package for easily building Discord API payloads. + +## Installation + +**Node.js 16.11.0 or newer is required.** + +```sh +npm install @discordjs/builders +yarn add @discordjs/builders +pnpm add @discordjs/builders +``` + +## Examples + +You can find examples of how to use the builders in the [Slash Command Builders][example] examples. + +## Links + +- [Website][website] ([source][website-source]) +- [Documentation][documentation] +- [Guide][guide] ([source][guide-source]) + Also see the v13 to v14 [Update Guide][guide-update], which includes updated and removed items from the library. +- [discord.js Discord server][discord] +- [Discord API Discord server][discord-api] +- [GitHub][source] +- [npm][npm] +- [Related libraries][related-libs] + +## Contributing + +Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the +[documentation][documentation]. +See [the contribution guide][contributing] if you'd like to submit a PR. + +## Help + +If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official [discord.js Server][discord]. + +[example]: https://github.com/discordjs/discord.js/blob/main/packages/builders/docs/examples/Slash%20Command%20Builders.md +[website]: https://discord.js.org +[website-source]: https://github.com/discordjs/discord.js/tree/main/apps/website +[documentation]: https://discord.js.org/docs/packages/builders/stable +[guide]: https://discordjs.guide/ +[guide-source]: https://github.com/discordjs/guide +[guide-update]: https://discordjs.guide/additional-info/changes-in-v14.html +[discord]: https://discord.gg/djs +[discord-api]: https://discord.gg/discord-api +[source]: https://github.com/discordjs/discord.js/tree/main/packages/builders +[npm]: https://www.npmjs.com/package/@discordjs/builders +[related-libs]: https://discord.com/developers/docs/topics/community-resources#libraries +[contributing]: https://github.com/discordjs/discord.js/blob/main/.github/CONTRIBUTING.md diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.mts b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.mts new file mode 100644 index 0000000..ac28cd2 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.mts @@ -0,0 +1,2043 @@ +import * as _sapphire_shapeshift from '@sapphire/shapeshift'; +import { APIEmbedField, APIEmbedAuthor, APIEmbedFooter, APIEmbedImage, APIEmbed, APISelectMenuOption, APIMessageComponentEmoji, ButtonStyle, ChannelType, APIActionRowComponent, APIActionRowComponentTypes, APIBaseComponent, ComponentType, APIButtonComponent, Snowflake, APISelectMenuComponent, APIChannelSelectComponent, APIMentionableSelectComponent, APISelectMenuDefaultValue, SelectMenuDefaultValueType, APIRoleSelectComponent, APIStringSelectComponent, APIUserSelectComponent, APITextInputComponent, TextInputStyle, APIMessageActionRowComponent, APIModalActionRowComponent, APIModalComponent, APIMessageComponent, APIModalInteractionResponseCallbackData, LocalizationMap, LocaleString, InteractionContextType, Permissions, ApplicationIntegrationType, RESTPostAPIChatInputApplicationCommandsJSONBody, ApplicationCommandOptionType, APIApplicationCommandBasicOption, APIApplicationCommandAttachmentOption, APIApplicationCommandBooleanOption, APIApplicationCommandChannelOption, APIApplicationCommandOptionChoice, APIApplicationCommandIntegerOption, APIApplicationCommandMentionableOption, APIApplicationCommandNumberOption, APIApplicationCommandRoleOption, APIApplicationCommandStringOption, APIApplicationCommandUserOption, APIApplicationCommandSubcommandGroupOption, APIApplicationCommandSubcommandOption, APIApplicationCommandOption, Locale, ApplicationCommandType, RESTPostAPIContextMenuApplicationCommandsJSONBody } from 'discord-api-types/v10'; +export * from '@discordjs/formatters'; +import { JSONEncodable, Equatable } from '@discordjs/util'; + +declare const fieldNamePredicate: _sapphire_shapeshift.StringValidator; +declare const fieldValuePredicate: _sapphire_shapeshift.StringValidator; +declare const fieldInlinePredicate: _sapphire_shapeshift.UnionValidator; +declare const embedFieldPredicate: _sapphire_shapeshift.ObjectValidator<{ + name: string; + value: string; + inline: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>>; +declare const embedFieldsArrayPredicate: _sapphire_shapeshift.ArrayValidator<_sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>[], _sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>>; +declare const fieldLengthPredicate: _sapphire_shapeshift.NumberValidator; +declare function validateFieldLength(amountAdding: number, fields?: APIEmbedField[]): void; +declare const authorNamePredicate: _sapphire_shapeshift.UnionValidator; +declare const imageURLPredicate: _sapphire_shapeshift.UnionValidator; +declare const urlPredicate: _sapphire_shapeshift.UnionValidator; +declare const embedAuthorPredicate: _sapphire_shapeshift.ObjectValidator<{ + name: string | null; + iconURL: string | null | undefined; + url: string | null | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name: string | null; + iconURL: string | null | undefined; + url: string | null | undefined; +}>>; +declare const RGBPredicate: _sapphire_shapeshift.NumberValidator; +declare const colorPredicate: _sapphire_shapeshift.UnionValidator; +declare const descriptionPredicate: _sapphire_shapeshift.UnionValidator; +declare const footerTextPredicate: _sapphire_shapeshift.UnionValidator; +declare const embedFooterPredicate: _sapphire_shapeshift.ObjectValidator<{ + text: string | null; + iconURL: string | null | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + text: string | null; + iconURL: string | null | undefined; +}>>; +declare const timestampPredicate: _sapphire_shapeshift.UnionValidator; +declare const titlePredicate: _sapphire_shapeshift.UnionValidator; + +declare const Assertions$5_RGBPredicate: typeof RGBPredicate; +declare const Assertions$5_authorNamePredicate: typeof authorNamePredicate; +declare const Assertions$5_colorPredicate: typeof colorPredicate; +declare const Assertions$5_descriptionPredicate: typeof descriptionPredicate; +declare const Assertions$5_embedAuthorPredicate: typeof embedAuthorPredicate; +declare const Assertions$5_embedFieldPredicate: typeof embedFieldPredicate; +declare const Assertions$5_embedFieldsArrayPredicate: typeof embedFieldsArrayPredicate; +declare const Assertions$5_embedFooterPredicate: typeof embedFooterPredicate; +declare const Assertions$5_fieldInlinePredicate: typeof fieldInlinePredicate; +declare const Assertions$5_fieldLengthPredicate: typeof fieldLengthPredicate; +declare const Assertions$5_fieldNamePredicate: typeof fieldNamePredicate; +declare const Assertions$5_fieldValuePredicate: typeof fieldValuePredicate; +declare const Assertions$5_footerTextPredicate: typeof footerTextPredicate; +declare const Assertions$5_imageURLPredicate: typeof imageURLPredicate; +declare const Assertions$5_timestampPredicate: typeof timestampPredicate; +declare const Assertions$5_titlePredicate: typeof titlePredicate; +declare const Assertions$5_urlPredicate: typeof urlPredicate; +declare const Assertions$5_validateFieldLength: typeof validateFieldLength; +declare namespace Assertions$5 { + export { Assertions$5_RGBPredicate as RGBPredicate, Assertions$5_authorNamePredicate as authorNamePredicate, Assertions$5_colorPredicate as colorPredicate, Assertions$5_descriptionPredicate as descriptionPredicate, Assertions$5_embedAuthorPredicate as embedAuthorPredicate, Assertions$5_embedFieldPredicate as embedFieldPredicate, Assertions$5_embedFieldsArrayPredicate as embedFieldsArrayPredicate, Assertions$5_embedFooterPredicate as embedFooterPredicate, Assertions$5_fieldInlinePredicate as fieldInlinePredicate, Assertions$5_fieldLengthPredicate as fieldLengthPredicate, Assertions$5_fieldNamePredicate as fieldNamePredicate, Assertions$5_fieldValuePredicate as fieldValuePredicate, Assertions$5_footerTextPredicate as footerTextPredicate, Assertions$5_imageURLPredicate as imageURLPredicate, Assertions$5_timestampPredicate as timestampPredicate, Assertions$5_titlePredicate as titlePredicate, Assertions$5_urlPredicate as urlPredicate, Assertions$5_validateFieldLength as validateFieldLength }; +} + +/** + * Normalizes data that is a rest parameter or an array into an array with a depth of 1. + * + * @typeParam ItemType - The data that must satisfy {@link RestOrArray}. + * @param arr - The (possibly variadic) data to normalize + */ +declare function normalizeArray(arr: RestOrArray): ItemType[]; +/** + * Represents data that may be an array or came from a rest parameter. + * + * @remarks + * This type is used throughout builders to ensure both an array and variadic arguments + * may be used. It is normalized with {@link normalizeArray}. + */ +type RestOrArray = Type[] | [Type[]]; + +/** + * A tuple satisfying the RGB color model. + * + * @see {@link https://developer.mozilla.org/docs/Glossary/RGB} + */ +type RGBTuple = [red: number, green: number, blue: number]; +/** + * The base icon data typically used in payloads. + */ +interface IconData { + /** + * The URL of the icon. + */ + iconURL?: string; + /** + * The proxy URL of the icon. + */ + proxyIconURL?: string; +} +/** + * Represents the author data of an embed. + */ +interface EmbedAuthorData extends IconData, Omit { +} +/** + * Represents the author options of an embed. + */ +interface EmbedAuthorOptions extends Omit { +} +/** + * Represents the footer data of an embed. + */ +interface EmbedFooterData extends IconData, Omit { +} +/** + * Represents the footer options of an embed. + */ +interface EmbedFooterOptions extends Omit { +} +/** + * Represents the image data of an embed. + */ +interface EmbedImageData extends Omit { + /** + * The proxy URL for the image. + */ + proxyURL?: string; +} +/** + * A builder that creates API-compatible JSON data for embeds. + */ +declare class EmbedBuilder { + /** + * The API data associated with this embed. + */ + readonly data: APIEmbed; + /** + * Creates a new embed from API data. + * + * @param data - The API data to create this embed with + */ + constructor(data?: APIEmbed); + /** + * Appends fields to the embed. + * + * @remarks + * This method accepts either an array of fields or a variable number of field parameters. + * The maximum amount of fields that can be added is 25. + * @example + * Using an array: + * ```ts + * const fields: APIEmbedField[] = ...; + * const embed = new EmbedBuilder() + * .addFields(fields); + * ``` + * @example + * Using rest parameters (variadic): + * ```ts + * const embed = new EmbedBuilder() + * .addFields( + * { name: 'Field 1', value: 'Value 1' }, + * { name: 'Field 2', value: 'Value 2' }, + * ); + * ``` + * @param fields - The fields to add + */ + addFields(...fields: RestOrArray): this; + /** + * Removes, replaces, or inserts fields for this embed. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}. + * The maximum amount of fields that can be added is 25. + * + * It's useful for modifying and adjusting order of the already-existing fields of an embed. + * @example + * Remove the first field: + * ```ts + * embed.spliceFields(0, 1); + * ``` + * @example + * Remove the first n fields: + * ```ts + * const n = 4; + * embed.spliceFields(0, n); + * ``` + * @example + * Remove the last field: + * ```ts + * embed.spliceFields(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of fields to remove + * @param fields - The replacing field objects + */ + spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this; + /** + * Sets the fields for this embed. + * + * @remarks + * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically, + * it splices the entire array of fields, replacing them with the provided fields. + * + * You can set a maximum of 25 fields. + * @param fields - The fields to set + */ + setFields(...fields: RestOrArray): this; + /** + * Sets the author of this embed. + * + * @param options - The options to use + */ + setAuthor(options: EmbedAuthorOptions | null): this; + /** + * Sets the color of this embed. + * + * @param color - The color to use + */ + setColor(color: RGBTuple | number | null): this; + /** + * Sets the description of this embed. + * + * @param description - The description to use + */ + setDescription(description: string | null): this; + /** + * Sets the footer of this embed. + * + * @param options - The footer to use + */ + setFooter(options: EmbedFooterOptions | null): this; + /** + * Sets the image of this embed. + * + * @param url - The image URL to use + */ + setImage(url: string | null): this; + /** + * Sets the thumbnail of this embed. + * + * @param url - The thumbnail URL to use + */ + setThumbnail(url: string | null): this; + /** + * Sets the timestamp of this embed. + * + * @param timestamp - The timestamp or date to use + */ + setTimestamp(timestamp?: Date | number | null): this; + /** + * Sets the title for this embed. + * + * @param title - The title to use + */ + setTitle(title: string | null): this; + /** + * Sets the URL of this embed. + * + * @param url - The URL to use + */ + setURL(url: string | null): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIEmbed; +} + +/** + * A builder that creates API-compatible JSON data for string select menu options. + */ +declare class StringSelectMenuOptionBuilder implements JSONEncodable { + data: Partial; + /** + * Creates a new string select menu option from API data. + * + * @param data - The API data to create this string select menu option with + * @example + * Creating a string select menu option from an API data object: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * label: 'catchy label', + * value: '1', + * }); + * ``` + * @example + * Creating a string select menu option using setters and API data: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * default: true, + * value: '1', + * }) + * .setLabel('woah'); + * ``` + */ + constructor(data?: Partial); + /** + * Sets the label for this option. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * Sets the value for this option. + * + * @param value - The value to use + */ + setValue(value: string): this; + /** + * Sets the description for this option. + * + * @param description - The description to use + */ + setDescription(description: string): this; + /** + * Sets whether this option is selected by default. + * + * @param isDefault - Whether this option is selected by default + */ + setDefault(isDefault?: boolean): this; + /** + * Sets the emoji to display for this option. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji: APIMessageComponentEmoji): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APISelectMenuOption; +} + +declare const customIdValidator: _sapphire_shapeshift.StringValidator; +declare const emojiValidator: _sapphire_shapeshift.ObjectValidator<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; +}>>; +declare const disabledValidator: _sapphire_shapeshift.BooleanValidator; +declare const buttonLabelValidator: _sapphire_shapeshift.StringValidator; +declare const buttonStyleValidator: _sapphire_shapeshift.NativeEnumValidator; +declare const placeholderValidator$1: _sapphire_shapeshift.StringValidator; +declare const minMaxValidator: _sapphire_shapeshift.NumberValidator; +declare const labelValueDescriptionValidator: _sapphire_shapeshift.StringValidator; +declare const jsonOptionValidator: _sapphire_shapeshift.ObjectValidator<{ + label: string; + value: string; + description: string | undefined; + emoji: _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; + }> | undefined; + default: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + label: string; + value: string; + description: string | undefined; + emoji: _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; + }> | undefined; + default: boolean | undefined; +}>>; +declare const optionValidator: _sapphire_shapeshift.InstanceValidator; +declare const optionsValidator: _sapphire_shapeshift.ArrayValidator; +declare const optionsLengthValidator: _sapphire_shapeshift.NumberValidator; +declare function validateRequiredSelectMenuParameters(options: StringSelectMenuOptionBuilder[], customId?: string): void; +declare const defaultValidator: _sapphire_shapeshift.BooleanValidator; +declare function validateRequiredSelectMenuOptionParameters(label?: string, value?: string): void; +declare const channelTypesValidator: _sapphire_shapeshift.ArrayValidator; +declare const urlValidator: _sapphire_shapeshift.StringValidator; +declare function validateRequiredButtonParameters(style?: ButtonStyle, label?: string, emoji?: APIMessageComponentEmoji, customId?: string, skuId?: string, url?: string): void; + +declare const Assertions$4_buttonLabelValidator: typeof buttonLabelValidator; +declare const Assertions$4_buttonStyleValidator: typeof buttonStyleValidator; +declare const Assertions$4_channelTypesValidator: typeof channelTypesValidator; +declare const Assertions$4_customIdValidator: typeof customIdValidator; +declare const Assertions$4_defaultValidator: typeof defaultValidator; +declare const Assertions$4_disabledValidator: typeof disabledValidator; +declare const Assertions$4_emojiValidator: typeof emojiValidator; +declare const Assertions$4_jsonOptionValidator: typeof jsonOptionValidator; +declare const Assertions$4_labelValueDescriptionValidator: typeof labelValueDescriptionValidator; +declare const Assertions$4_minMaxValidator: typeof minMaxValidator; +declare const Assertions$4_optionValidator: typeof optionValidator; +declare const Assertions$4_optionsLengthValidator: typeof optionsLengthValidator; +declare const Assertions$4_optionsValidator: typeof optionsValidator; +declare const Assertions$4_urlValidator: typeof urlValidator; +declare const Assertions$4_validateRequiredButtonParameters: typeof validateRequiredButtonParameters; +declare const Assertions$4_validateRequiredSelectMenuOptionParameters: typeof validateRequiredSelectMenuOptionParameters; +declare const Assertions$4_validateRequiredSelectMenuParameters: typeof validateRequiredSelectMenuParameters; +declare namespace Assertions$4 { + export { Assertions$4_buttonLabelValidator as buttonLabelValidator, Assertions$4_buttonStyleValidator as buttonStyleValidator, Assertions$4_channelTypesValidator as channelTypesValidator, Assertions$4_customIdValidator as customIdValidator, Assertions$4_defaultValidator as defaultValidator, Assertions$4_disabledValidator as disabledValidator, Assertions$4_emojiValidator as emojiValidator, Assertions$4_jsonOptionValidator as jsonOptionValidator, Assertions$4_labelValueDescriptionValidator as labelValueDescriptionValidator, Assertions$4_minMaxValidator as minMaxValidator, Assertions$4_optionValidator as optionValidator, Assertions$4_optionsLengthValidator as optionsLengthValidator, Assertions$4_optionsValidator as optionsValidator, placeholderValidator$1 as placeholderValidator, Assertions$4_urlValidator as urlValidator, Assertions$4_validateRequiredButtonParameters as validateRequiredButtonParameters, Assertions$4_validateRequiredSelectMenuOptionParameters as validateRequiredSelectMenuOptionParameters, Assertions$4_validateRequiredSelectMenuParameters as validateRequiredSelectMenuParameters }; +} + +/** + * Any action row component data represented as an object. + */ +type AnyAPIActionRowComponent = APIActionRowComponent | APIActionRowComponentTypes; +/** + * The base component builder that contains common symbols for all sorts of components. + * + * @typeParam DataType - The type of internal API data that is stored within the component + */ +declare abstract class ComponentBuilder> = APIBaseComponent> implements JSONEncodable { + /** + * The API data associated with this component. + */ + readonly data: Partial; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + abstract toJSON(): AnyAPIActionRowComponent; + /** + * Constructs a new kind of component. + * + * @param data - The data to construct a component out of + */ + constructor(data: Partial); +} + +/** + * A builder that creates API-compatible JSON data for buttons. + */ +declare class ButtonBuilder extends ComponentBuilder { + /** + * Creates a new button from API data. + * + * @param data - The API data to create this button with + * @example + * Creating a button from an API data object: + * ```ts + * const button = new ButtonBuilder({ + * custom_id: 'a cool button', + * style: ButtonStyle.Primary, + * label: 'Click Me', + * emoji: { + * name: 'smile', + * id: '123456789012345678', + * }, + * }); + * ``` + * @example + * Creating a button using setters and API data: + * ```ts + * const button = new ButtonBuilder({ + * style: ButtonStyle.Secondary, + * label: 'Click Me', + * }) + * .setEmoji({ name: '🙂' }) + * .setCustomId('another cool button'); + * ``` + */ + constructor(data?: Partial); + /** + * Sets the style of this button. + * + * @param style - The style to use + */ + setStyle(style: ButtonStyle): this; + /** + * Sets the URL for this button. + * + * @remarks + * This method is only available to buttons using the `Link` button style. + * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`. + * @param url - The URL to use + */ + setURL(url: string): this; + /** + * Sets the custom id for this button. + * + * @remarks + * This method is only applicable to buttons that are not using the `Link` button style. + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets the SKU id that represents a purchasable SKU for this button. + * + * @remarks Only available when using premium-style buttons. + * @param skuId - The SKU id to use + */ + setSKUId(skuId: Snowflake): this; + /** + * Sets the emoji to display on this button. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji: APIMessageComponentEmoji): this; + /** + * Sets whether this button is disabled. + * + * @param disabled - Whether to disable this button + */ + setDisabled(disabled?: boolean): this; + /** + * Sets the label for this button. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIButtonComponent; +} + +/** + * The base select menu builder that contains common symbols for select menu builders. + * + * @typeParam SelectMenuType - The type of select menu this would be instantiated for. + */ +declare abstract class BaseSelectMenuBuilder extends ComponentBuilder { + /** + * Sets the placeholder for this select menu. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder: string): this; + /** + * Sets the minimum values that must be selected in the select menu. + * + * @param minValues - The minimum values that must be selected + */ + setMinValues(minValues: number): this; + /** + * Sets the maximum values that must be selected in the select menu. + * + * @param maxValues - The maximum values that must be selected + */ + setMaxValues(maxValues: number): this; + /** + * Sets the custom id for this select menu. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets whether this select menu is disabled. + * + * @param disabled - Whether this select menu is disabled + */ + setDisabled(disabled?: boolean): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): SelectMenuType; +} + +/** + * A builder that creates API-compatible JSON data for channel select menus. + */ +declare class ChannelSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement) + * .setMinValues(2); + * ``` + */ + constructor(data?: Partial); + /** + * Adds channel types to this select menu. + * + * @param types - The channel types to use + */ + addChannelTypes(...types: RestOrArray): this; + /** + * Sets channel types for this select menu. + * + * @param types - The channel types to use + */ + setChannelTypes(...types: RestOrArray): this; + /** + * Adds default channels to this auto populated select menu. + * + * @param channels - The channels to add + */ + addDefaultChannels(...channels: RestOrArray): this; + /** + * Sets default channels for this auto populated select menu. + * + * @param channels - The channels to set + */ + setDefaultChannels(...channels: RestOrArray): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APIChannelSelectComponent; +} + +/** + * A builder that creates API-compatible JSON data for mentionable select menus. + */ +declare class MentionableSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles: RestOrArray): this; + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users: RestOrArray): this; + /** + * Adds default values to this auto populated select menu. + * + * @param values - The values to add + */ + addDefaultValues(...values: RestOrArray | APISelectMenuDefaultValue>): this; + /** + * Sets default values for this auto populated select menu. + * + * @param values - The values to set + */ + setDefaultValues(...values: RestOrArray | APISelectMenuDefaultValue>): this; +} + +/** + * A builder that creates API-compatible JSON data for role select menus. + */ +declare class RoleSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles: RestOrArray): this; + /** + * Sets default roles for this auto populated select menu. + * + * @param roles - The roles to set + */ + setDefaultRoles(...roles: RestOrArray): this; +} + +/** + * A builder that creates API-compatible JSON data for string select menus. + */ +declare class StringSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * The options within this select menu. + */ + readonly options: StringSelectMenuOptionBuilder[]; + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * options: [ + * { label: 'option 1', value: '1' }, + * { label: 'option 2', value: '2' }, + * { label: 'option 3', value: '3' }, + * ], + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1) + * .addOptions({ + * label: 'Catchy', + * value: 'catch', + * }); + * ``` + */ + constructor(data?: Partial); + /** + * Adds options to this select menu. + * + * @param options - The options to add + */ + addOptions(...options: RestOrArray): this; + /** + * Sets the options for this select menu. + * + * @param options - The options to set + */ + setOptions(...options: RestOrArray): this; + /** + * Removes, replaces, or inserts options for this select menu. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}. + * It's useful for modifying and adjusting the order of existing options. + * @example + * Remove the first option: + * ```ts + * selectMenu.spliceOptions(0, 1); + * ``` + * @example + * Remove the first n option: + * ```ts + * const n = 4; + * selectMenu.spliceOptions(0, n); + * ``` + * @example + * Remove the last option: + * ```ts + * selectMenu.spliceOptions(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of options to remove + * @param options - The replacing option objects or builders + */ + spliceOptions(index: number, deleteCount: number, ...options: RestOrArray): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APIStringSelectComponent; +} + +/** + * A builder that creates API-compatible JSON data for user select menus. + */ +declare class UserSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users: RestOrArray): this; + /** + * Sets default users for this auto populated select menu. + * + * @param users - The users to set + */ + setDefaultUsers(...users: RestOrArray): this; +} + +/** + * A builder that creates API-compatible JSON data for text inputs. + */ +declare class TextInputBuilder extends ComponentBuilder implements Equatable> { + /** + * Creates a new text input from API data. + * + * @param data - The API data to create this text input with + * @example + * Creating a text input from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool text input', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a text input using setters and API data: + * ```ts + * const textInput = new TextInputBuilder({ + * label: 'Type something else', + * }) + * .setCustomId('woah') + * .setStyle(TextInputStyle.Paragraph); + * ``` + */ + constructor(data?: APITextInputComponent & { + type?: ComponentType.TextInput; + }); + /** + * Sets the custom id for this text input. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets the label for this text input. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * Sets the style for this text input. + * + * @param style - The style to use + */ + setStyle(style: TextInputStyle): this; + /** + * Sets the minimum length of text for this text input. + * + * @param minLength - The minimum length of text for this text input + */ + setMinLength(minLength: number): this; + /** + * Sets the maximum length of text for this text input. + * + * @param maxLength - The maximum length of text for this text input + */ + setMaxLength(maxLength: number): this; + /** + * Sets the placeholder for this text input. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder: string): this; + /** + * Sets the value for this text input. + * + * @param value - The value to use + */ + setValue(value: string): this; + /** + * Sets whether this text input is required. + * + * @param required - Whether this text input is required + */ + setRequired(required?: boolean): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APITextInputComponent; + /** + * Whether this is equal to another structure. + */ + equals(other: APITextInputComponent | JSONEncodable): boolean; +} + +/** + * The builders that may be used for messages. + */ +type MessageComponentBuilder = ActionRowBuilder | MessageActionRowComponentBuilder; +/** + * The builders that may be used for modals. + */ +type ModalComponentBuilder = ActionRowBuilder | ModalActionRowComponentBuilder; +/** + * The builders that may be used within an action row for messages. + */ +type MessageActionRowComponentBuilder = ButtonBuilder | ChannelSelectMenuBuilder | MentionableSelectMenuBuilder | RoleSelectMenuBuilder | StringSelectMenuBuilder | UserSelectMenuBuilder; +/** + * The builders that may be used within an action row for modals. + */ +type ModalActionRowComponentBuilder = TextInputBuilder; +/** + * Any builder. + */ +type AnyComponentBuilder = MessageActionRowComponentBuilder | ModalActionRowComponentBuilder; +/** + * A builder that creates API-compatible JSON data for action rows. + * + * @typeParam ComponentType - The types of components this action row holds + */ +declare class ActionRowBuilder extends ComponentBuilder> { + /** + * The components within this action row. + */ + readonly components: ComponentType[]; + /** + * Creates a new action row from API data. + * + * @param data - The API data to create this action row with + * @example + * Creating an action row from an API data object: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Type something", + * style: TextInputStyle.Short, + * type: ComponentType.TextInput, + * }, + * ], + * }); + * ``` + * @example + * Creating an action row using setters and API data: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Click me", + * style: ButtonStyle.Primary, + * type: ComponentType.Button, + * }, + * ], + * }) + * .addComponents(button2, button3); + * ``` + */ + constructor({ components, ...data }?: Partial>); + /** + * Adds components to this action row. + * + * @param components - The components to add + */ + addComponents(...components: RestOrArray): this; + /** + * Sets components for this action row. + * + * @param components - The components to set + */ + setComponents(...components: RestOrArray): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIActionRowComponent>; +} + +/** + * Components here are mapped to their respective builder. + */ +interface MappedComponentTypes { + /** + * The action row component type is associated with an {@link ActionRowBuilder}. + */ + [ComponentType.ActionRow]: ActionRowBuilder; + /** + * The button component type is associated with a {@link ButtonBuilder}. + */ + [ComponentType.Button]: ButtonBuilder; + /** + * The string select component type is associated with a {@link StringSelectMenuBuilder}. + */ + [ComponentType.StringSelect]: StringSelectMenuBuilder; + /** + * The text input component type is associated with a {@link TextInputBuilder}. + */ + [ComponentType.TextInput]: TextInputBuilder; + /** + * The user select component type is associated with a {@link UserSelectMenuBuilder}. + */ + [ComponentType.UserSelect]: UserSelectMenuBuilder; + /** + * The role select component type is associated with a {@link RoleSelectMenuBuilder}. + */ + [ComponentType.RoleSelect]: RoleSelectMenuBuilder; + /** + * The mentionable select component type is associated with a {@link MentionableSelectMenuBuilder}. + */ + [ComponentType.MentionableSelect]: MentionableSelectMenuBuilder; + /** + * The channel select component type is associated with a {@link ChannelSelectMenuBuilder}. + */ + [ComponentType.ChannelSelect]: ChannelSelectMenuBuilder; +} +/** + * Factory for creating components from API data. + * + * @typeParam ComponentType - The type of component to use + * @param data - The API data to transform to a component class + */ +declare function createComponentBuilder(data: (APIModalComponent | APIMessageComponent) & { + type: ComponentType; +}): MappedComponentTypes[ComponentType]; +/** + * Factory for creating components from API data. + * + * @typeParam ComponentBuilder - The type of component to use + * @param data - The API data to transform to a component class + */ +declare function createComponentBuilder(data: ComponentBuilder): ComponentBuilder; + +declare const textInputStyleValidator: _sapphire_shapeshift.NativeEnumValidator; +declare const minLengthValidator: _sapphire_shapeshift.NumberValidator; +declare const maxLengthValidator: _sapphire_shapeshift.NumberValidator; +declare const requiredValidator: _sapphire_shapeshift.BooleanValidator; +declare const valueValidator: _sapphire_shapeshift.StringValidator; +declare const placeholderValidator: _sapphire_shapeshift.StringValidator; +declare const labelValidator: _sapphire_shapeshift.StringValidator; +declare function validateRequiredParameters$3(customId?: string, style?: TextInputStyle, label?: string): void; + +declare const Assertions$3_labelValidator: typeof labelValidator; +declare const Assertions$3_maxLengthValidator: typeof maxLengthValidator; +declare const Assertions$3_minLengthValidator: typeof minLengthValidator; +declare const Assertions$3_placeholderValidator: typeof placeholderValidator; +declare const Assertions$3_requiredValidator: typeof requiredValidator; +declare const Assertions$3_textInputStyleValidator: typeof textInputStyleValidator; +declare const Assertions$3_valueValidator: typeof valueValidator; +declare namespace Assertions$3 { + export { Assertions$3_labelValidator as labelValidator, Assertions$3_maxLengthValidator as maxLengthValidator, Assertions$3_minLengthValidator as minLengthValidator, Assertions$3_placeholderValidator as placeholderValidator, Assertions$3_requiredValidator as requiredValidator, Assertions$3_textInputStyleValidator as textInputStyleValidator, validateRequiredParameters$3 as validateRequiredParameters, Assertions$3_valueValidator as valueValidator }; +} + +/** + * A builder that creates API-compatible JSON data for modals. + */ +declare class ModalBuilder implements JSONEncodable { + /** + * The API data associated with this modal. + */ + readonly data: Partial; + /** + * The components within this modal. + */ + readonly components: ActionRowBuilder[]; + /** + * Creates a new modal from API data. + * + * @param data - The API data to create this modal with + */ + constructor({ components, ...data }?: Partial); + /** + * Sets the title of this modal. + * + * @param title - The title to use + */ + setTitle(title: string): this; + /** + * Sets the custom id of this modal. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Adds components to this modal. + * + * @param components - The components to add + */ + addComponents(...components: RestOrArray | APIActionRowComponent>): this; + /** + * Sets components for this modal. + * + * @param components - The components to set + */ + setComponents(...components: RestOrArray>): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIModalInteractionResponseCallbackData; +} + +declare const titleValidator: _sapphire_shapeshift.StringValidator; +declare const componentsValidator: _sapphire_shapeshift.ArrayValidator<[ActionRowBuilder, ...ActionRowBuilder[]], ActionRowBuilder>; +declare function validateRequiredParameters$2(customId?: string, title?: string, components?: ActionRowBuilder[]): void; + +declare const Assertions$2_componentsValidator: typeof componentsValidator; +declare const Assertions$2_titleValidator: typeof titleValidator; +declare namespace Assertions$2 { + export { Assertions$2_componentsValidator as componentsValidator, Assertions$2_titleValidator as titleValidator, validateRequiredParameters$2 as validateRequiredParameters }; +} + +/** + * This mixin holds name and description symbols for slash commands. + */ +declare class SharedNameAndDescription { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The description of this command. + */ + readonly description: string; + /** + * The description localizations of this command. + */ + readonly description_localizations?: LocalizationMap; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name: string): this; + /** + * Sets the description of this command. + * + * @param description - The description to use + */ + setDescription(description: string): this; + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale: LocaleString, localizedName: string | null): this; + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames: LocalizationMap | null): this; + /** + * Sets a description localization for this command. + * + * @param locale - The locale to set + * @param localizedDescription - The localized description for the given locale + */ + setDescriptionLocalization(locale: LocaleString, localizedDescription: string | null): this; + /** + * Sets the description localizations for this command. + * + * @param localizedDescriptions - The object of localized descriptions to set + */ + setDescriptionLocalizations(localizedDescriptions: LocalizationMap | null): this; +} + +/** + * This mixin holds symbols that can be shared in slashcommands independent of options or subcommands. + */ +declare class SharedSlashCommand { + readonly name: string; + readonly name_localizations?: LocalizationMap; + readonly description: string; + readonly description_localizations?: LocalizationMap; + readonly options: ToAPIApplicationCommandOptions[]; + readonly contexts?: InteractionContextType[]; + /** + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + readonly default_member_permissions: Permissions | null | undefined; + /** + * @deprecated Use {@link SharedSlashCommand.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + readonly integration_types?: ApplicationIntegrationType[]; + readonly nsfw: boolean | undefined; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts: RestOrArray): this; + /** + * Sets the integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes: RestOrArray): this; + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether or not to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + setDefaultPermission(value: boolean): this; + /** + * Sets the default permissions a member should have in order to run the command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined): this; + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated + * Use {@link SharedSlashCommand.setContexts} instead. + */ + setDMPermission(enabled: boolean | null | undefined): this; + /** + * Sets whether this command is NSFW. + * + * @param nsfw - Whether this command is NSFW + */ + setNSFW(nsfw?: boolean): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): RESTPostAPIChatInputApplicationCommandsJSONBody; +} + +/** + * The base application command option builder that contains common symbols for application command builders. + */ +declare abstract class ApplicationCommandOptionBase extends SharedNameAndDescription { + /** + * The type of this option. + */ + abstract readonly type: ApplicationCommandOptionType; + /** + * Whether this option is required. + * + * @defaultValue `false` + */ + readonly required: boolean; + /** + * Sets whether this option is required. + * + * @param required - Whether this option should be required + */ + setRequired(required: boolean): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + abstract toJSON(): APIApplicationCommandBasicOption; + /** + * This method runs required validators on this builder. + */ + protected runRequiredValidations(): void; +} + +/** + * A slash command attachment option. + */ +declare class SlashCommandAttachmentOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Attachment; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandAttachmentOption; +} + +/** + * A slash command boolean option. + */ +declare class SlashCommandBooleanOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Boolean; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandBooleanOption; +} + +/** + * The allowed channel types used for a channel option in a slash command builder. + * + * @privateRemarks This can't be dynamic because const enums are erased at runtime. + * @internal + */ +declare const allowedChannelTypes: readonly [ChannelType.GuildText, ChannelType.GuildVoice, ChannelType.GuildCategory, ChannelType.GuildAnnouncement, ChannelType.AnnouncementThread, ChannelType.PublicThread, ChannelType.PrivateThread, ChannelType.GuildStageVoice, ChannelType.GuildForum, ChannelType.GuildMedia]; +/** + * The type of allowed channel types used for a channel option. + */ +type ApplicationCommandOptionAllowedChannelTypes = (typeof allowedChannelTypes)[number]; +/** + * This mixin holds channel type symbols used for options. + */ +declare class ApplicationCommandOptionChannelTypesMixin { + /** + * The channel types of this option. + */ + readonly channel_types?: ApplicationCommandOptionAllowedChannelTypes[]; + /** + * Adds channel types to this option. + * + * @param channelTypes - The channel types + */ + addChannelTypes(...channelTypes: RestOrArray): this; +} + +/** + * A slash command channel option. + */ +declare class SlashCommandChannelOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Channel; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandChannelOption; +} +interface SlashCommandChannelOption extends ApplicationCommandOptionChannelTypesMixin { +} + +/** + * This mixin holds minimum and maximum symbols used for options. + */ +declare abstract class ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The maximum value of this option. + */ + readonly max_value?: number; + /** + * The minimum value of this option. + */ + readonly min_value?: number; + /** + * Sets the maximum number value of this option. + * + * @param max - The maximum value this option can be + */ + abstract setMaxValue(max: number): this; + /** + * Sets the minimum number value of this option. + * + * @param min - The minimum value this option can be + */ + abstract setMinValue(min: number): this; +} + +/** + * This mixin holds choices and autocomplete symbols used for options. + */ +declare class ApplicationCommandOptionWithAutocompleteMixin { + /** + * Whether this option utilizes autocomplete. + */ + readonly autocomplete?: boolean; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + readonly type: ApplicationCommandOptionType; + /** + * Whether this option uses autocomplete. + * + * @param autocomplete - Whether this option should use autocomplete + */ + setAutocomplete(autocomplete: boolean): this; +} + +/** + * This mixin holds choices and autocomplete symbols used for options. + */ +declare class ApplicationCommandOptionWithChoicesMixin { + /** + * The choices of this option. + */ + readonly choices?: APIApplicationCommandOptionChoice[]; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + readonly type: ApplicationCommandOptionType; + /** + * Adds multiple choices to this option. + * + * @param choices - The choices to add + */ + addChoices(...choices: RestOrArray>): this; + /** + * Sets multiple choices for this option. + * + * @param choices - The choices to set + */ + setChoices>(...choices: RestOrArray): this; +} + +/** + * A slash command integer option. + */ +declare class SlashCommandIntegerOption extends ApplicationCommandOptionBase implements ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Integer; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max: number): this; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandIntegerOption; +} +interface SlashCommandIntegerOption extends ApplicationCommandNumericOptionMinMaxValueMixin, ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command mentionable option. + */ +declare class SlashCommandMentionableOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Mentionable; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandMentionableOption; +} + +/** + * A slash command number option. + */ +declare class SlashCommandNumberOption extends ApplicationCommandOptionBase implements ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Number; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max: number): this; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandNumberOption; +} +interface SlashCommandNumberOption extends ApplicationCommandNumericOptionMinMaxValueMixin, ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command role option. + */ +declare class SlashCommandRoleOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Role; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandRoleOption; +} + +/** + * A slash command string option. + */ +declare class SlashCommandStringOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.String; + /** + * The maximum length of this option. + */ + readonly max_length?: number; + /** + * The minimum length of this option. + */ + readonly min_length?: number; + /** + * Sets the maximum length of this string option. + * + * @param max - The maximum length this option can be + */ + setMaxLength(max: number): this; + /** + * Sets the minimum length of this string option. + * + * @param min - The minimum length this option can be + */ + setMinLength(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandStringOption; +} +interface SlashCommandStringOption extends ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command user option. + */ +declare class SlashCommandUserOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.User; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandUserOption; +} + +/** + * This mixin holds symbols that can be shared in slash command options. + * + * @typeParam TypeAfterAddingOptions - The type this class should return after adding an option. + */ +declare class SharedSlashCommandOptions> { + readonly options: ToAPIApplicationCommandOptions[]; + /** + * Adds a boolean option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addBooleanOption(input: SlashCommandBooleanOption | ((builder: SlashCommandBooleanOption) => SlashCommandBooleanOption)): TypeAfterAddingOptions; + /** + * Adds a user option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addUserOption(input: SlashCommandUserOption | ((builder: SlashCommandUserOption) => SlashCommandUserOption)): TypeAfterAddingOptions; + /** + * Adds a channel option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addChannelOption(input: SlashCommandChannelOption | ((builder: SlashCommandChannelOption) => SlashCommandChannelOption)): TypeAfterAddingOptions; + /** + * Adds a role option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addRoleOption(input: SlashCommandRoleOption | ((builder: SlashCommandRoleOption) => SlashCommandRoleOption)): TypeAfterAddingOptions; + /** + * Adds an attachment option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addAttachmentOption(input: SlashCommandAttachmentOption | ((builder: SlashCommandAttachmentOption) => SlashCommandAttachmentOption)): TypeAfterAddingOptions; + /** + * Adds a mentionable option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addMentionableOption(input: SlashCommandMentionableOption | ((builder: SlashCommandMentionableOption) => SlashCommandMentionableOption)): TypeAfterAddingOptions; + /** + * Adds a string option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addStringOption(input: SlashCommandStringOption | ((builder: SlashCommandStringOption) => SlashCommandStringOption)): TypeAfterAddingOptions; + /** + * Adds an integer option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addIntegerOption(input: SlashCommandIntegerOption | ((builder: SlashCommandIntegerOption) => SlashCommandIntegerOption)): TypeAfterAddingOptions; + /** + * Adds a number option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addNumberOption(input: SlashCommandNumberOption | ((builder: SlashCommandNumberOption) => SlashCommandNumberOption)): TypeAfterAddingOptions; + /** + * Where the actual adding magic happens. ✨ + * + * @param input - The input. What else? + * @param Instance - The instance of whatever is being added + * @internal + */ + private _sharedAddOptionMethod; +} + +/** + * Represents a folder for subcommands. + * + * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups} + */ +declare class SlashCommandSubcommandGroupBuilder implements ToAPIApplicationCommandOptions { + /** + * The name of this subcommand group. + */ + readonly name: string; + /** + * The description of this subcommand group. + */ + readonly description: string; + /** + * The subcommands within this subcommand group. + */ + readonly options: SlashCommandSubcommandBuilder[]; + /** + * Adds a new subcommand to this group. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input: SlashCommandSubcommandBuilder | ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder)): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIApplicationCommandSubcommandGroupOption; +} +interface SlashCommandSubcommandGroupBuilder extends SharedNameAndDescription { +} +/** + * A builder that creates API-compatible JSON data for slash command subcommands. + * + * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups} + */ +declare class SlashCommandSubcommandBuilder implements ToAPIApplicationCommandOptions { + /** + * The name of this subcommand. + */ + readonly name: string; + /** + * The description of this subcommand. + */ + readonly description: string; + /** + * The options within this subcommand. + */ + readonly options: ApplicationCommandOptionBase[]; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIApplicationCommandSubcommandOption; +} +interface SlashCommandSubcommandBuilder extends SharedNameAndDescription, SharedSlashCommandOptions { +} + +/** + * This mixin holds symbols that can be shared in slash subcommands. + * + * @typeParam TypeAfterAddingSubcommands - The type this class should return after adding a subcommand or subcommand group. + */ +declare class SharedSlashCommandSubcommands> { + readonly options: ToAPIApplicationCommandOptions[]; + /** + * Adds a new subcommand group to this command. + * + * @param input - A function that returns a subcommand group builder or an already built builder + */ + addSubcommandGroup(input: SlashCommandSubcommandGroupBuilder | ((subcommandGroup: SlashCommandSubcommandGroupBuilder) => SlashCommandSubcommandGroupBuilder)): TypeAfterAddingSubcommands; + /** + * Adds a new subcommand to this command. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input: SlashCommandSubcommandBuilder | ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder)): TypeAfterAddingSubcommands; +} + +/** + * A builder that creates API-compatible JSON data for slash commands. + */ +declare class SlashCommandBuilder { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The description of this command. + */ + readonly description: string; + /** + * The description localizations of this command. + */ + readonly description_localizations?: LocalizationMap; + /** + * The options of this command. + */ + readonly options: ToAPIApplicationCommandOptions[]; + /** + * The contexts for this command. + */ + readonly contexts?: InteractionContextType[]; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + /** + * The set of permissions represented as a bit set for the command. + */ + readonly default_member_permissions: Permissions | null | undefined; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link SlashCommandBuilder.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + /** + * The integration types for this command. + */ + readonly integration_types?: ApplicationIntegrationType[]; + /** + * Whether this command is NSFW. + */ + readonly nsfw: boolean | undefined; +} +interface SlashCommandBuilder extends SharedNameAndDescription, SharedSlashCommandOptions, SharedSlashCommandSubcommands, SharedSlashCommand { +} +/** + * An interface specifically for slash command subcommands. + */ +interface SlashCommandSubcommandsOnlyBuilder extends SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand { +} +/** + * An interface specifically for slash command options. + */ +interface SlashCommandOptionsOnlyBuilder extends SharedNameAndDescription, SharedSlashCommandOptions, SharedSlashCommand { +} +/** + * An interface that ensures the `toJSON()` call will return something + * that can be serialized into API-compatible data. + */ +interface ToAPIApplicationCommandOptions { + toJSON(): APIApplicationCommandOption; +} + +declare function validateName$1(name: unknown): asserts name is string; +declare function validateDescription(description: unknown): asserts description is string; +declare function validateLocale(locale: unknown): Locale; +declare function validateMaxOptionsLength(options: unknown): asserts options is ToAPIApplicationCommandOptions[]; +declare function validateRequiredParameters$1(name: string, description: string, options: ToAPIApplicationCommandOptions[]): void; +declare function validateDefaultPermission$1(value: unknown): asserts value is boolean; +declare function validateRequired(required: unknown): asserts required is boolean; +declare function validateChoicesLength(amountAdding: number, choices?: APIApplicationCommandOptionChoice[]): void; +declare function assertReturnOfBuilder(input: unknown, ExpectedInstanceOf: new () => ReturnType): asserts input is ReturnType; +declare const localizationMapPredicate: _sapphire_shapeshift.UnionValidator<_sapphire_shapeshift.UndefinedToOptional>> | null | undefined>; +declare function validateLocalizationMap(value: unknown): asserts value is LocalizationMap; +declare function validateDMPermission$1(value: unknown): asserts value is boolean | null | undefined; +declare function validateDefaultMemberPermissions$1(permissions: unknown): string | null | undefined; +declare function validateNSFW(value: unknown): asserts value is boolean; +declare const contextsPredicate$1: _sapphire_shapeshift.ArrayValidator; +declare const integrationTypesPredicate$1: _sapphire_shapeshift.ArrayValidator; + +declare const Assertions$1_assertReturnOfBuilder: typeof assertReturnOfBuilder; +declare const Assertions$1_localizationMapPredicate: typeof localizationMapPredicate; +declare const Assertions$1_validateChoicesLength: typeof validateChoicesLength; +declare const Assertions$1_validateDescription: typeof validateDescription; +declare const Assertions$1_validateLocale: typeof validateLocale; +declare const Assertions$1_validateLocalizationMap: typeof validateLocalizationMap; +declare const Assertions$1_validateMaxOptionsLength: typeof validateMaxOptionsLength; +declare const Assertions$1_validateNSFW: typeof validateNSFW; +declare const Assertions$1_validateRequired: typeof validateRequired; +declare namespace Assertions$1 { + export { Assertions$1_assertReturnOfBuilder as assertReturnOfBuilder, contextsPredicate$1 as contextsPredicate, integrationTypesPredicate$1 as integrationTypesPredicate, Assertions$1_localizationMapPredicate as localizationMapPredicate, Assertions$1_validateChoicesLength as validateChoicesLength, validateDMPermission$1 as validateDMPermission, validateDefaultMemberPermissions$1 as validateDefaultMemberPermissions, validateDefaultPermission$1 as validateDefaultPermission, Assertions$1_validateDescription as validateDescription, Assertions$1_validateLocale as validateLocale, Assertions$1_validateLocalizationMap as validateLocalizationMap, Assertions$1_validateMaxOptionsLength as validateMaxOptionsLength, Assertions$1_validateNSFW as validateNSFW, validateName$1 as validateName, Assertions$1_validateRequired as validateRequired, validateRequiredParameters$1 as validateRequiredParameters }; +} + +/** + * The type a context menu command can be. + */ +type ContextMenuCommandType = ApplicationCommandType.Message | ApplicationCommandType.User; +/** + * A builder that creates API-compatible JSON data for context menu commands. + */ +declare class ContextMenuCommandBuilder { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The type of this command. + */ + readonly type: ContextMenuCommandType; + /** + * The contexts for this command. + */ + readonly contexts?: InteractionContextType[]; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + /** + * The set of permissions represented as a bit set for the command. + */ + readonly default_member_permissions: Permissions | null | undefined; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link ContextMenuCommandBuilder.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + /** + * The integration types for this command. + */ + readonly integration_types?: ApplicationIntegrationType[]; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts: RestOrArray): this; + /** + * Sets integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes: RestOrArray): this; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name: string): this; + /** + * Sets the type of this command. + * + * @param type - The type to use + */ + setType(type: ContextMenuCommandType): this; + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + setDefaultPermission(value: boolean): this; + /** + * Sets the default permissions a member should have in order to run this command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined): this; + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead. + */ + setDMPermission(enabled: boolean | null | undefined): this; + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale: LocaleString, localizedName: string | null): this; + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames: LocalizationMap | null): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): RESTPostAPIContextMenuApplicationCommandsJSONBody; +} + +declare function validateDefaultPermission(value: unknown): asserts value is boolean; +declare function validateName(name: unknown): asserts name is string; +declare function validateType(type: unknown): asserts type is ContextMenuCommandType; +declare function validateRequiredParameters(name: string, type: number): void; +declare function validateDMPermission(value: unknown): asserts value is boolean | null | undefined; +declare function validateDefaultMemberPermissions(permissions: unknown): string | null | undefined; +declare const contextsPredicate: _sapphire_shapeshift.ArrayValidator; +declare const integrationTypesPredicate: _sapphire_shapeshift.ArrayValidator; + +declare const Assertions_contextsPredicate: typeof contextsPredicate; +declare const Assertions_integrationTypesPredicate: typeof integrationTypesPredicate; +declare const Assertions_validateDMPermission: typeof validateDMPermission; +declare const Assertions_validateDefaultMemberPermissions: typeof validateDefaultMemberPermissions; +declare const Assertions_validateDefaultPermission: typeof validateDefaultPermission; +declare const Assertions_validateName: typeof validateName; +declare const Assertions_validateRequiredParameters: typeof validateRequiredParameters; +declare const Assertions_validateType: typeof validateType; +declare namespace Assertions { + export { Assertions_contextsPredicate as contextsPredicate, Assertions_integrationTypesPredicate as integrationTypesPredicate, Assertions_validateDMPermission as validateDMPermission, Assertions_validateDefaultMemberPermissions as validateDefaultMemberPermissions, Assertions_validateDefaultPermission as validateDefaultPermission, Assertions_validateName as validateName, Assertions_validateRequiredParameters as validateRequiredParameters, Assertions_validateType as validateType }; +} + +/** + * Calculates the length of the embed. + * + * @param data - The embed data to check + */ +declare function embedLength(data: APIEmbed): number; + +/** + * Enables validators. + * + * @returns Whether validation is occurring. + */ +declare function enableValidators(): boolean; +/** + * Disables validators. + * + * @returns Whether validation is occurring. + */ +declare function disableValidators(): boolean; +/** + * Checks whether validation is occurring. + */ +declare function isValidationEnabled(): boolean; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/builders#readme | @discordjs/builders} version + * that you are currently using. + * + * @privateRemarks This needs to explicitly be `string` so it is not typed as a "const string" that gets injected by esbuild. + */ +declare const version: string; + +export { ActionRowBuilder, type AnyAPIActionRowComponent, type AnyComponentBuilder, ApplicationCommandNumericOptionMinMaxValueMixin, type ApplicationCommandOptionAllowedChannelTypes, ApplicationCommandOptionBase, ApplicationCommandOptionChannelTypesMixin, ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin, BaseSelectMenuBuilder, ButtonBuilder, ChannelSelectMenuBuilder, Assertions$4 as ComponentAssertions, ComponentBuilder, Assertions as ContextMenuCommandAssertions, ContextMenuCommandBuilder, type ContextMenuCommandType, Assertions$5 as EmbedAssertions, type EmbedAuthorData, type EmbedAuthorOptions, EmbedBuilder, type EmbedFooterData, type EmbedFooterOptions, type EmbedImageData, type IconData, type MappedComponentTypes, MentionableSelectMenuBuilder, type MessageActionRowComponentBuilder, type MessageComponentBuilder, type ModalActionRowComponentBuilder, Assertions$2 as ModalAssertions, ModalBuilder, type ModalComponentBuilder, type RGBTuple, type RestOrArray, RoleSelectMenuBuilder, StringSelectMenuBuilder as SelectMenuBuilder, StringSelectMenuOptionBuilder as SelectMenuOptionBuilder, SharedNameAndDescription, SharedSlashCommand, SharedSlashCommandOptions, SharedSlashCommandSubcommands, Assertions$1 as SlashCommandAssertions, SlashCommandAttachmentOption, SlashCommandBooleanOption, SlashCommandBuilder, SlashCommandChannelOption, SlashCommandIntegerOption, SlashCommandMentionableOption, SlashCommandNumberOption, type SlashCommandOptionsOnlyBuilder, SlashCommandRoleOption, SlashCommandStringOption, SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder, type SlashCommandSubcommandsOnlyBuilder, SlashCommandUserOption, StringSelectMenuBuilder, StringSelectMenuOptionBuilder, Assertions$3 as TextInputAssertions, TextInputBuilder, type ToAPIApplicationCommandOptions, UserSelectMenuBuilder, createComponentBuilder, disableValidators, embedLength, enableValidators, isValidationEnabled, normalizeArray, version }; diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.ts b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.ts new file mode 100644 index 0000000..ac28cd2 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.d.ts @@ -0,0 +1,2043 @@ +import * as _sapphire_shapeshift from '@sapphire/shapeshift'; +import { APIEmbedField, APIEmbedAuthor, APIEmbedFooter, APIEmbedImage, APIEmbed, APISelectMenuOption, APIMessageComponentEmoji, ButtonStyle, ChannelType, APIActionRowComponent, APIActionRowComponentTypes, APIBaseComponent, ComponentType, APIButtonComponent, Snowflake, APISelectMenuComponent, APIChannelSelectComponent, APIMentionableSelectComponent, APISelectMenuDefaultValue, SelectMenuDefaultValueType, APIRoleSelectComponent, APIStringSelectComponent, APIUserSelectComponent, APITextInputComponent, TextInputStyle, APIMessageActionRowComponent, APIModalActionRowComponent, APIModalComponent, APIMessageComponent, APIModalInteractionResponseCallbackData, LocalizationMap, LocaleString, InteractionContextType, Permissions, ApplicationIntegrationType, RESTPostAPIChatInputApplicationCommandsJSONBody, ApplicationCommandOptionType, APIApplicationCommandBasicOption, APIApplicationCommandAttachmentOption, APIApplicationCommandBooleanOption, APIApplicationCommandChannelOption, APIApplicationCommandOptionChoice, APIApplicationCommandIntegerOption, APIApplicationCommandMentionableOption, APIApplicationCommandNumberOption, APIApplicationCommandRoleOption, APIApplicationCommandStringOption, APIApplicationCommandUserOption, APIApplicationCommandSubcommandGroupOption, APIApplicationCommandSubcommandOption, APIApplicationCommandOption, Locale, ApplicationCommandType, RESTPostAPIContextMenuApplicationCommandsJSONBody } from 'discord-api-types/v10'; +export * from '@discordjs/formatters'; +import { JSONEncodable, Equatable } from '@discordjs/util'; + +declare const fieldNamePredicate: _sapphire_shapeshift.StringValidator; +declare const fieldValuePredicate: _sapphire_shapeshift.StringValidator; +declare const fieldInlinePredicate: _sapphire_shapeshift.UnionValidator; +declare const embedFieldPredicate: _sapphire_shapeshift.ObjectValidator<{ + name: string; + value: string; + inline: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>>; +declare const embedFieldsArrayPredicate: _sapphire_shapeshift.ArrayValidator<_sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>[], _sapphire_shapeshift.UndefinedToOptional<{ + name: string; + value: string; + inline: boolean | undefined; +}>>; +declare const fieldLengthPredicate: _sapphire_shapeshift.NumberValidator; +declare function validateFieldLength(amountAdding: number, fields?: APIEmbedField[]): void; +declare const authorNamePredicate: _sapphire_shapeshift.UnionValidator; +declare const imageURLPredicate: _sapphire_shapeshift.UnionValidator; +declare const urlPredicate: _sapphire_shapeshift.UnionValidator; +declare const embedAuthorPredicate: _sapphire_shapeshift.ObjectValidator<{ + name: string | null; + iconURL: string | null | undefined; + url: string | null | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name: string | null; + iconURL: string | null | undefined; + url: string | null | undefined; +}>>; +declare const RGBPredicate: _sapphire_shapeshift.NumberValidator; +declare const colorPredicate: _sapphire_shapeshift.UnionValidator; +declare const descriptionPredicate: _sapphire_shapeshift.UnionValidator; +declare const footerTextPredicate: _sapphire_shapeshift.UnionValidator; +declare const embedFooterPredicate: _sapphire_shapeshift.ObjectValidator<{ + text: string | null; + iconURL: string | null | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + text: string | null; + iconURL: string | null | undefined; +}>>; +declare const timestampPredicate: _sapphire_shapeshift.UnionValidator; +declare const titlePredicate: _sapphire_shapeshift.UnionValidator; + +declare const Assertions$5_RGBPredicate: typeof RGBPredicate; +declare const Assertions$5_authorNamePredicate: typeof authorNamePredicate; +declare const Assertions$5_colorPredicate: typeof colorPredicate; +declare const Assertions$5_descriptionPredicate: typeof descriptionPredicate; +declare const Assertions$5_embedAuthorPredicate: typeof embedAuthorPredicate; +declare const Assertions$5_embedFieldPredicate: typeof embedFieldPredicate; +declare const Assertions$5_embedFieldsArrayPredicate: typeof embedFieldsArrayPredicate; +declare const Assertions$5_embedFooterPredicate: typeof embedFooterPredicate; +declare const Assertions$5_fieldInlinePredicate: typeof fieldInlinePredicate; +declare const Assertions$5_fieldLengthPredicate: typeof fieldLengthPredicate; +declare const Assertions$5_fieldNamePredicate: typeof fieldNamePredicate; +declare const Assertions$5_fieldValuePredicate: typeof fieldValuePredicate; +declare const Assertions$5_footerTextPredicate: typeof footerTextPredicate; +declare const Assertions$5_imageURLPredicate: typeof imageURLPredicate; +declare const Assertions$5_timestampPredicate: typeof timestampPredicate; +declare const Assertions$5_titlePredicate: typeof titlePredicate; +declare const Assertions$5_urlPredicate: typeof urlPredicate; +declare const Assertions$5_validateFieldLength: typeof validateFieldLength; +declare namespace Assertions$5 { + export { Assertions$5_RGBPredicate as RGBPredicate, Assertions$5_authorNamePredicate as authorNamePredicate, Assertions$5_colorPredicate as colorPredicate, Assertions$5_descriptionPredicate as descriptionPredicate, Assertions$5_embedAuthorPredicate as embedAuthorPredicate, Assertions$5_embedFieldPredicate as embedFieldPredicate, Assertions$5_embedFieldsArrayPredicate as embedFieldsArrayPredicate, Assertions$5_embedFooterPredicate as embedFooterPredicate, Assertions$5_fieldInlinePredicate as fieldInlinePredicate, Assertions$5_fieldLengthPredicate as fieldLengthPredicate, Assertions$5_fieldNamePredicate as fieldNamePredicate, Assertions$5_fieldValuePredicate as fieldValuePredicate, Assertions$5_footerTextPredicate as footerTextPredicate, Assertions$5_imageURLPredicate as imageURLPredicate, Assertions$5_timestampPredicate as timestampPredicate, Assertions$5_titlePredicate as titlePredicate, Assertions$5_urlPredicate as urlPredicate, Assertions$5_validateFieldLength as validateFieldLength }; +} + +/** + * Normalizes data that is a rest parameter or an array into an array with a depth of 1. + * + * @typeParam ItemType - The data that must satisfy {@link RestOrArray}. + * @param arr - The (possibly variadic) data to normalize + */ +declare function normalizeArray(arr: RestOrArray): ItemType[]; +/** + * Represents data that may be an array or came from a rest parameter. + * + * @remarks + * This type is used throughout builders to ensure both an array and variadic arguments + * may be used. It is normalized with {@link normalizeArray}. + */ +type RestOrArray = Type[] | [Type[]]; + +/** + * A tuple satisfying the RGB color model. + * + * @see {@link https://developer.mozilla.org/docs/Glossary/RGB} + */ +type RGBTuple = [red: number, green: number, blue: number]; +/** + * The base icon data typically used in payloads. + */ +interface IconData { + /** + * The URL of the icon. + */ + iconURL?: string; + /** + * The proxy URL of the icon. + */ + proxyIconURL?: string; +} +/** + * Represents the author data of an embed. + */ +interface EmbedAuthorData extends IconData, Omit { +} +/** + * Represents the author options of an embed. + */ +interface EmbedAuthorOptions extends Omit { +} +/** + * Represents the footer data of an embed. + */ +interface EmbedFooterData extends IconData, Omit { +} +/** + * Represents the footer options of an embed. + */ +interface EmbedFooterOptions extends Omit { +} +/** + * Represents the image data of an embed. + */ +interface EmbedImageData extends Omit { + /** + * The proxy URL for the image. + */ + proxyURL?: string; +} +/** + * A builder that creates API-compatible JSON data for embeds. + */ +declare class EmbedBuilder { + /** + * The API data associated with this embed. + */ + readonly data: APIEmbed; + /** + * Creates a new embed from API data. + * + * @param data - The API data to create this embed with + */ + constructor(data?: APIEmbed); + /** + * Appends fields to the embed. + * + * @remarks + * This method accepts either an array of fields or a variable number of field parameters. + * The maximum amount of fields that can be added is 25. + * @example + * Using an array: + * ```ts + * const fields: APIEmbedField[] = ...; + * const embed = new EmbedBuilder() + * .addFields(fields); + * ``` + * @example + * Using rest parameters (variadic): + * ```ts + * const embed = new EmbedBuilder() + * .addFields( + * { name: 'Field 1', value: 'Value 1' }, + * { name: 'Field 2', value: 'Value 2' }, + * ); + * ``` + * @param fields - The fields to add + */ + addFields(...fields: RestOrArray): this; + /** + * Removes, replaces, or inserts fields for this embed. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}. + * The maximum amount of fields that can be added is 25. + * + * It's useful for modifying and adjusting order of the already-existing fields of an embed. + * @example + * Remove the first field: + * ```ts + * embed.spliceFields(0, 1); + * ``` + * @example + * Remove the first n fields: + * ```ts + * const n = 4; + * embed.spliceFields(0, n); + * ``` + * @example + * Remove the last field: + * ```ts + * embed.spliceFields(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of fields to remove + * @param fields - The replacing field objects + */ + spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this; + /** + * Sets the fields for this embed. + * + * @remarks + * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically, + * it splices the entire array of fields, replacing them with the provided fields. + * + * You can set a maximum of 25 fields. + * @param fields - The fields to set + */ + setFields(...fields: RestOrArray): this; + /** + * Sets the author of this embed. + * + * @param options - The options to use + */ + setAuthor(options: EmbedAuthorOptions | null): this; + /** + * Sets the color of this embed. + * + * @param color - The color to use + */ + setColor(color: RGBTuple | number | null): this; + /** + * Sets the description of this embed. + * + * @param description - The description to use + */ + setDescription(description: string | null): this; + /** + * Sets the footer of this embed. + * + * @param options - The footer to use + */ + setFooter(options: EmbedFooterOptions | null): this; + /** + * Sets the image of this embed. + * + * @param url - The image URL to use + */ + setImage(url: string | null): this; + /** + * Sets the thumbnail of this embed. + * + * @param url - The thumbnail URL to use + */ + setThumbnail(url: string | null): this; + /** + * Sets the timestamp of this embed. + * + * @param timestamp - The timestamp or date to use + */ + setTimestamp(timestamp?: Date | number | null): this; + /** + * Sets the title for this embed. + * + * @param title - The title to use + */ + setTitle(title: string | null): this; + /** + * Sets the URL of this embed. + * + * @param url - The URL to use + */ + setURL(url: string | null): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIEmbed; +} + +/** + * A builder that creates API-compatible JSON data for string select menu options. + */ +declare class StringSelectMenuOptionBuilder implements JSONEncodable { + data: Partial; + /** + * Creates a new string select menu option from API data. + * + * @param data - The API data to create this string select menu option with + * @example + * Creating a string select menu option from an API data object: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * label: 'catchy label', + * value: '1', + * }); + * ``` + * @example + * Creating a string select menu option using setters and API data: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * default: true, + * value: '1', + * }) + * .setLabel('woah'); + * ``` + */ + constructor(data?: Partial); + /** + * Sets the label for this option. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * Sets the value for this option. + * + * @param value - The value to use + */ + setValue(value: string): this; + /** + * Sets the description for this option. + * + * @param description - The description to use + */ + setDescription(description: string): this; + /** + * Sets whether this option is selected by default. + * + * @param isDefault - Whether this option is selected by default + */ + setDefault(isDefault?: boolean): this; + /** + * Sets the emoji to display for this option. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji: APIMessageComponentEmoji): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APISelectMenuOption; +} + +declare const customIdValidator: _sapphire_shapeshift.StringValidator; +declare const emojiValidator: _sapphire_shapeshift.ObjectValidator<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; +}>>; +declare const disabledValidator: _sapphire_shapeshift.BooleanValidator; +declare const buttonLabelValidator: _sapphire_shapeshift.StringValidator; +declare const buttonStyleValidator: _sapphire_shapeshift.NativeEnumValidator; +declare const placeholderValidator$1: _sapphire_shapeshift.StringValidator; +declare const minMaxValidator: _sapphire_shapeshift.NumberValidator; +declare const labelValueDescriptionValidator: _sapphire_shapeshift.StringValidator; +declare const jsonOptionValidator: _sapphire_shapeshift.ObjectValidator<{ + label: string; + value: string; + description: string | undefined; + emoji: _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; + }> | undefined; + default: boolean | undefined; +}, _sapphire_shapeshift.UndefinedToOptional<{ + label: string; + value: string; + description: string | undefined; + emoji: _sapphire_shapeshift.UndefinedToOptional<{ + name?: string | undefined; + id?: string | undefined; + animated?: boolean | undefined; + }> | undefined; + default: boolean | undefined; +}>>; +declare const optionValidator: _sapphire_shapeshift.InstanceValidator; +declare const optionsValidator: _sapphire_shapeshift.ArrayValidator; +declare const optionsLengthValidator: _sapphire_shapeshift.NumberValidator; +declare function validateRequiredSelectMenuParameters(options: StringSelectMenuOptionBuilder[], customId?: string): void; +declare const defaultValidator: _sapphire_shapeshift.BooleanValidator; +declare function validateRequiredSelectMenuOptionParameters(label?: string, value?: string): void; +declare const channelTypesValidator: _sapphire_shapeshift.ArrayValidator; +declare const urlValidator: _sapphire_shapeshift.StringValidator; +declare function validateRequiredButtonParameters(style?: ButtonStyle, label?: string, emoji?: APIMessageComponentEmoji, customId?: string, skuId?: string, url?: string): void; + +declare const Assertions$4_buttonLabelValidator: typeof buttonLabelValidator; +declare const Assertions$4_buttonStyleValidator: typeof buttonStyleValidator; +declare const Assertions$4_channelTypesValidator: typeof channelTypesValidator; +declare const Assertions$4_customIdValidator: typeof customIdValidator; +declare const Assertions$4_defaultValidator: typeof defaultValidator; +declare const Assertions$4_disabledValidator: typeof disabledValidator; +declare const Assertions$4_emojiValidator: typeof emojiValidator; +declare const Assertions$4_jsonOptionValidator: typeof jsonOptionValidator; +declare const Assertions$4_labelValueDescriptionValidator: typeof labelValueDescriptionValidator; +declare const Assertions$4_minMaxValidator: typeof minMaxValidator; +declare const Assertions$4_optionValidator: typeof optionValidator; +declare const Assertions$4_optionsLengthValidator: typeof optionsLengthValidator; +declare const Assertions$4_optionsValidator: typeof optionsValidator; +declare const Assertions$4_urlValidator: typeof urlValidator; +declare const Assertions$4_validateRequiredButtonParameters: typeof validateRequiredButtonParameters; +declare const Assertions$4_validateRequiredSelectMenuOptionParameters: typeof validateRequiredSelectMenuOptionParameters; +declare const Assertions$4_validateRequiredSelectMenuParameters: typeof validateRequiredSelectMenuParameters; +declare namespace Assertions$4 { + export { Assertions$4_buttonLabelValidator as buttonLabelValidator, Assertions$4_buttonStyleValidator as buttonStyleValidator, Assertions$4_channelTypesValidator as channelTypesValidator, Assertions$4_customIdValidator as customIdValidator, Assertions$4_defaultValidator as defaultValidator, Assertions$4_disabledValidator as disabledValidator, Assertions$4_emojiValidator as emojiValidator, Assertions$4_jsonOptionValidator as jsonOptionValidator, Assertions$4_labelValueDescriptionValidator as labelValueDescriptionValidator, Assertions$4_minMaxValidator as minMaxValidator, Assertions$4_optionValidator as optionValidator, Assertions$4_optionsLengthValidator as optionsLengthValidator, Assertions$4_optionsValidator as optionsValidator, placeholderValidator$1 as placeholderValidator, Assertions$4_urlValidator as urlValidator, Assertions$4_validateRequiredButtonParameters as validateRequiredButtonParameters, Assertions$4_validateRequiredSelectMenuOptionParameters as validateRequiredSelectMenuOptionParameters, Assertions$4_validateRequiredSelectMenuParameters as validateRequiredSelectMenuParameters }; +} + +/** + * Any action row component data represented as an object. + */ +type AnyAPIActionRowComponent = APIActionRowComponent | APIActionRowComponentTypes; +/** + * The base component builder that contains common symbols for all sorts of components. + * + * @typeParam DataType - The type of internal API data that is stored within the component + */ +declare abstract class ComponentBuilder> = APIBaseComponent> implements JSONEncodable { + /** + * The API data associated with this component. + */ + readonly data: Partial; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + abstract toJSON(): AnyAPIActionRowComponent; + /** + * Constructs a new kind of component. + * + * @param data - The data to construct a component out of + */ + constructor(data: Partial); +} + +/** + * A builder that creates API-compatible JSON data for buttons. + */ +declare class ButtonBuilder extends ComponentBuilder { + /** + * Creates a new button from API data. + * + * @param data - The API data to create this button with + * @example + * Creating a button from an API data object: + * ```ts + * const button = new ButtonBuilder({ + * custom_id: 'a cool button', + * style: ButtonStyle.Primary, + * label: 'Click Me', + * emoji: { + * name: 'smile', + * id: '123456789012345678', + * }, + * }); + * ``` + * @example + * Creating a button using setters and API data: + * ```ts + * const button = new ButtonBuilder({ + * style: ButtonStyle.Secondary, + * label: 'Click Me', + * }) + * .setEmoji({ name: '🙂' }) + * .setCustomId('another cool button'); + * ``` + */ + constructor(data?: Partial); + /** + * Sets the style of this button. + * + * @param style - The style to use + */ + setStyle(style: ButtonStyle): this; + /** + * Sets the URL for this button. + * + * @remarks + * This method is only available to buttons using the `Link` button style. + * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`. + * @param url - The URL to use + */ + setURL(url: string): this; + /** + * Sets the custom id for this button. + * + * @remarks + * This method is only applicable to buttons that are not using the `Link` button style. + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets the SKU id that represents a purchasable SKU for this button. + * + * @remarks Only available when using premium-style buttons. + * @param skuId - The SKU id to use + */ + setSKUId(skuId: Snowflake): this; + /** + * Sets the emoji to display on this button. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji: APIMessageComponentEmoji): this; + /** + * Sets whether this button is disabled. + * + * @param disabled - Whether to disable this button + */ + setDisabled(disabled?: boolean): this; + /** + * Sets the label for this button. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIButtonComponent; +} + +/** + * The base select menu builder that contains common symbols for select menu builders. + * + * @typeParam SelectMenuType - The type of select menu this would be instantiated for. + */ +declare abstract class BaseSelectMenuBuilder extends ComponentBuilder { + /** + * Sets the placeholder for this select menu. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder: string): this; + /** + * Sets the minimum values that must be selected in the select menu. + * + * @param minValues - The minimum values that must be selected + */ + setMinValues(minValues: number): this; + /** + * Sets the maximum values that must be selected in the select menu. + * + * @param maxValues - The maximum values that must be selected + */ + setMaxValues(maxValues: number): this; + /** + * Sets the custom id for this select menu. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets whether this select menu is disabled. + * + * @param disabled - Whether this select menu is disabled + */ + setDisabled(disabled?: boolean): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): SelectMenuType; +} + +/** + * A builder that creates API-compatible JSON data for channel select menus. + */ +declare class ChannelSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement) + * .setMinValues(2); + * ``` + */ + constructor(data?: Partial); + /** + * Adds channel types to this select menu. + * + * @param types - The channel types to use + */ + addChannelTypes(...types: RestOrArray): this; + /** + * Sets channel types for this select menu. + * + * @param types - The channel types to use + */ + setChannelTypes(...types: RestOrArray): this; + /** + * Adds default channels to this auto populated select menu. + * + * @param channels - The channels to add + */ + addDefaultChannels(...channels: RestOrArray): this; + /** + * Sets default channels for this auto populated select menu. + * + * @param channels - The channels to set + */ + setDefaultChannels(...channels: RestOrArray): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APIChannelSelectComponent; +} + +/** + * A builder that creates API-compatible JSON data for mentionable select menus. + */ +declare class MentionableSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles: RestOrArray): this; + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users: RestOrArray): this; + /** + * Adds default values to this auto populated select menu. + * + * @param values - The values to add + */ + addDefaultValues(...values: RestOrArray | APISelectMenuDefaultValue>): this; + /** + * Sets default values for this auto populated select menu. + * + * @param values - The values to set + */ + setDefaultValues(...values: RestOrArray | APISelectMenuDefaultValue>): this; +} + +/** + * A builder that creates API-compatible JSON data for role select menus. + */ +declare class RoleSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles: RestOrArray): this; + /** + * Sets default roles for this auto populated select menu. + * + * @param roles - The roles to set + */ + setDefaultRoles(...roles: RestOrArray): this; +} + +/** + * A builder that creates API-compatible JSON data for string select menus. + */ +declare class StringSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * The options within this select menu. + */ + readonly options: StringSelectMenuOptionBuilder[]; + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * options: [ + * { label: 'option 1', value: '1' }, + * { label: 'option 2', value: '2' }, + * { label: 'option 3', value: '3' }, + * ], + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1) + * .addOptions({ + * label: 'Catchy', + * value: 'catch', + * }); + * ``` + */ + constructor(data?: Partial); + /** + * Adds options to this select menu. + * + * @param options - The options to add + */ + addOptions(...options: RestOrArray): this; + /** + * Sets the options for this select menu. + * + * @param options - The options to set + */ + setOptions(...options: RestOrArray): this; + /** + * Removes, replaces, or inserts options for this select menu. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}. + * It's useful for modifying and adjusting the order of existing options. + * @example + * Remove the first option: + * ```ts + * selectMenu.spliceOptions(0, 1); + * ``` + * @example + * Remove the first n option: + * ```ts + * const n = 4; + * selectMenu.spliceOptions(0, n); + * ``` + * @example + * Remove the last option: + * ```ts + * selectMenu.spliceOptions(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of options to remove + * @param options - The replacing option objects or builders + */ + spliceOptions(index: number, deleteCount: number, ...options: RestOrArray): this; + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON(): APIStringSelectComponent; +} + +/** + * A builder that creates API-compatible JSON data for user select menus. + */ +declare class UserSelectMenuBuilder extends BaseSelectMenuBuilder { + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data?: Partial); + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users: RestOrArray): this; + /** + * Sets default users for this auto populated select menu. + * + * @param users - The users to set + */ + setDefaultUsers(...users: RestOrArray): this; +} + +/** + * A builder that creates API-compatible JSON data for text inputs. + */ +declare class TextInputBuilder extends ComponentBuilder implements Equatable> { + /** + * Creates a new text input from API data. + * + * @param data - The API data to create this text input with + * @example + * Creating a text input from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool text input', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a text input using setters and API data: + * ```ts + * const textInput = new TextInputBuilder({ + * label: 'Type something else', + * }) + * .setCustomId('woah') + * .setStyle(TextInputStyle.Paragraph); + * ``` + */ + constructor(data?: APITextInputComponent & { + type?: ComponentType.TextInput; + }); + /** + * Sets the custom id for this text input. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Sets the label for this text input. + * + * @param label - The label to use + */ + setLabel(label: string): this; + /** + * Sets the style for this text input. + * + * @param style - The style to use + */ + setStyle(style: TextInputStyle): this; + /** + * Sets the minimum length of text for this text input. + * + * @param minLength - The minimum length of text for this text input + */ + setMinLength(minLength: number): this; + /** + * Sets the maximum length of text for this text input. + * + * @param maxLength - The maximum length of text for this text input + */ + setMaxLength(maxLength: number): this; + /** + * Sets the placeholder for this text input. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder: string): this; + /** + * Sets the value for this text input. + * + * @param value - The value to use + */ + setValue(value: string): this; + /** + * Sets whether this text input is required. + * + * @param required - Whether this text input is required + */ + setRequired(required?: boolean): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APITextInputComponent; + /** + * Whether this is equal to another structure. + */ + equals(other: APITextInputComponent | JSONEncodable): boolean; +} + +/** + * The builders that may be used for messages. + */ +type MessageComponentBuilder = ActionRowBuilder | MessageActionRowComponentBuilder; +/** + * The builders that may be used for modals. + */ +type ModalComponentBuilder = ActionRowBuilder | ModalActionRowComponentBuilder; +/** + * The builders that may be used within an action row for messages. + */ +type MessageActionRowComponentBuilder = ButtonBuilder | ChannelSelectMenuBuilder | MentionableSelectMenuBuilder | RoleSelectMenuBuilder | StringSelectMenuBuilder | UserSelectMenuBuilder; +/** + * The builders that may be used within an action row for modals. + */ +type ModalActionRowComponentBuilder = TextInputBuilder; +/** + * Any builder. + */ +type AnyComponentBuilder = MessageActionRowComponentBuilder | ModalActionRowComponentBuilder; +/** + * A builder that creates API-compatible JSON data for action rows. + * + * @typeParam ComponentType - The types of components this action row holds + */ +declare class ActionRowBuilder extends ComponentBuilder> { + /** + * The components within this action row. + */ + readonly components: ComponentType[]; + /** + * Creates a new action row from API data. + * + * @param data - The API data to create this action row with + * @example + * Creating an action row from an API data object: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Type something", + * style: TextInputStyle.Short, + * type: ComponentType.TextInput, + * }, + * ], + * }); + * ``` + * @example + * Creating an action row using setters and API data: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Click me", + * style: ButtonStyle.Primary, + * type: ComponentType.Button, + * }, + * ], + * }) + * .addComponents(button2, button3); + * ``` + */ + constructor({ components, ...data }?: Partial>); + /** + * Adds components to this action row. + * + * @param components - The components to add + */ + addComponents(...components: RestOrArray): this; + /** + * Sets components for this action row. + * + * @param components - The components to set + */ + setComponents(...components: RestOrArray): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIActionRowComponent>; +} + +/** + * Components here are mapped to their respective builder. + */ +interface MappedComponentTypes { + /** + * The action row component type is associated with an {@link ActionRowBuilder}. + */ + [ComponentType.ActionRow]: ActionRowBuilder; + /** + * The button component type is associated with a {@link ButtonBuilder}. + */ + [ComponentType.Button]: ButtonBuilder; + /** + * The string select component type is associated with a {@link StringSelectMenuBuilder}. + */ + [ComponentType.StringSelect]: StringSelectMenuBuilder; + /** + * The text input component type is associated with a {@link TextInputBuilder}. + */ + [ComponentType.TextInput]: TextInputBuilder; + /** + * The user select component type is associated with a {@link UserSelectMenuBuilder}. + */ + [ComponentType.UserSelect]: UserSelectMenuBuilder; + /** + * The role select component type is associated with a {@link RoleSelectMenuBuilder}. + */ + [ComponentType.RoleSelect]: RoleSelectMenuBuilder; + /** + * The mentionable select component type is associated with a {@link MentionableSelectMenuBuilder}. + */ + [ComponentType.MentionableSelect]: MentionableSelectMenuBuilder; + /** + * The channel select component type is associated with a {@link ChannelSelectMenuBuilder}. + */ + [ComponentType.ChannelSelect]: ChannelSelectMenuBuilder; +} +/** + * Factory for creating components from API data. + * + * @typeParam ComponentType - The type of component to use + * @param data - The API data to transform to a component class + */ +declare function createComponentBuilder(data: (APIModalComponent | APIMessageComponent) & { + type: ComponentType; +}): MappedComponentTypes[ComponentType]; +/** + * Factory for creating components from API data. + * + * @typeParam ComponentBuilder - The type of component to use + * @param data - The API data to transform to a component class + */ +declare function createComponentBuilder(data: ComponentBuilder): ComponentBuilder; + +declare const textInputStyleValidator: _sapphire_shapeshift.NativeEnumValidator; +declare const minLengthValidator: _sapphire_shapeshift.NumberValidator; +declare const maxLengthValidator: _sapphire_shapeshift.NumberValidator; +declare const requiredValidator: _sapphire_shapeshift.BooleanValidator; +declare const valueValidator: _sapphire_shapeshift.StringValidator; +declare const placeholderValidator: _sapphire_shapeshift.StringValidator; +declare const labelValidator: _sapphire_shapeshift.StringValidator; +declare function validateRequiredParameters$3(customId?: string, style?: TextInputStyle, label?: string): void; + +declare const Assertions$3_labelValidator: typeof labelValidator; +declare const Assertions$3_maxLengthValidator: typeof maxLengthValidator; +declare const Assertions$3_minLengthValidator: typeof minLengthValidator; +declare const Assertions$3_placeholderValidator: typeof placeholderValidator; +declare const Assertions$3_requiredValidator: typeof requiredValidator; +declare const Assertions$3_textInputStyleValidator: typeof textInputStyleValidator; +declare const Assertions$3_valueValidator: typeof valueValidator; +declare namespace Assertions$3 { + export { Assertions$3_labelValidator as labelValidator, Assertions$3_maxLengthValidator as maxLengthValidator, Assertions$3_minLengthValidator as minLengthValidator, Assertions$3_placeholderValidator as placeholderValidator, Assertions$3_requiredValidator as requiredValidator, Assertions$3_textInputStyleValidator as textInputStyleValidator, validateRequiredParameters$3 as validateRequiredParameters, Assertions$3_valueValidator as valueValidator }; +} + +/** + * A builder that creates API-compatible JSON data for modals. + */ +declare class ModalBuilder implements JSONEncodable { + /** + * The API data associated with this modal. + */ + readonly data: Partial; + /** + * The components within this modal. + */ + readonly components: ActionRowBuilder[]; + /** + * Creates a new modal from API data. + * + * @param data - The API data to create this modal with + */ + constructor({ components, ...data }?: Partial); + /** + * Sets the title of this modal. + * + * @param title - The title to use + */ + setTitle(title: string): this; + /** + * Sets the custom id of this modal. + * + * @param customId - The custom id to use + */ + setCustomId(customId: string): this; + /** + * Adds components to this modal. + * + * @param components - The components to add + */ + addComponents(...components: RestOrArray | APIActionRowComponent>): this; + /** + * Sets components for this modal. + * + * @param components - The components to set + */ + setComponents(...components: RestOrArray>): this; + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON(): APIModalInteractionResponseCallbackData; +} + +declare const titleValidator: _sapphire_shapeshift.StringValidator; +declare const componentsValidator: _sapphire_shapeshift.ArrayValidator<[ActionRowBuilder, ...ActionRowBuilder[]], ActionRowBuilder>; +declare function validateRequiredParameters$2(customId?: string, title?: string, components?: ActionRowBuilder[]): void; + +declare const Assertions$2_componentsValidator: typeof componentsValidator; +declare const Assertions$2_titleValidator: typeof titleValidator; +declare namespace Assertions$2 { + export { Assertions$2_componentsValidator as componentsValidator, Assertions$2_titleValidator as titleValidator, validateRequiredParameters$2 as validateRequiredParameters }; +} + +/** + * This mixin holds name and description symbols for slash commands. + */ +declare class SharedNameAndDescription { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The description of this command. + */ + readonly description: string; + /** + * The description localizations of this command. + */ + readonly description_localizations?: LocalizationMap; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name: string): this; + /** + * Sets the description of this command. + * + * @param description - The description to use + */ + setDescription(description: string): this; + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale: LocaleString, localizedName: string | null): this; + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames: LocalizationMap | null): this; + /** + * Sets a description localization for this command. + * + * @param locale - The locale to set + * @param localizedDescription - The localized description for the given locale + */ + setDescriptionLocalization(locale: LocaleString, localizedDescription: string | null): this; + /** + * Sets the description localizations for this command. + * + * @param localizedDescriptions - The object of localized descriptions to set + */ + setDescriptionLocalizations(localizedDescriptions: LocalizationMap | null): this; +} + +/** + * This mixin holds symbols that can be shared in slashcommands independent of options or subcommands. + */ +declare class SharedSlashCommand { + readonly name: string; + readonly name_localizations?: LocalizationMap; + readonly description: string; + readonly description_localizations?: LocalizationMap; + readonly options: ToAPIApplicationCommandOptions[]; + readonly contexts?: InteractionContextType[]; + /** + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + readonly default_member_permissions: Permissions | null | undefined; + /** + * @deprecated Use {@link SharedSlashCommand.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + readonly integration_types?: ApplicationIntegrationType[]; + readonly nsfw: boolean | undefined; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts: RestOrArray): this; + /** + * Sets the integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes: RestOrArray): this; + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether or not to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + setDefaultPermission(value: boolean): this; + /** + * Sets the default permissions a member should have in order to run the command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined): this; + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated + * Use {@link SharedSlashCommand.setContexts} instead. + */ + setDMPermission(enabled: boolean | null | undefined): this; + /** + * Sets whether this command is NSFW. + * + * @param nsfw - Whether this command is NSFW + */ + setNSFW(nsfw?: boolean): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): RESTPostAPIChatInputApplicationCommandsJSONBody; +} + +/** + * The base application command option builder that contains common symbols for application command builders. + */ +declare abstract class ApplicationCommandOptionBase extends SharedNameAndDescription { + /** + * The type of this option. + */ + abstract readonly type: ApplicationCommandOptionType; + /** + * Whether this option is required. + * + * @defaultValue `false` + */ + readonly required: boolean; + /** + * Sets whether this option is required. + * + * @param required - Whether this option should be required + */ + setRequired(required: boolean): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + abstract toJSON(): APIApplicationCommandBasicOption; + /** + * This method runs required validators on this builder. + */ + protected runRequiredValidations(): void; +} + +/** + * A slash command attachment option. + */ +declare class SlashCommandAttachmentOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Attachment; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandAttachmentOption; +} + +/** + * A slash command boolean option. + */ +declare class SlashCommandBooleanOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Boolean; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandBooleanOption; +} + +/** + * The allowed channel types used for a channel option in a slash command builder. + * + * @privateRemarks This can't be dynamic because const enums are erased at runtime. + * @internal + */ +declare const allowedChannelTypes: readonly [ChannelType.GuildText, ChannelType.GuildVoice, ChannelType.GuildCategory, ChannelType.GuildAnnouncement, ChannelType.AnnouncementThread, ChannelType.PublicThread, ChannelType.PrivateThread, ChannelType.GuildStageVoice, ChannelType.GuildForum, ChannelType.GuildMedia]; +/** + * The type of allowed channel types used for a channel option. + */ +type ApplicationCommandOptionAllowedChannelTypes = (typeof allowedChannelTypes)[number]; +/** + * This mixin holds channel type symbols used for options. + */ +declare class ApplicationCommandOptionChannelTypesMixin { + /** + * The channel types of this option. + */ + readonly channel_types?: ApplicationCommandOptionAllowedChannelTypes[]; + /** + * Adds channel types to this option. + * + * @param channelTypes - The channel types + */ + addChannelTypes(...channelTypes: RestOrArray): this; +} + +/** + * A slash command channel option. + */ +declare class SlashCommandChannelOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Channel; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandChannelOption; +} +interface SlashCommandChannelOption extends ApplicationCommandOptionChannelTypesMixin { +} + +/** + * This mixin holds minimum and maximum symbols used for options. + */ +declare abstract class ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The maximum value of this option. + */ + readonly max_value?: number; + /** + * The minimum value of this option. + */ + readonly min_value?: number; + /** + * Sets the maximum number value of this option. + * + * @param max - The maximum value this option can be + */ + abstract setMaxValue(max: number): this; + /** + * Sets the minimum number value of this option. + * + * @param min - The minimum value this option can be + */ + abstract setMinValue(min: number): this; +} + +/** + * This mixin holds choices and autocomplete symbols used for options. + */ +declare class ApplicationCommandOptionWithAutocompleteMixin { + /** + * Whether this option utilizes autocomplete. + */ + readonly autocomplete?: boolean; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + readonly type: ApplicationCommandOptionType; + /** + * Whether this option uses autocomplete. + * + * @param autocomplete - Whether this option should use autocomplete + */ + setAutocomplete(autocomplete: boolean): this; +} + +/** + * This mixin holds choices and autocomplete symbols used for options. + */ +declare class ApplicationCommandOptionWithChoicesMixin { + /** + * The choices of this option. + */ + readonly choices?: APIApplicationCommandOptionChoice[]; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + readonly type: ApplicationCommandOptionType; + /** + * Adds multiple choices to this option. + * + * @param choices - The choices to add + */ + addChoices(...choices: RestOrArray>): this; + /** + * Sets multiple choices for this option. + * + * @param choices - The choices to set + */ + setChoices>(...choices: RestOrArray): this; +} + +/** + * A slash command integer option. + */ +declare class SlashCommandIntegerOption extends ApplicationCommandOptionBase implements ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Integer; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max: number): this; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandIntegerOption; +} +interface SlashCommandIntegerOption extends ApplicationCommandNumericOptionMinMaxValueMixin, ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command mentionable option. + */ +declare class SlashCommandMentionableOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Mentionable; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandMentionableOption; +} + +/** + * A slash command number option. + */ +declare class SlashCommandNumberOption extends ApplicationCommandOptionBase implements ApplicationCommandNumericOptionMinMaxValueMixin { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Number; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max: number): this; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandNumberOption; +} +interface SlashCommandNumberOption extends ApplicationCommandNumericOptionMinMaxValueMixin, ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command role option. + */ +declare class SlashCommandRoleOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.Role; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandRoleOption; +} + +/** + * A slash command string option. + */ +declare class SlashCommandStringOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.String; + /** + * The maximum length of this option. + */ + readonly max_length?: number; + /** + * The minimum length of this option. + */ + readonly min_length?: number; + /** + * Sets the maximum length of this string option. + * + * @param max - The maximum length this option can be + */ + setMaxLength(max: number): this; + /** + * Sets the minimum length of this string option. + * + * @param min - The minimum length this option can be + */ + setMinLength(min: number): this; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandStringOption; +} +interface SlashCommandStringOption extends ApplicationCommandOptionWithChoicesMixin, ApplicationCommandOptionWithAutocompleteMixin { +} + +/** + * A slash command user option. + */ +declare class SlashCommandUserOption extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + readonly type: ApplicationCommandOptionType.User; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON(): APIApplicationCommandUserOption; +} + +/** + * This mixin holds symbols that can be shared in slash command options. + * + * @typeParam TypeAfterAddingOptions - The type this class should return after adding an option. + */ +declare class SharedSlashCommandOptions> { + readonly options: ToAPIApplicationCommandOptions[]; + /** + * Adds a boolean option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addBooleanOption(input: SlashCommandBooleanOption | ((builder: SlashCommandBooleanOption) => SlashCommandBooleanOption)): TypeAfterAddingOptions; + /** + * Adds a user option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addUserOption(input: SlashCommandUserOption | ((builder: SlashCommandUserOption) => SlashCommandUserOption)): TypeAfterAddingOptions; + /** + * Adds a channel option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addChannelOption(input: SlashCommandChannelOption | ((builder: SlashCommandChannelOption) => SlashCommandChannelOption)): TypeAfterAddingOptions; + /** + * Adds a role option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addRoleOption(input: SlashCommandRoleOption | ((builder: SlashCommandRoleOption) => SlashCommandRoleOption)): TypeAfterAddingOptions; + /** + * Adds an attachment option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addAttachmentOption(input: SlashCommandAttachmentOption | ((builder: SlashCommandAttachmentOption) => SlashCommandAttachmentOption)): TypeAfterAddingOptions; + /** + * Adds a mentionable option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addMentionableOption(input: SlashCommandMentionableOption | ((builder: SlashCommandMentionableOption) => SlashCommandMentionableOption)): TypeAfterAddingOptions; + /** + * Adds a string option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addStringOption(input: SlashCommandStringOption | ((builder: SlashCommandStringOption) => SlashCommandStringOption)): TypeAfterAddingOptions; + /** + * Adds an integer option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addIntegerOption(input: SlashCommandIntegerOption | ((builder: SlashCommandIntegerOption) => SlashCommandIntegerOption)): TypeAfterAddingOptions; + /** + * Adds a number option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addNumberOption(input: SlashCommandNumberOption | ((builder: SlashCommandNumberOption) => SlashCommandNumberOption)): TypeAfterAddingOptions; + /** + * Where the actual adding magic happens. ✨ + * + * @param input - The input. What else? + * @param Instance - The instance of whatever is being added + * @internal + */ + private _sharedAddOptionMethod; +} + +/** + * Represents a folder for subcommands. + * + * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups} + */ +declare class SlashCommandSubcommandGroupBuilder implements ToAPIApplicationCommandOptions { + /** + * The name of this subcommand group. + */ + readonly name: string; + /** + * The description of this subcommand group. + */ + readonly description: string; + /** + * The subcommands within this subcommand group. + */ + readonly options: SlashCommandSubcommandBuilder[]; + /** + * Adds a new subcommand to this group. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input: SlashCommandSubcommandBuilder | ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder)): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIApplicationCommandSubcommandGroupOption; +} +interface SlashCommandSubcommandGroupBuilder extends SharedNameAndDescription { +} +/** + * A builder that creates API-compatible JSON data for slash command subcommands. + * + * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups} + */ +declare class SlashCommandSubcommandBuilder implements ToAPIApplicationCommandOptions { + /** + * The name of this subcommand. + */ + readonly name: string; + /** + * The description of this subcommand. + */ + readonly description: string; + /** + * The options within this subcommand. + */ + readonly options: ApplicationCommandOptionBase[]; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): APIApplicationCommandSubcommandOption; +} +interface SlashCommandSubcommandBuilder extends SharedNameAndDescription, SharedSlashCommandOptions { +} + +/** + * This mixin holds symbols that can be shared in slash subcommands. + * + * @typeParam TypeAfterAddingSubcommands - The type this class should return after adding a subcommand or subcommand group. + */ +declare class SharedSlashCommandSubcommands> { + readonly options: ToAPIApplicationCommandOptions[]; + /** + * Adds a new subcommand group to this command. + * + * @param input - A function that returns a subcommand group builder or an already built builder + */ + addSubcommandGroup(input: SlashCommandSubcommandGroupBuilder | ((subcommandGroup: SlashCommandSubcommandGroupBuilder) => SlashCommandSubcommandGroupBuilder)): TypeAfterAddingSubcommands; + /** + * Adds a new subcommand to this command. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input: SlashCommandSubcommandBuilder | ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder)): TypeAfterAddingSubcommands; +} + +/** + * A builder that creates API-compatible JSON data for slash commands. + */ +declare class SlashCommandBuilder { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The description of this command. + */ + readonly description: string; + /** + * The description localizations of this command. + */ + readonly description_localizations?: LocalizationMap; + /** + * The options of this command. + */ + readonly options: ToAPIApplicationCommandOptions[]; + /** + * The contexts for this command. + */ + readonly contexts?: InteractionContextType[]; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + /** + * The set of permissions represented as a bit set for the command. + */ + readonly default_member_permissions: Permissions | null | undefined; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link SlashCommandBuilder.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + /** + * The integration types for this command. + */ + readonly integration_types?: ApplicationIntegrationType[]; + /** + * Whether this command is NSFW. + */ + readonly nsfw: boolean | undefined; +} +interface SlashCommandBuilder extends SharedNameAndDescription, SharedSlashCommandOptions, SharedSlashCommandSubcommands, SharedSlashCommand { +} +/** + * An interface specifically for slash command subcommands. + */ +interface SlashCommandSubcommandsOnlyBuilder extends SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand { +} +/** + * An interface specifically for slash command options. + */ +interface SlashCommandOptionsOnlyBuilder extends SharedNameAndDescription, SharedSlashCommandOptions, SharedSlashCommand { +} +/** + * An interface that ensures the `toJSON()` call will return something + * that can be serialized into API-compatible data. + */ +interface ToAPIApplicationCommandOptions { + toJSON(): APIApplicationCommandOption; +} + +declare function validateName$1(name: unknown): asserts name is string; +declare function validateDescription(description: unknown): asserts description is string; +declare function validateLocale(locale: unknown): Locale; +declare function validateMaxOptionsLength(options: unknown): asserts options is ToAPIApplicationCommandOptions[]; +declare function validateRequiredParameters$1(name: string, description: string, options: ToAPIApplicationCommandOptions[]): void; +declare function validateDefaultPermission$1(value: unknown): asserts value is boolean; +declare function validateRequired(required: unknown): asserts required is boolean; +declare function validateChoicesLength(amountAdding: number, choices?: APIApplicationCommandOptionChoice[]): void; +declare function assertReturnOfBuilder(input: unknown, ExpectedInstanceOf: new () => ReturnType): asserts input is ReturnType; +declare const localizationMapPredicate: _sapphire_shapeshift.UnionValidator<_sapphire_shapeshift.UndefinedToOptional>> | null | undefined>; +declare function validateLocalizationMap(value: unknown): asserts value is LocalizationMap; +declare function validateDMPermission$1(value: unknown): asserts value is boolean | null | undefined; +declare function validateDefaultMemberPermissions$1(permissions: unknown): string | null | undefined; +declare function validateNSFW(value: unknown): asserts value is boolean; +declare const contextsPredicate$1: _sapphire_shapeshift.ArrayValidator; +declare const integrationTypesPredicate$1: _sapphire_shapeshift.ArrayValidator; + +declare const Assertions$1_assertReturnOfBuilder: typeof assertReturnOfBuilder; +declare const Assertions$1_localizationMapPredicate: typeof localizationMapPredicate; +declare const Assertions$1_validateChoicesLength: typeof validateChoicesLength; +declare const Assertions$1_validateDescription: typeof validateDescription; +declare const Assertions$1_validateLocale: typeof validateLocale; +declare const Assertions$1_validateLocalizationMap: typeof validateLocalizationMap; +declare const Assertions$1_validateMaxOptionsLength: typeof validateMaxOptionsLength; +declare const Assertions$1_validateNSFW: typeof validateNSFW; +declare const Assertions$1_validateRequired: typeof validateRequired; +declare namespace Assertions$1 { + export { Assertions$1_assertReturnOfBuilder as assertReturnOfBuilder, contextsPredicate$1 as contextsPredicate, integrationTypesPredicate$1 as integrationTypesPredicate, Assertions$1_localizationMapPredicate as localizationMapPredicate, Assertions$1_validateChoicesLength as validateChoicesLength, validateDMPermission$1 as validateDMPermission, validateDefaultMemberPermissions$1 as validateDefaultMemberPermissions, validateDefaultPermission$1 as validateDefaultPermission, Assertions$1_validateDescription as validateDescription, Assertions$1_validateLocale as validateLocale, Assertions$1_validateLocalizationMap as validateLocalizationMap, Assertions$1_validateMaxOptionsLength as validateMaxOptionsLength, Assertions$1_validateNSFW as validateNSFW, validateName$1 as validateName, Assertions$1_validateRequired as validateRequired, validateRequiredParameters$1 as validateRequiredParameters }; +} + +/** + * The type a context menu command can be. + */ +type ContextMenuCommandType = ApplicationCommandType.Message | ApplicationCommandType.User; +/** + * A builder that creates API-compatible JSON data for context menu commands. + */ +declare class ContextMenuCommandBuilder { + /** + * The name of this command. + */ + readonly name: string; + /** + * The name localizations of this command. + */ + readonly name_localizations?: LocalizationMap; + /** + * The type of this command. + */ + readonly type: ContextMenuCommandType; + /** + * The contexts for this command. + */ + readonly contexts?: InteractionContextType[]; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + readonly default_permission: boolean | undefined; + /** + * The set of permissions represented as a bit set for the command. + */ + readonly default_member_permissions: Permissions | null | undefined; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link ContextMenuCommandBuilder.contexts} instead. + */ + readonly dm_permission: boolean | undefined; + /** + * The integration types for this command. + */ + readonly integration_types?: ApplicationIntegrationType[]; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts: RestOrArray): this; + /** + * Sets integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes: RestOrArray): this; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name: string): this; + /** + * Sets the type of this command. + * + * @param type - The type to use + */ + setType(type: ContextMenuCommandType): this; + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + setDefaultPermission(value: boolean): this; + /** + * Sets the default permissions a member should have in order to run this command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined): this; + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead. + */ + setDMPermission(enabled: boolean | null | undefined): this; + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale: LocaleString, localizedName: string | null): this; + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames: LocalizationMap | null): this; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON(): RESTPostAPIContextMenuApplicationCommandsJSONBody; +} + +declare function validateDefaultPermission(value: unknown): asserts value is boolean; +declare function validateName(name: unknown): asserts name is string; +declare function validateType(type: unknown): asserts type is ContextMenuCommandType; +declare function validateRequiredParameters(name: string, type: number): void; +declare function validateDMPermission(value: unknown): asserts value is boolean | null | undefined; +declare function validateDefaultMemberPermissions(permissions: unknown): string | null | undefined; +declare const contextsPredicate: _sapphire_shapeshift.ArrayValidator; +declare const integrationTypesPredicate: _sapphire_shapeshift.ArrayValidator; + +declare const Assertions_contextsPredicate: typeof contextsPredicate; +declare const Assertions_integrationTypesPredicate: typeof integrationTypesPredicate; +declare const Assertions_validateDMPermission: typeof validateDMPermission; +declare const Assertions_validateDefaultMemberPermissions: typeof validateDefaultMemberPermissions; +declare const Assertions_validateDefaultPermission: typeof validateDefaultPermission; +declare const Assertions_validateName: typeof validateName; +declare const Assertions_validateRequiredParameters: typeof validateRequiredParameters; +declare const Assertions_validateType: typeof validateType; +declare namespace Assertions { + export { Assertions_contextsPredicate as contextsPredicate, Assertions_integrationTypesPredicate as integrationTypesPredicate, Assertions_validateDMPermission as validateDMPermission, Assertions_validateDefaultMemberPermissions as validateDefaultMemberPermissions, Assertions_validateDefaultPermission as validateDefaultPermission, Assertions_validateName as validateName, Assertions_validateRequiredParameters as validateRequiredParameters, Assertions_validateType as validateType }; +} + +/** + * Calculates the length of the embed. + * + * @param data - The embed data to check + */ +declare function embedLength(data: APIEmbed): number; + +/** + * Enables validators. + * + * @returns Whether validation is occurring. + */ +declare function enableValidators(): boolean; +/** + * Disables validators. + * + * @returns Whether validation is occurring. + */ +declare function disableValidators(): boolean; +/** + * Checks whether validation is occurring. + */ +declare function isValidationEnabled(): boolean; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/builders#readme | @discordjs/builders} version + * that you are currently using. + * + * @privateRemarks This needs to explicitly be `string` so it is not typed as a "const string" that gets injected by esbuild. + */ +declare const version: string; + +export { ActionRowBuilder, type AnyAPIActionRowComponent, type AnyComponentBuilder, ApplicationCommandNumericOptionMinMaxValueMixin, type ApplicationCommandOptionAllowedChannelTypes, ApplicationCommandOptionBase, ApplicationCommandOptionChannelTypesMixin, ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin, BaseSelectMenuBuilder, ButtonBuilder, ChannelSelectMenuBuilder, Assertions$4 as ComponentAssertions, ComponentBuilder, Assertions as ContextMenuCommandAssertions, ContextMenuCommandBuilder, type ContextMenuCommandType, Assertions$5 as EmbedAssertions, type EmbedAuthorData, type EmbedAuthorOptions, EmbedBuilder, type EmbedFooterData, type EmbedFooterOptions, type EmbedImageData, type IconData, type MappedComponentTypes, MentionableSelectMenuBuilder, type MessageActionRowComponentBuilder, type MessageComponentBuilder, type ModalActionRowComponentBuilder, Assertions$2 as ModalAssertions, ModalBuilder, type ModalComponentBuilder, type RGBTuple, type RestOrArray, RoleSelectMenuBuilder, StringSelectMenuBuilder as SelectMenuBuilder, StringSelectMenuOptionBuilder as SelectMenuOptionBuilder, SharedNameAndDescription, SharedSlashCommand, SharedSlashCommandOptions, SharedSlashCommandSubcommands, Assertions$1 as SlashCommandAssertions, SlashCommandAttachmentOption, SlashCommandBooleanOption, SlashCommandBuilder, SlashCommandChannelOption, SlashCommandIntegerOption, SlashCommandMentionableOption, SlashCommandNumberOption, type SlashCommandOptionsOnlyBuilder, SlashCommandRoleOption, SlashCommandStringOption, SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder, type SlashCommandSubcommandsOnlyBuilder, SlashCommandUserOption, StringSelectMenuBuilder, StringSelectMenuOptionBuilder, Assertions$3 as TextInputAssertions, TextInputBuilder, type ToAPIApplicationCommandOptions, UserSelectMenuBuilder, createComponentBuilder, disableValidators, embedLength, enableValidators, isValidationEnabled, normalizeArray, version }; diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js new file mode 100644 index 0000000..e229e15 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js @@ -0,0 +1,2916 @@ +"use strict"; +var __create = Object.create; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __getProtoOf = Object.getPrototypeOf; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key) && key !== except) + __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); + } + return to; +}; +var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default")); +var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( + // If the importer is in node compatibility mode or this is not an ESM + // file that has been converted to a CommonJS file using a Babel- + // compatible transform (i.e. "__esModule" has not been set), then set + // "default" to the CommonJS "module.exports" for node compatibility. + isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, + mod +)); +var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); +var __decorateClass = (decorators, target, key, kind) => { + var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target; + for (var i = decorators.length - 1, decorator; i >= 0; i--) + if (decorator = decorators[i]) + result = (kind ? decorator(target, key, result) : decorator(result)) || result; + if (kind && result) __defProp(target, key, result); + return result; +}; + +// src/index.ts +var src_exports = {}; +__export(src_exports, { + ActionRowBuilder: () => ActionRowBuilder, + ApplicationCommandNumericOptionMinMaxValueMixin: () => ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionBase: () => ApplicationCommandOptionBase, + ApplicationCommandOptionChannelTypesMixin: () => ApplicationCommandOptionChannelTypesMixin, + ApplicationCommandOptionWithAutocompleteMixin: () => ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin: () => ApplicationCommandOptionWithChoicesMixin, + BaseSelectMenuBuilder: () => BaseSelectMenuBuilder, + ButtonBuilder: () => ButtonBuilder, + ChannelSelectMenuBuilder: () => ChannelSelectMenuBuilder, + ComponentAssertions: () => Assertions_exports2, + ComponentBuilder: () => ComponentBuilder, + ContextMenuCommandAssertions: () => Assertions_exports6, + ContextMenuCommandBuilder: () => ContextMenuCommandBuilder, + EmbedAssertions: () => Assertions_exports, + EmbedBuilder: () => EmbedBuilder, + MentionableSelectMenuBuilder: () => MentionableSelectMenuBuilder, + ModalAssertions: () => Assertions_exports4, + ModalBuilder: () => ModalBuilder, + RoleSelectMenuBuilder: () => RoleSelectMenuBuilder, + SelectMenuBuilder: () => StringSelectMenuBuilder, + SelectMenuOptionBuilder: () => StringSelectMenuOptionBuilder, + SharedNameAndDescription: () => SharedNameAndDescription, + SharedSlashCommand: () => SharedSlashCommand, + SharedSlashCommandOptions: () => SharedSlashCommandOptions, + SharedSlashCommandSubcommands: () => SharedSlashCommandSubcommands, + SlashCommandAssertions: () => Assertions_exports5, + SlashCommandAttachmentOption: () => SlashCommandAttachmentOption, + SlashCommandBooleanOption: () => SlashCommandBooleanOption, + SlashCommandBuilder: () => SlashCommandBuilder, + SlashCommandChannelOption: () => SlashCommandChannelOption, + SlashCommandIntegerOption: () => SlashCommandIntegerOption, + SlashCommandMentionableOption: () => SlashCommandMentionableOption, + SlashCommandNumberOption: () => SlashCommandNumberOption, + SlashCommandRoleOption: () => SlashCommandRoleOption, + SlashCommandStringOption: () => SlashCommandStringOption, + SlashCommandSubcommandBuilder: () => SlashCommandSubcommandBuilder, + SlashCommandSubcommandGroupBuilder: () => SlashCommandSubcommandGroupBuilder, + SlashCommandUserOption: () => SlashCommandUserOption, + StringSelectMenuBuilder: () => StringSelectMenuBuilder, + StringSelectMenuOptionBuilder: () => StringSelectMenuOptionBuilder, + TextInputAssertions: () => Assertions_exports3, + TextInputBuilder: () => TextInputBuilder, + UserSelectMenuBuilder: () => UserSelectMenuBuilder, + createComponentBuilder: () => createComponentBuilder, + disableValidators: () => disableValidators, + embedLength: () => embedLength, + enableValidators: () => enableValidators, + isValidationEnabled: () => isValidationEnabled, + normalizeArray: () => normalizeArray, + version: () => version +}); +module.exports = __toCommonJS(src_exports); + +// src/messages/embed/Assertions.ts +var Assertions_exports = {}; +__export(Assertions_exports, { + RGBPredicate: () => RGBPredicate, + authorNamePredicate: () => authorNamePredicate, + colorPredicate: () => colorPredicate, + descriptionPredicate: () => descriptionPredicate, + embedAuthorPredicate: () => embedAuthorPredicate, + embedFieldPredicate: () => embedFieldPredicate, + embedFieldsArrayPredicate: () => embedFieldsArrayPredicate, + embedFooterPredicate: () => embedFooterPredicate, + fieldInlinePredicate: () => fieldInlinePredicate, + fieldLengthPredicate: () => fieldLengthPredicate, + fieldNamePredicate: () => fieldNamePredicate, + fieldValuePredicate: () => fieldValuePredicate, + footerTextPredicate: () => footerTextPredicate, + imageURLPredicate: () => imageURLPredicate, + timestampPredicate: () => timestampPredicate, + titlePredicate: () => titlePredicate, + urlPredicate: () => urlPredicate, + validateFieldLength: () => validateFieldLength +}); +var import_shapeshift = require("@sapphire/shapeshift"); + +// src/util/validation.ts +var validate = true; +function enableValidators() { + return validate = true; +} +__name(enableValidators, "enableValidators"); +function disableValidators() { + return validate = false; +} +__name(disableValidators, "disableValidators"); +function isValidationEnabled() { + return validate; +} +__name(isValidationEnabled, "isValidationEnabled"); + +// src/messages/embed/Assertions.ts +var fieldNamePredicate = import_shapeshift.s.string().lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled); +var fieldValuePredicate = import_shapeshift.s.string().lengthLessThanOrEqual(1024).setValidationEnabled(isValidationEnabled); +var fieldInlinePredicate = import_shapeshift.s.boolean().optional(); +var embedFieldPredicate = import_shapeshift.s.object({ + name: fieldNamePredicate, + value: fieldValuePredicate, + inline: fieldInlinePredicate +}).setValidationEnabled(isValidationEnabled); +var embedFieldsArrayPredicate = embedFieldPredicate.array().setValidationEnabled(isValidationEnabled); +var fieldLengthPredicate = import_shapeshift.s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateFieldLength(amountAdding, fields) { + fieldLengthPredicate.parse((fields?.length ?? 0) + amountAdding); +} +__name(validateFieldLength, "validateFieldLength"); +var authorNamePredicate = fieldNamePredicate.lengthGreaterThanOrEqual(1).nullable().setValidationEnabled(isValidationEnabled); +var imageURLPredicate = import_shapeshift.s.string().url({ + allowedProtocols: ["http:", "https:", "attachment:"] +}).nullish().setValidationEnabled(isValidationEnabled); +var urlPredicate = import_shapeshift.s.string().url({ + allowedProtocols: ["http:", "https:"] +}).nullish().setValidationEnabled(isValidationEnabled); +var embedAuthorPredicate = import_shapeshift.s.object({ + name: authorNamePredicate, + iconURL: imageURLPredicate, + url: urlPredicate +}).setValidationEnabled(isValidationEnabled); +var RGBPredicate = import_shapeshift.s.number().int().greaterThanOrEqual(0).lessThanOrEqual(255).setValidationEnabled(isValidationEnabled); +var colorPredicate = import_shapeshift.s.number().int().greaterThanOrEqual(0).lessThanOrEqual(16777215).or(import_shapeshift.s.tuple([RGBPredicate, RGBPredicate, RGBPredicate])).nullable().setValidationEnabled(isValidationEnabled); +var descriptionPredicate = import_shapeshift.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(4096).nullable().setValidationEnabled(isValidationEnabled); +var footerTextPredicate = import_shapeshift.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(2048).nullable().setValidationEnabled(isValidationEnabled); +var embedFooterPredicate = import_shapeshift.s.object({ + text: footerTextPredicate, + iconURL: imageURLPredicate +}).setValidationEnabled(isValidationEnabled); +var timestampPredicate = import_shapeshift.s.union([import_shapeshift.s.number(), import_shapeshift.s.date()]).nullable().setValidationEnabled(isValidationEnabled); +var titlePredicate = fieldNamePredicate.lengthGreaterThanOrEqual(1).nullable().setValidationEnabled(isValidationEnabled); + +// src/util/normalizeArray.ts +function normalizeArray(arr) { + if (Array.isArray(arr[0])) return [...arr[0]]; + return arr; +} +__name(normalizeArray, "normalizeArray"); + +// src/messages/embed/Embed.ts +var EmbedBuilder = class { + static { + __name(this, "EmbedBuilder"); + } + /** + * The API data associated with this embed. + */ + data; + /** + * Creates a new embed from API data. + * + * @param data - The API data to create this embed with + */ + constructor(data = {}) { + this.data = { ...data }; + if (data.timestamp) this.data.timestamp = new Date(data.timestamp).toISOString(); + } + /** + * Appends fields to the embed. + * + * @remarks + * This method accepts either an array of fields or a variable number of field parameters. + * The maximum amount of fields that can be added is 25. + * @example + * Using an array: + * ```ts + * const fields: APIEmbedField[] = ...; + * const embed = new EmbedBuilder() + * .addFields(fields); + * ``` + * @example + * Using rest parameters (variadic): + * ```ts + * const embed = new EmbedBuilder() + * .addFields( + * { name: 'Field 1', value: 'Value 1' }, + * { name: 'Field 2', value: 'Value 2' }, + * ); + * ``` + * @param fields - The fields to add + */ + addFields(...fields) { + const normalizedFields = normalizeArray(fields); + validateFieldLength(normalizedFields.length, this.data.fields); + embedFieldsArrayPredicate.parse(normalizedFields); + if (this.data.fields) this.data.fields.push(...normalizedFields); + else this.data.fields = normalizedFields; + return this; + } + /** + * Removes, replaces, or inserts fields for this embed. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}. + * The maximum amount of fields that can be added is 25. + * + * It's useful for modifying and adjusting order of the already-existing fields of an embed. + * @example + * Remove the first field: + * ```ts + * embed.spliceFields(0, 1); + * ``` + * @example + * Remove the first n fields: + * ```ts + * const n = 4; + * embed.spliceFields(0, n); + * ``` + * @example + * Remove the last field: + * ```ts + * embed.spliceFields(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of fields to remove + * @param fields - The replacing field objects + */ + spliceFields(index, deleteCount, ...fields) { + validateFieldLength(fields.length - deleteCount, this.data.fields); + embedFieldsArrayPredicate.parse(fields); + if (this.data.fields) this.data.fields.splice(index, deleteCount, ...fields); + else this.data.fields = fields; + return this; + } + /** + * Sets the fields for this embed. + * + * @remarks + * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically, + * it splices the entire array of fields, replacing them with the provided fields. + * + * You can set a maximum of 25 fields. + * @param fields - The fields to set + */ + setFields(...fields) { + this.spliceFields(0, this.data.fields?.length ?? 0, ...normalizeArray(fields)); + return this; + } + /** + * Sets the author of this embed. + * + * @param options - The options to use + */ + setAuthor(options) { + if (options === null) { + this.data.author = void 0; + return this; + } + embedAuthorPredicate.parse(options); + this.data.author = { name: options.name, url: options.url, icon_url: options.iconURL }; + return this; + } + /** + * Sets the color of this embed. + * + * @param color - The color to use + */ + setColor(color) { + colorPredicate.parse(color); + if (Array.isArray(color)) { + const [red, green, blue] = color; + this.data.color = (red << 16) + (green << 8) + blue; + return this; + } + this.data.color = color ?? void 0; + return this; + } + /** + * Sets the description of this embed. + * + * @param description - The description to use + */ + setDescription(description) { + descriptionPredicate.parse(description); + this.data.description = description ?? void 0; + return this; + } + /** + * Sets the footer of this embed. + * + * @param options - The footer to use + */ + setFooter(options) { + if (options === null) { + this.data.footer = void 0; + return this; + } + embedFooterPredicate.parse(options); + this.data.footer = { text: options.text, icon_url: options.iconURL }; + return this; + } + /** + * Sets the image of this embed. + * + * @param url - The image URL to use + */ + setImage(url) { + imageURLPredicate.parse(url); + this.data.image = url ? { url } : void 0; + return this; + } + /** + * Sets the thumbnail of this embed. + * + * @param url - The thumbnail URL to use + */ + setThumbnail(url) { + imageURLPredicate.parse(url); + this.data.thumbnail = url ? { url } : void 0; + return this; + } + /** + * Sets the timestamp of this embed. + * + * @param timestamp - The timestamp or date to use + */ + setTimestamp(timestamp = Date.now()) { + timestampPredicate.parse(timestamp); + this.data.timestamp = timestamp ? new Date(timestamp).toISOString() : void 0; + return this; + } + /** + * Sets the title for this embed. + * + * @param title - The title to use + */ + setTitle(title) { + titlePredicate.parse(title); + this.data.title = title ?? void 0; + return this; + } + /** + * Sets the URL of this embed. + * + * @param url - The URL to use + */ + setURL(url) { + urlPredicate.parse(url); + this.data.url = url ?? void 0; + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + return { ...this.data }; + } +}; + +// src/index.ts +__reExport(src_exports, require("@discordjs/formatters"), module.exports); + +// src/components/Assertions.ts +var Assertions_exports2 = {}; +__export(Assertions_exports2, { + buttonLabelValidator: () => buttonLabelValidator, + buttonStyleValidator: () => buttonStyleValidator, + channelTypesValidator: () => channelTypesValidator, + customIdValidator: () => customIdValidator, + defaultValidator: () => defaultValidator, + disabledValidator: () => disabledValidator, + emojiValidator: () => emojiValidator, + jsonOptionValidator: () => jsonOptionValidator, + labelValueDescriptionValidator: () => labelValueDescriptionValidator, + minMaxValidator: () => minMaxValidator, + optionValidator: () => optionValidator, + optionsLengthValidator: () => optionsLengthValidator, + optionsValidator: () => optionsValidator, + placeholderValidator: () => placeholderValidator, + urlValidator: () => urlValidator, + validateRequiredButtonParameters: () => validateRequiredButtonParameters, + validateRequiredSelectMenuOptionParameters: () => validateRequiredSelectMenuOptionParameters, + validateRequiredSelectMenuParameters: () => validateRequiredSelectMenuParameters +}); +var import_shapeshift2 = require("@sapphire/shapeshift"); +var import_v10 = require("discord-api-types/v10"); + +// src/components/selectMenu/StringSelectMenuOption.ts +var StringSelectMenuOptionBuilder = class { + /** + * Creates a new string select menu option from API data. + * + * @param data - The API data to create this string select menu option with + * @example + * Creating a string select menu option from an API data object: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * label: 'catchy label', + * value: '1', + * }); + * ``` + * @example + * Creating a string select menu option using setters and API data: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * default: true, + * value: '1', + * }) + * .setLabel('woah'); + * ``` + */ + constructor(data = {}) { + this.data = data; + } + static { + __name(this, "StringSelectMenuOptionBuilder"); + } + /** + * Sets the label for this option. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = labelValueDescriptionValidator.parse(label); + return this; + } + /** + * Sets the value for this option. + * + * @param value - The value to use + */ + setValue(value) { + this.data.value = labelValueDescriptionValidator.parse(value); + return this; + } + /** + * Sets the description for this option. + * + * @param description - The description to use + */ + setDescription(description) { + this.data.description = labelValueDescriptionValidator.parse(description); + return this; + } + /** + * Sets whether this option is selected by default. + * + * @param isDefault - Whether this option is selected by default + */ + setDefault(isDefault = true) { + this.data.default = defaultValidator.parse(isDefault); + return this; + } + /** + * Sets the emoji to display for this option. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji) { + this.data.emoji = emojiValidator.parse(emoji); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + validateRequiredSelectMenuOptionParameters(this.data.label, this.data.value); + return { + ...this.data + }; + } +}; + +// src/components/Assertions.ts +var customIdValidator = import_shapeshift2.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var emojiValidator = import_shapeshift2.s.object({ + id: import_shapeshift2.s.string(), + name: import_shapeshift2.s.string(), + animated: import_shapeshift2.s.boolean() +}).partial().strict().setValidationEnabled(isValidationEnabled); +var disabledValidator = import_shapeshift2.s.boolean(); +var buttonLabelValidator = import_shapeshift2.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(80).setValidationEnabled(isValidationEnabled); +var buttonStyleValidator = import_shapeshift2.s.nativeEnum(import_v10.ButtonStyle); +var placeholderValidator = import_shapeshift2.s.string().lengthLessThanOrEqual(150).setValidationEnabled(isValidationEnabled); +var minMaxValidator = import_shapeshift2.s.number().int().greaterThanOrEqual(0).lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +var labelValueDescriptionValidator = import_shapeshift2.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var jsonOptionValidator = import_shapeshift2.s.object({ + label: labelValueDescriptionValidator, + value: labelValueDescriptionValidator, + description: labelValueDescriptionValidator.optional(), + emoji: emojiValidator.optional(), + default: import_shapeshift2.s.boolean().optional() +}).setValidationEnabled(isValidationEnabled); +var optionValidator = import_shapeshift2.s.instance(StringSelectMenuOptionBuilder).setValidationEnabled(isValidationEnabled); +var optionsValidator = optionValidator.array().lengthGreaterThanOrEqual(0).setValidationEnabled(isValidationEnabled); +var optionsLengthValidator = import_shapeshift2.s.number().int().greaterThanOrEqual(0).lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateRequiredSelectMenuParameters(options, customId) { + customIdValidator.parse(customId); + optionsValidator.parse(options); +} +__name(validateRequiredSelectMenuParameters, "validateRequiredSelectMenuParameters"); +var defaultValidator = import_shapeshift2.s.boolean(); +function validateRequiredSelectMenuOptionParameters(label, value) { + labelValueDescriptionValidator.parse(label); + labelValueDescriptionValidator.parse(value); +} +__name(validateRequiredSelectMenuOptionParameters, "validateRequiredSelectMenuOptionParameters"); +var channelTypesValidator = import_shapeshift2.s.nativeEnum(import_v10.ChannelType).array().setValidationEnabled(isValidationEnabled); +var urlValidator = import_shapeshift2.s.string().url({ + allowedProtocols: ["http:", "https:", "discord:"] +}).setValidationEnabled(isValidationEnabled); +function validateRequiredButtonParameters(style, label, emoji, customId, skuId, url) { + if (style === import_v10.ButtonStyle.Premium) { + if (!skuId) { + throw new RangeError("Premium buttons must have an SKU id."); + } + if (customId || label || url || emoji) { + throw new RangeError("Premium buttons cannot have a custom id, label, URL, or emoji."); + } + } else { + if (skuId) { + throw new RangeError("Non-premium buttons must not have an SKU id."); + } + if (url && customId) { + throw new RangeError("URL and custom id are mutually exclusive."); + } + if (!label && !emoji) { + throw new RangeError("Non-premium buttons must have a label and/or an emoji."); + } + if (style === import_v10.ButtonStyle.Link) { + if (!url) { + throw new RangeError("Link buttons must have a URL."); + } + } else if (url) { + throw new RangeError("Non-premium and non-link buttons cannot have a URL."); + } + } +} +__name(validateRequiredButtonParameters, "validateRequiredButtonParameters"); + +// src/components/ActionRow.ts +var import_v1011 = require("discord-api-types/v10"); + +// src/components/Component.ts +var ComponentBuilder = class { + static { + __name(this, "ComponentBuilder"); + } + /** + * The API data associated with this component. + */ + data; + /** + * Constructs a new kind of component. + * + * @param data - The data to construct a component out of + */ + constructor(data) { + this.data = data; + } +}; + +// src/components/Components.ts +var import_v1010 = require("discord-api-types/v10"); + +// src/components/button/Button.ts +var import_v102 = require("discord-api-types/v10"); +var ButtonBuilder = class extends ComponentBuilder { + static { + __name(this, "ButtonBuilder"); + } + /** + * Creates a new button from API data. + * + * @param data - The API data to create this button with + * @example + * Creating a button from an API data object: + * ```ts + * const button = new ButtonBuilder({ + * custom_id: 'a cool button', + * style: ButtonStyle.Primary, + * label: 'Click Me', + * emoji: { + * name: 'smile', + * id: '123456789012345678', + * }, + * }); + * ``` + * @example + * Creating a button using setters and API data: + * ```ts + * const button = new ButtonBuilder({ + * style: ButtonStyle.Secondary, + * label: 'Click Me', + * }) + * .setEmoji({ name: '🙂' }) + * .setCustomId('another cool button'); + * ``` + */ + constructor(data) { + super({ type: import_v102.ComponentType.Button, ...data }); + } + /** + * Sets the style of this button. + * + * @param style - The style to use + */ + setStyle(style) { + this.data.style = buttonStyleValidator.parse(style); + return this; + } + /** + * Sets the URL for this button. + * + * @remarks + * This method is only available to buttons using the `Link` button style. + * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`. + * @param url - The URL to use + */ + setURL(url) { + this.data.url = urlValidator.parse(url); + return this; + } + /** + * Sets the custom id for this button. + * + * @remarks + * This method is only applicable to buttons that are not using the `Link` button style. + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets the SKU id that represents a purchasable SKU for this button. + * + * @remarks Only available when using premium-style buttons. + * @param skuId - The SKU id to use + */ + setSKUId(skuId) { + this.data.sku_id = skuId; + return this; + } + /** + * Sets the emoji to display on this button. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji) { + this.data.emoji = emojiValidator.parse(emoji); + return this; + } + /** + * Sets whether this button is disabled. + * + * @param disabled - Whether to disable this button + */ + setDisabled(disabled = true) { + this.data.disabled = disabledValidator.parse(disabled); + return this; + } + /** + * Sets the label for this button. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = buttonLabelValidator.parse(label); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredButtonParameters( + this.data.style, + this.data.label, + this.data.emoji, + this.data.custom_id, + this.data.sku_id, + this.data.url + ); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/ChannelSelectMenu.ts +var import_v103 = require("discord-api-types/v10"); + +// src/components/selectMenu/BaseSelectMenu.ts +var BaseSelectMenuBuilder = class extends ComponentBuilder { + static { + __name(this, "BaseSelectMenuBuilder"); + } + /** + * Sets the placeholder for this select menu. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder) { + this.data.placeholder = placeholderValidator.parse(placeholder); + return this; + } + /** + * Sets the minimum values that must be selected in the select menu. + * + * @param minValues - The minimum values that must be selected + */ + setMinValues(minValues) { + this.data.min_values = minMaxValidator.parse(minValues); + return this; + } + /** + * Sets the maximum values that must be selected in the select menu. + * + * @param maxValues - The maximum values that must be selected + */ + setMaxValues(maxValues) { + this.data.max_values = minMaxValidator.parse(maxValues); + return this; + } + /** + * Sets the custom id for this select menu. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets whether this select menu is disabled. + * + * @param disabled - Whether this select menu is disabled + */ + setDisabled(disabled = true) { + this.data.disabled = disabledValidator.parse(disabled); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + customIdValidator.parse(this.data.custom_id); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/ChannelSelectMenu.ts +var ChannelSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "ChannelSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement) + * .setMinValues(2); + * ``` + */ + constructor(data) { + super({ ...data, type: import_v103.ComponentType.ChannelSelect }); + } + /** + * Adds channel types to this select menu. + * + * @param types - The channel types to use + */ + addChannelTypes(...types) { + const normalizedTypes = normalizeArray(types); + this.data.channel_types ??= []; + this.data.channel_types.push(...channelTypesValidator.parse(normalizedTypes)); + return this; + } + /** + * Sets channel types for this select menu. + * + * @param types - The channel types to use + */ + setChannelTypes(...types) { + const normalizedTypes = normalizeArray(types); + this.data.channel_types ??= []; + this.data.channel_types.splice(0, this.data.channel_types.length, ...channelTypesValidator.parse(normalizedTypes)); + return this; + } + /** + * Adds default channels to this auto populated select menu. + * + * @param channels - The channels to add + */ + addDefaultChannels(...channels) { + const normalizedValues = normalizeArray(channels); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: import_v103.SelectMenuDefaultValueType.Channel + })) + ); + return this; + } + /** + * Sets default channels for this auto populated select menu. + * + * @param channels - The channels to set + */ + setDefaultChannels(...channels) { + const normalizedValues = normalizeArray(channels); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: import_v103.SelectMenuDefaultValueType.Channel + })); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + customIdValidator.parse(this.data.custom_id); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/MentionableSelectMenu.ts +var import_v104 = require("discord-api-types/v10"); +var MentionableSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "MentionableSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: import_v104.ComponentType.MentionableSelect }); + } + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: import_v104.SelectMenuDefaultValueType.Role + })) + ); + return this; + } + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: import_v104.SelectMenuDefaultValueType.User + })) + ); + return this; + } + /** + * Adds default values to this auto populated select menu. + * + * @param values - The values to add + */ + addDefaultValues(...values) { + const normalizedValues = normalizeArray(values); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push(...normalizedValues); + return this; + } + /** + * Sets default values for this auto populated select menu. + * + * @param values - The values to set + */ + setDefaultValues(...values) { + const normalizedValues = normalizeArray(values); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues; + return this; + } +}; + +// src/components/selectMenu/RoleSelectMenu.ts +var import_v105 = require("discord-api-types/v10"); +var RoleSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "RoleSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: import_v105.ComponentType.RoleSelect }); + } + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: import_v105.SelectMenuDefaultValueType.Role + })) + ); + return this; + } + /** + * Sets default roles for this auto populated select menu. + * + * @param roles - The roles to set + */ + setDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: import_v105.SelectMenuDefaultValueType.Role + })); + return this; + } +}; + +// src/components/selectMenu/StringSelectMenu.ts +var import_v106 = require("discord-api-types/v10"); +var StringSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "StringSelectMenuBuilder"); + } + /** + * The options within this select menu. + */ + options; + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * options: [ + * { label: 'option 1', value: '1' }, + * { label: 'option 2', value: '2' }, + * { label: 'option 3', value: '3' }, + * ], + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1) + * .addOptions({ + * label: 'Catchy', + * value: 'catch', + * }); + * ``` + */ + constructor(data) { + const { options, ...initData } = data ?? {}; + super({ ...initData, type: import_v106.ComponentType.StringSelect }); + this.options = options?.map((option) => new StringSelectMenuOptionBuilder(option)) ?? []; + } + /** + * Adds options to this select menu. + * + * @param options - The options to add + */ + addOptions(...options) { + const normalizedOptions = normalizeArray(options); + optionsLengthValidator.parse(this.options.length + normalizedOptions.length); + this.options.push( + ...normalizedOptions.map( + (normalizedOption) => normalizedOption instanceof StringSelectMenuOptionBuilder ? normalizedOption : new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)) + ) + ); + return this; + } + /** + * Sets the options for this select menu. + * + * @param options - The options to set + */ + setOptions(...options) { + return this.spliceOptions(0, this.options.length, ...options); + } + /** + * Removes, replaces, or inserts options for this select menu. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}. + * It's useful for modifying and adjusting the order of existing options. + * @example + * Remove the first option: + * ```ts + * selectMenu.spliceOptions(0, 1); + * ``` + * @example + * Remove the first n option: + * ```ts + * const n = 4; + * selectMenu.spliceOptions(0, n); + * ``` + * @example + * Remove the last option: + * ```ts + * selectMenu.spliceOptions(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of options to remove + * @param options - The replacing option objects or builders + */ + spliceOptions(index, deleteCount, ...options) { + const normalizedOptions = normalizeArray(options); + const clone = [...this.options]; + clone.splice( + index, + deleteCount, + ...normalizedOptions.map( + (normalizedOption) => normalizedOption instanceof StringSelectMenuOptionBuilder ? normalizedOption : new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)) + ) + ); + optionsLengthValidator.parse(clone.length); + this.options.splice(0, this.options.length, ...clone); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + validateRequiredSelectMenuParameters(this.options, this.data.custom_id); + return { + ...this.data, + options: this.options.map((option) => option.toJSON()) + }; + } +}; + +// src/components/selectMenu/UserSelectMenu.ts +var import_v107 = require("discord-api-types/v10"); +var UserSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "UserSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: import_v107.ComponentType.UserSelect }); + } + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: import_v107.SelectMenuDefaultValueType.User + })) + ); + return this; + } + /** + * Sets default users for this auto populated select menu. + * + * @param users - The users to set + */ + setDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: import_v107.SelectMenuDefaultValueType.User + })); + return this; + } +}; + +// src/components/textInput/TextInput.ts +var import_util = require("@discordjs/util"); +var import_v109 = require("discord-api-types/v10"); +var import_fast_deep_equal = __toESM(require("fast-deep-equal")); + +// src/components/textInput/Assertions.ts +var Assertions_exports3 = {}; +__export(Assertions_exports3, { + labelValidator: () => labelValidator, + maxLengthValidator: () => maxLengthValidator, + minLengthValidator: () => minLengthValidator, + placeholderValidator: () => placeholderValidator2, + requiredValidator: () => requiredValidator, + textInputStyleValidator: () => textInputStyleValidator, + validateRequiredParameters: () => validateRequiredParameters, + valueValidator: () => valueValidator +}); +var import_shapeshift3 = require("@sapphire/shapeshift"); +var import_v108 = require("discord-api-types/v10"); +var textInputStyleValidator = import_shapeshift3.s.nativeEnum(import_v108.TextInputStyle); +var minLengthValidator = import_shapeshift3.s.number().int().greaterThanOrEqual(0).lessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var maxLengthValidator = import_shapeshift3.s.number().int().greaterThanOrEqual(1).lessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var requiredValidator = import_shapeshift3.s.boolean(); +var valueValidator = import_shapeshift3.s.string().lengthLessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var placeholderValidator2 = import_shapeshift3.s.string().lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var labelValidator = import_shapeshift3.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(45).setValidationEnabled(isValidationEnabled); +function validateRequiredParameters(customId, style, label) { + customIdValidator.parse(customId); + textInputStyleValidator.parse(style); + labelValidator.parse(label); +} +__name(validateRequiredParameters, "validateRequiredParameters"); + +// src/components/textInput/TextInput.ts +var TextInputBuilder = class extends ComponentBuilder { + static { + __name(this, "TextInputBuilder"); + } + /** + * Creates a new text input from API data. + * + * @param data - The API data to create this text input with + * @example + * Creating a text input from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool text input', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a text input using setters and API data: + * ```ts + * const textInput = new TextInputBuilder({ + * label: 'Type something else', + * }) + * .setCustomId('woah') + * .setStyle(TextInputStyle.Paragraph); + * ``` + */ + constructor(data) { + super({ type: import_v109.ComponentType.TextInput, ...data }); + } + /** + * Sets the custom id for this text input. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets the label for this text input. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = labelValidator.parse(label); + return this; + } + /** + * Sets the style for this text input. + * + * @param style - The style to use + */ + setStyle(style) { + this.data.style = textInputStyleValidator.parse(style); + return this; + } + /** + * Sets the minimum length of text for this text input. + * + * @param minLength - The minimum length of text for this text input + */ + setMinLength(minLength) { + this.data.min_length = minLengthValidator.parse(minLength); + return this; + } + /** + * Sets the maximum length of text for this text input. + * + * @param maxLength - The maximum length of text for this text input + */ + setMaxLength(maxLength) { + this.data.max_length = maxLengthValidator.parse(maxLength); + return this; + } + /** + * Sets the placeholder for this text input. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder) { + this.data.placeholder = placeholderValidator2.parse(placeholder); + return this; + } + /** + * Sets the value for this text input. + * + * @param value - The value to use + */ + setValue(value) { + this.data.value = valueValidator.parse(value); + return this; + } + /** + * Sets whether this text input is required. + * + * @param required - Whether this text input is required + */ + setRequired(required = true) { + this.data.required = requiredValidator.parse(required); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredParameters(this.data.custom_id, this.data.style, this.data.label); + return { + ...this.data + }; + } + /** + * Whether this is equal to another structure. + */ + equals(other) { + if ((0, import_util.isJSONEncodable)(other)) { + return (0, import_fast_deep_equal.default)(other.toJSON(), this.data); + } + return (0, import_fast_deep_equal.default)(other, this.data); + } +}; + +// src/components/Components.ts +function createComponentBuilder(data) { + if (data instanceof ComponentBuilder) { + return data; + } + switch (data.type) { + case import_v1010.ComponentType.ActionRow: + return new ActionRowBuilder(data); + case import_v1010.ComponentType.Button: + return new ButtonBuilder(data); + case import_v1010.ComponentType.StringSelect: + return new StringSelectMenuBuilder(data); + case import_v1010.ComponentType.TextInput: + return new TextInputBuilder(data); + case import_v1010.ComponentType.UserSelect: + return new UserSelectMenuBuilder(data); + case import_v1010.ComponentType.RoleSelect: + return new RoleSelectMenuBuilder(data); + case import_v1010.ComponentType.MentionableSelect: + return new MentionableSelectMenuBuilder(data); + case import_v1010.ComponentType.ChannelSelect: + return new ChannelSelectMenuBuilder(data); + default: + throw new Error(`Cannot properly serialize component type: ${data.type}`); + } +} +__name(createComponentBuilder, "createComponentBuilder"); + +// src/components/ActionRow.ts +var ActionRowBuilder = class extends ComponentBuilder { + static { + __name(this, "ActionRowBuilder"); + } + /** + * The components within this action row. + */ + components; + /** + * Creates a new action row from API data. + * + * @param data - The API data to create this action row with + * @example + * Creating an action row from an API data object: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Type something", + * style: TextInputStyle.Short, + * type: ComponentType.TextInput, + * }, + * ], + * }); + * ``` + * @example + * Creating an action row using setters and API data: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Click me", + * style: ButtonStyle.Primary, + * type: ComponentType.Button, + * }, + * ], + * }) + * .addComponents(button2, button3); + * ``` + */ + constructor({ components, ...data } = {}) { + super({ type: import_v1011.ComponentType.ActionRow, ...data }); + this.components = components?.map((component) => createComponentBuilder(component)) ?? []; + } + /** + * Adds components to this action row. + * + * @param components - The components to add + */ + addComponents(...components) { + this.components.push(...normalizeArray(components)); + return this; + } + /** + * Sets components for this action row. + * + * @param components - The components to set + */ + setComponents(...components) { + this.components.splice(0, this.components.length, ...normalizeArray(components)); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + return { + ...this.data, + components: this.components.map((component) => component.toJSON()) + }; + } +}; + +// src/interactions/modals/Assertions.ts +var Assertions_exports4 = {}; +__export(Assertions_exports4, { + componentsValidator: () => componentsValidator, + titleValidator: () => titleValidator, + validateRequiredParameters: () => validateRequiredParameters2 +}); +var import_shapeshift4 = require("@sapphire/shapeshift"); +var titleValidator = import_shapeshift4.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(45).setValidationEnabled(isValidationEnabled); +var componentsValidator = import_shapeshift4.s.instance(ActionRowBuilder).array().lengthGreaterThanOrEqual(1).setValidationEnabled(isValidationEnabled); +function validateRequiredParameters2(customId, title, components) { + customIdValidator.parse(customId); + titleValidator.parse(title); + componentsValidator.parse(components); +} +__name(validateRequiredParameters2, "validateRequiredParameters"); + +// src/interactions/modals/Modal.ts +var ModalBuilder = class { + static { + __name(this, "ModalBuilder"); + } + /** + * The API data associated with this modal. + */ + data; + /** + * The components within this modal. + */ + components = []; + /** + * Creates a new modal from API data. + * + * @param data - The API data to create this modal with + */ + constructor({ components, ...data } = {}) { + this.data = { ...data }; + this.components = components?.map((component) => createComponentBuilder(component)) ?? []; + } + /** + * Sets the title of this modal. + * + * @param title - The title to use + */ + setTitle(title) { + this.data.title = titleValidator.parse(title); + return this; + } + /** + * Sets the custom id of this modal. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Adds components to this modal. + * + * @param components - The components to add + */ + addComponents(...components) { + this.components.push( + ...normalizeArray(components).map( + (component) => component instanceof ActionRowBuilder ? component : new ActionRowBuilder(component) + ) + ); + return this; + } + /** + * Sets components for this modal. + * + * @param components - The components to set + */ + setComponents(...components) { + this.components.splice(0, this.components.length, ...normalizeArray(components)); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredParameters2(this.data.custom_id, this.data.title, this.components); + return { + ...this.data, + components: this.components.map((component) => component.toJSON()) + }; + } +}; + +// src/interactions/slashCommands/Assertions.ts +var Assertions_exports5 = {}; +__export(Assertions_exports5, { + assertReturnOfBuilder: () => assertReturnOfBuilder, + contextsPredicate: () => contextsPredicate, + integrationTypesPredicate: () => integrationTypesPredicate, + localizationMapPredicate: () => localizationMapPredicate, + validateChoicesLength: () => validateChoicesLength, + validateDMPermission: () => validateDMPermission, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions, + validateDefaultPermission: () => validateDefaultPermission, + validateDescription: () => validateDescription, + validateLocale: () => validateLocale, + validateLocalizationMap: () => validateLocalizationMap, + validateMaxOptionsLength: () => validateMaxOptionsLength, + validateNSFW: () => validateNSFW, + validateName: () => validateName, + validateRequired: () => validateRequired, + validateRequiredParameters: () => validateRequiredParameters3 +}); +var import_shapeshift5 = require("@sapphire/shapeshift"); +var import_v1012 = require("discord-api-types/v10"); +var namePredicate = import_shapeshift5.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(32).regex(/^[\p{Ll}\p{Lm}\p{Lo}\p{N}\p{sc=Devanagari}\p{sc=Thai}_-]+$/u).setValidationEnabled(isValidationEnabled); +function validateName(name) { + namePredicate.parse(name); +} +__name(validateName, "validateName"); +var descriptionPredicate2 = import_shapeshift5.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var localePredicate = import_shapeshift5.s.nativeEnum(import_v1012.Locale); +function validateDescription(description) { + descriptionPredicate2.parse(description); +} +__name(validateDescription, "validateDescription"); +var maxArrayLengthPredicate = import_shapeshift5.s.unknown().array().lengthLessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateLocale(locale) { + return localePredicate.parse(locale); +} +__name(validateLocale, "validateLocale"); +function validateMaxOptionsLength(options) { + maxArrayLengthPredicate.parse(options); +} +__name(validateMaxOptionsLength, "validateMaxOptionsLength"); +function validateRequiredParameters3(name, description, options) { + validateName(name); + validateDescription(description); + validateMaxOptionsLength(options); +} +__name(validateRequiredParameters3, "validateRequiredParameters"); +var booleanPredicate = import_shapeshift5.s.boolean(); +function validateDefaultPermission(value) { + booleanPredicate.parse(value); +} +__name(validateDefaultPermission, "validateDefaultPermission"); +function validateRequired(required) { + booleanPredicate.parse(required); +} +__name(validateRequired, "validateRequired"); +var choicesLengthPredicate = import_shapeshift5.s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateChoicesLength(amountAdding, choices) { + choicesLengthPredicate.parse((choices?.length ?? 0) + amountAdding); +} +__name(validateChoicesLength, "validateChoicesLength"); +function assertReturnOfBuilder(input, ExpectedInstanceOf) { + import_shapeshift5.s.instance(ExpectedInstanceOf).parse(input); +} +__name(assertReturnOfBuilder, "assertReturnOfBuilder"); +var localizationMapPredicate = import_shapeshift5.s.object(Object.fromEntries(Object.values(import_v1012.Locale).map((locale) => [locale, import_shapeshift5.s.string().nullish()]))).strict().nullish().setValidationEnabled(isValidationEnabled); +function validateLocalizationMap(value) { + localizationMapPredicate.parse(value); +} +__name(validateLocalizationMap, "validateLocalizationMap"); +var dmPermissionPredicate = import_shapeshift5.s.boolean().nullish(); +function validateDMPermission(value) { + dmPermissionPredicate.parse(value); +} +__name(validateDMPermission, "validateDMPermission"); +var memberPermissionPredicate = import_shapeshift5.s.union([ + import_shapeshift5.s.bigint().transform((value) => value.toString()), + import_shapeshift5.s.number().safeInt().transform((value) => value.toString()), + import_shapeshift5.s.string().regex(/^\d+$/) +]).nullish(); +function validateDefaultMemberPermissions(permissions) { + return memberPermissionPredicate.parse(permissions); +} +__name(validateDefaultMemberPermissions, "validateDefaultMemberPermissions"); +function validateNSFW(value) { + booleanPredicate.parse(value); +} +__name(validateNSFW, "validateNSFW"); +var contextsPredicate = import_shapeshift5.s.array( + import_shapeshift5.s.nativeEnum(import_v1012.InteractionContextType).setValidationEnabled(isValidationEnabled) +); +var integrationTypesPredicate = import_shapeshift5.s.array( + import_shapeshift5.s.nativeEnum(import_v1012.ApplicationIntegrationType).setValidationEnabled(isValidationEnabled) +); + +// src/interactions/slashCommands/SlashCommandBuilder.ts +var import_ts_mixer6 = require("ts-mixer"); + +// src/interactions/slashCommands/mixins/NameAndDescription.ts +var SharedNameAndDescription = class { + static { + __name(this, "SharedNameAndDescription"); + } + /** + * The name of this command. + */ + name; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The description of this command. + */ + description; + /** + * The description localizations of this command. + */ + description_localizations; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name) { + validateName(name); + Reflect.set(this, "name", name); + return this; + } + /** + * Sets the description of this command. + * + * @param description - The description to use + */ + setDescription(description) { + validateDescription(description); + Reflect.set(this, "description", description); + return this; + } + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale, localizedName) { + if (!this.name_localizations) { + Reflect.set(this, "name_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedName === null) { + this.name_localizations[parsedLocale] = null; + return this; + } + validateName(localizedName); + this.name_localizations[parsedLocale] = localizedName; + return this; + } + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames) { + if (localizedNames === null) { + Reflect.set(this, "name_localizations", null); + return this; + } + Reflect.set(this, "name_localizations", {}); + for (const args of Object.entries(localizedNames)) { + this.setNameLocalization(...args); + } + return this; + } + /** + * Sets a description localization for this command. + * + * @param locale - The locale to set + * @param localizedDescription - The localized description for the given locale + */ + setDescriptionLocalization(locale, localizedDescription) { + if (!this.description_localizations) { + Reflect.set(this, "description_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedDescription === null) { + this.description_localizations[parsedLocale] = null; + return this; + } + validateDescription(localizedDescription); + this.description_localizations[parsedLocale] = localizedDescription; + return this; + } + /** + * Sets the description localizations for this command. + * + * @param localizedDescriptions - The object of localized descriptions to set + */ + setDescriptionLocalizations(localizedDescriptions) { + if (localizedDescriptions === null) { + Reflect.set(this, "description_localizations", null); + return this; + } + Reflect.set(this, "description_localizations", {}); + for (const args of Object.entries(localizedDescriptions)) { + this.setDescriptionLocalization(...args); + } + return this; + } +}; + +// src/interactions/slashCommands/mixins/SharedSlashCommand.ts +var import_v1013 = require("discord-api-types/v10"); +var SharedSlashCommand = class { + static { + __name(this, "SharedSlashCommand"); + } + name = void 0; + name_localizations; + description = void 0; + description_localizations; + options = []; + contexts; + /** + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + default_permission = void 0; + default_member_permissions = void 0; + /** + * @deprecated Use {@link SharedSlashCommand.contexts} instead. + */ + dm_permission = void 0; + integration_types; + nsfw = void 0; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts) { + Reflect.set(this, "contexts", contextsPredicate.parse(normalizeArray(contexts))); + return this; + } + /** + * Sets the integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes) { + Reflect.set(this, "integration_types", integrationTypesPredicate.parse(normalizeArray(integrationTypes))); + return this; + } + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether or not to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + setDefaultPermission(value) { + validateDefaultPermission(value); + Reflect.set(this, "default_permission", value); + return this; + } + /** + * Sets the default permissions a member should have in order to run the command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions) { + const permissionValue = validateDefaultMemberPermissions(permissions); + Reflect.set(this, "default_member_permissions", permissionValue); + return this; + } + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated + * Use {@link SharedSlashCommand.setContexts} instead. + */ + setDMPermission(enabled) { + validateDMPermission(enabled); + Reflect.set(this, "dm_permission", enabled); + return this; + } + /** + * Sets whether this command is NSFW. + * + * @param nsfw - Whether this command is NSFW + */ + setNSFW(nsfw = true) { + validateNSFW(nsfw); + Reflect.set(this, "nsfw", nsfw); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + validateLocalizationMap(this.name_localizations); + validateLocalizationMap(this.description_localizations); + return { + ...this, + type: import_v1013.ApplicationCommandType.ChatInput, + options: this.options.map((option) => option.toJSON()) + }; + } +}; + +// src/interactions/slashCommands/options/attachment.ts +var import_v1014 = require("discord-api-types/v10"); + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionBase.ts +var ApplicationCommandOptionBase = class extends SharedNameAndDescription { + static { + __name(this, "ApplicationCommandOptionBase"); + } + /** + * Whether this option is required. + * + * @defaultValue `false` + */ + required = false; + /** + * Sets whether this option is required. + * + * @param required - Whether this option should be required + */ + setRequired(required) { + validateRequired(required); + Reflect.set(this, "required", required); + return this; + } + /** + * This method runs required validators on this builder. + */ + runRequiredValidations() { + validateRequiredParameters3(this.name, this.description, []); + validateLocalizationMap(this.name_localizations); + validateLocalizationMap(this.description_localizations); + validateRequired(this.required); + } +}; + +// src/interactions/slashCommands/options/attachment.ts +var SlashCommandAttachmentOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandAttachmentOption"); + } + /** + * The type of this option. + */ + type = import_v1014.ApplicationCommandOptionType.Attachment; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/boolean.ts +var import_v1015 = require("discord-api-types/v10"); +var SlashCommandBooleanOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandBooleanOption"); + } + /** + * The type of this option. + */ + type = import_v1015.ApplicationCommandOptionType.Boolean; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/channel.ts +var import_v1017 = require("discord-api-types/v10"); +var import_ts_mixer = require("ts-mixer"); + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.ts +var import_shapeshift6 = require("@sapphire/shapeshift"); +var import_v1016 = require("discord-api-types/v10"); +var allowedChannelTypes = [ + import_v1016.ChannelType.GuildText, + import_v1016.ChannelType.GuildVoice, + import_v1016.ChannelType.GuildCategory, + import_v1016.ChannelType.GuildAnnouncement, + import_v1016.ChannelType.AnnouncementThread, + import_v1016.ChannelType.PublicThread, + import_v1016.ChannelType.PrivateThread, + import_v1016.ChannelType.GuildStageVoice, + import_v1016.ChannelType.GuildForum, + import_v1016.ChannelType.GuildMedia +]; +var channelTypesPredicate = import_shapeshift6.s.array(import_shapeshift6.s.union(allowedChannelTypes.map((type) => import_shapeshift6.s.literal(type)))); +var ApplicationCommandOptionChannelTypesMixin = class { + static { + __name(this, "ApplicationCommandOptionChannelTypesMixin"); + } + /** + * The channel types of this option. + */ + channel_types; + /** + * Adds channel types to this option. + * + * @param channelTypes - The channel types + */ + addChannelTypes(...channelTypes) { + if (this.channel_types === void 0) { + Reflect.set(this, "channel_types", []); + } + this.channel_types.push(...channelTypesPredicate.parse(normalizeArray(channelTypes))); + return this; + } +}; + +// src/interactions/slashCommands/options/channel.ts +var SlashCommandChannelOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = import_v1017.ApplicationCommandOptionType.Channel; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; +__name(SlashCommandChannelOption, "SlashCommandChannelOption"); +SlashCommandChannelOption = __decorateClass([ + (0, import_ts_mixer.mix)(ApplicationCommandOptionChannelTypesMixin) +], SlashCommandChannelOption); + +// src/interactions/slashCommands/options/integer.ts +var import_shapeshift9 = require("@sapphire/shapeshift"); +var import_v1019 = require("discord-api-types/v10"); +var import_ts_mixer2 = require("ts-mixer"); + +// src/interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.ts +var ApplicationCommandNumericOptionMinMaxValueMixin = class { + static { + __name(this, "ApplicationCommandNumericOptionMinMaxValueMixin"); + } + /** + * The maximum value of this option. + */ + max_value; + /** + * The minimum value of this option. + */ + min_value; +}; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.ts +var import_shapeshift7 = require("@sapphire/shapeshift"); +var booleanPredicate2 = import_shapeshift7.s.boolean(); +var ApplicationCommandOptionWithAutocompleteMixin = class { + static { + __name(this, "ApplicationCommandOptionWithAutocompleteMixin"); + } + /** + * Whether this option utilizes autocomplete. + */ + autocomplete; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + type; + /** + * Whether this option uses autocomplete. + * + * @param autocomplete - Whether this option should use autocomplete + */ + setAutocomplete(autocomplete) { + booleanPredicate2.parse(autocomplete); + if (autocomplete && "choices" in this && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + Reflect.set(this, "autocomplete", autocomplete); + return this; + } +}; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.ts +var import_shapeshift8 = require("@sapphire/shapeshift"); +var import_v1018 = require("discord-api-types/v10"); +var stringPredicate = import_shapeshift8.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100); +var numberPredicate = import_shapeshift8.s.number().greaterThan(Number.NEGATIVE_INFINITY).lessThan(Number.POSITIVE_INFINITY); +var choicesPredicate = import_shapeshift8.s.object({ + name: stringPredicate, + name_localizations: localizationMapPredicate, + value: import_shapeshift8.s.union([stringPredicate, numberPredicate]) +}).array(); +var ApplicationCommandOptionWithChoicesMixin = class { + static { + __name(this, "ApplicationCommandOptionWithChoicesMixin"); + } + /** + * The choices of this option. + */ + choices; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + type; + /** + * Adds multiple choices to this option. + * + * @param choices - The choices to add + */ + addChoices(...choices) { + const normalizedChoices = normalizeArray(choices); + if (normalizedChoices.length > 0 && "autocomplete" in this && this.autocomplete) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + choicesPredicate.parse(normalizedChoices); + if (this.choices === void 0) { + Reflect.set(this, "choices", []); + } + validateChoicesLength(normalizedChoices.length, this.choices); + for (const { name, name_localizations, value } of normalizedChoices) { + if (this.type === import_v1018.ApplicationCommandOptionType.String) { + stringPredicate.parse(value); + } else { + numberPredicate.parse(value); + } + this.choices.push({ name, name_localizations, value }); + } + return this; + } + /** + * Sets multiple choices for this option. + * + * @param choices - The choices to set + */ + setChoices(...choices) { + const normalizedChoices = normalizeArray(choices); + if (normalizedChoices.length > 0 && "autocomplete" in this && this.autocomplete) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + choicesPredicate.parse(normalizedChoices); + Reflect.set(this, "choices", []); + this.addChoices(normalizedChoices); + return this; + } +}; + +// src/interactions/slashCommands/options/integer.ts +var numberValidator = import_shapeshift9.s.number().int(); +var SlashCommandIntegerOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = import_v1019.ApplicationCommandOptionType.Integer; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max) { + numberValidator.parse(max); + Reflect.set(this, "max_value", max); + return this; + } + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min) { + numberValidator.parse(min); + Reflect.set(this, "min_value", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandIntegerOption, "SlashCommandIntegerOption"); +SlashCommandIntegerOption = __decorateClass([ + (0, import_ts_mixer2.mix)( + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin + ) +], SlashCommandIntegerOption); + +// src/interactions/slashCommands/options/mentionable.ts +var import_v1020 = require("discord-api-types/v10"); +var SlashCommandMentionableOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandMentionableOption"); + } + /** + * The type of this option. + */ + type = import_v1020.ApplicationCommandOptionType.Mentionable; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/number.ts +var import_shapeshift10 = require("@sapphire/shapeshift"); +var import_v1021 = require("discord-api-types/v10"); +var import_ts_mixer3 = require("ts-mixer"); +var numberValidator2 = import_shapeshift10.s.number(); +var SlashCommandNumberOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = import_v1021.ApplicationCommandOptionType.Number; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max) { + numberValidator2.parse(max); + Reflect.set(this, "max_value", max); + return this; + } + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min) { + numberValidator2.parse(min); + Reflect.set(this, "min_value", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandNumberOption, "SlashCommandNumberOption"); +SlashCommandNumberOption = __decorateClass([ + (0, import_ts_mixer3.mix)( + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin + ) +], SlashCommandNumberOption); + +// src/interactions/slashCommands/options/role.ts +var import_v1022 = require("discord-api-types/v10"); +var SlashCommandRoleOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandRoleOption"); + } + /** + * The type of this option. + */ + type = import_v1022.ApplicationCommandOptionType.Role; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/string.ts +var import_shapeshift11 = require("@sapphire/shapeshift"); +var import_v1023 = require("discord-api-types/v10"); +var import_ts_mixer4 = require("ts-mixer"); +var minLengthValidator2 = import_shapeshift11.s.number().greaterThanOrEqual(0).lessThanOrEqual(6e3); +var maxLengthValidator2 = import_shapeshift11.s.number().greaterThanOrEqual(1).lessThanOrEqual(6e3); +var SlashCommandStringOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = import_v1023.ApplicationCommandOptionType.String; + /** + * The maximum length of this option. + */ + max_length; + /** + * The minimum length of this option. + */ + min_length; + /** + * Sets the maximum length of this string option. + * + * @param max - The maximum length this option can be + */ + setMaxLength(max) { + maxLengthValidator2.parse(max); + Reflect.set(this, "max_length", max); + return this; + } + /** + * Sets the minimum length of this string option. + * + * @param min - The minimum length this option can be + */ + setMinLength(min) { + minLengthValidator2.parse(min); + Reflect.set(this, "min_length", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandStringOption, "SlashCommandStringOption"); +SlashCommandStringOption = __decorateClass([ + (0, import_ts_mixer4.mix)(ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin) +], SlashCommandStringOption); + +// src/interactions/slashCommands/options/user.ts +var import_v1024 = require("discord-api-types/v10"); +var SlashCommandUserOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandUserOption"); + } + /** + * The type of this option. + */ + type = import_v1024.ApplicationCommandOptionType.User; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/mixins/SharedSlashCommandOptions.ts +var SharedSlashCommandOptions = class { + static { + __name(this, "SharedSlashCommandOptions"); + } + options; + /** + * Adds a boolean option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addBooleanOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandBooleanOption); + } + /** + * Adds a user option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addUserOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandUserOption); + } + /** + * Adds a channel option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addChannelOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandChannelOption); + } + /** + * Adds a role option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addRoleOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandRoleOption); + } + /** + * Adds an attachment option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addAttachmentOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandAttachmentOption); + } + /** + * Adds a mentionable option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addMentionableOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandMentionableOption); + } + /** + * Adds a string option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addStringOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandStringOption); + } + /** + * Adds an integer option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addIntegerOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandIntegerOption); + } + /** + * Adds a number option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addNumberOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandNumberOption); + } + /** + * Where the actual adding magic happens. ✨ + * + * @param input - The input. What else? + * @param Instance - The instance of whatever is being added + * @internal + */ + _sharedAddOptionMethod(input, Instance) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new Instance()) : input; + assertReturnOfBuilder(result, Instance); + options.push(result); + return this; + } +}; + +// src/interactions/slashCommands/SlashCommandSubcommands.ts +var import_v1025 = require("discord-api-types/v10"); +var import_ts_mixer5 = require("ts-mixer"); +var SlashCommandSubcommandGroupBuilder = class { + /** + * The name of this subcommand group. + */ + name = void 0; + /** + * The description of this subcommand group. + */ + description = void 0; + /** + * The subcommands within this subcommand group. + */ + options = []; + /** + * Adds a new subcommand to this group. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandBuilder); + options.push(result); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + return { + type: import_v1025.ApplicationCommandOptionType.SubcommandGroup, + name: this.name, + name_localizations: this.name_localizations, + description: this.description, + description_localizations: this.description_localizations, + options: this.options.map((option) => option.toJSON()) + }; + } +}; +__name(SlashCommandSubcommandGroupBuilder, "SlashCommandSubcommandGroupBuilder"); +SlashCommandSubcommandGroupBuilder = __decorateClass([ + (0, import_ts_mixer5.mix)(SharedNameAndDescription) +], SlashCommandSubcommandGroupBuilder); +var SlashCommandSubcommandBuilder = class { + /** + * The name of this subcommand. + */ + name = void 0; + /** + * The description of this subcommand. + */ + description = void 0; + /** + * The options within this subcommand. + */ + options = []; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + return { + type: import_v1025.ApplicationCommandOptionType.Subcommand, + name: this.name, + name_localizations: this.name_localizations, + description: this.description, + description_localizations: this.description_localizations, + options: this.options.map((option) => option.toJSON()) + }; + } +}; +__name(SlashCommandSubcommandBuilder, "SlashCommandSubcommandBuilder"); +SlashCommandSubcommandBuilder = __decorateClass([ + (0, import_ts_mixer5.mix)(SharedNameAndDescription, SharedSlashCommandOptions) +], SlashCommandSubcommandBuilder); + +// src/interactions/slashCommands/mixins/SharedSubcommands.ts +var SharedSlashCommandSubcommands = class { + static { + __name(this, "SharedSlashCommandSubcommands"); + } + options = []; + /** + * Adds a new subcommand group to this command. + * + * @param input - A function that returns a subcommand group builder or an already built builder + */ + addSubcommandGroup(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandGroupBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandGroupBuilder); + options.push(result); + return this; + } + /** + * Adds a new subcommand to this command. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandBuilder); + options.push(result); + return this; + } +}; + +// src/interactions/slashCommands/SlashCommandBuilder.ts +var SlashCommandBuilder = class { + /** + * The name of this command. + */ + name = void 0; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The description of this command. + */ + description = void 0; + /** + * The description localizations of this command. + */ + description_localizations; + /** + * The options of this command. + */ + options = []; + /** + * The contexts for this command. + */ + contexts; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + default_permission = void 0; + /** + * The set of permissions represented as a bit set for the command. + */ + default_member_permissions = void 0; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link SlashCommandBuilder.contexts} instead. + */ + dm_permission = void 0; + /** + * The integration types for this command. + */ + integration_types; + /** + * Whether this command is NSFW. + */ + nsfw = void 0; +}; +__name(SlashCommandBuilder, "SlashCommandBuilder"); +SlashCommandBuilder = __decorateClass([ + (0, import_ts_mixer6.mix)(SharedSlashCommandOptions, SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand) +], SlashCommandBuilder); + +// src/interactions/contextMenuCommands/Assertions.ts +var Assertions_exports6 = {}; +__export(Assertions_exports6, { + contextsPredicate: () => contextsPredicate2, + integrationTypesPredicate: () => integrationTypesPredicate2, + validateDMPermission: () => validateDMPermission2, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions2, + validateDefaultPermission: () => validateDefaultPermission2, + validateName: () => validateName2, + validateRequiredParameters: () => validateRequiredParameters4, + validateType: () => validateType +}); +var import_shapeshift12 = require("@sapphire/shapeshift"); +var import_v1026 = require("discord-api-types/v10"); +var namePredicate2 = import_shapeshift12.s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(32).regex(/^( *[\p{P}\p{L}\p{N}\p{sc=Devanagari}\p{sc=Thai}]+ *)+$/u).setValidationEnabled(isValidationEnabled); +var typePredicate = import_shapeshift12.s.union([import_shapeshift12.s.literal(import_v1026.ApplicationCommandType.User), import_shapeshift12.s.literal(import_v1026.ApplicationCommandType.Message)]).setValidationEnabled(isValidationEnabled); +var booleanPredicate3 = import_shapeshift12.s.boolean(); +function validateDefaultPermission2(value) { + booleanPredicate3.parse(value); +} +__name(validateDefaultPermission2, "validateDefaultPermission"); +function validateName2(name) { + namePredicate2.parse(name); +} +__name(validateName2, "validateName"); +function validateType(type) { + typePredicate.parse(type); +} +__name(validateType, "validateType"); +function validateRequiredParameters4(name, type) { + validateName2(name); + validateType(type); +} +__name(validateRequiredParameters4, "validateRequiredParameters"); +var dmPermissionPredicate2 = import_shapeshift12.s.boolean().nullish(); +function validateDMPermission2(value) { + dmPermissionPredicate2.parse(value); +} +__name(validateDMPermission2, "validateDMPermission"); +var memberPermissionPredicate2 = import_shapeshift12.s.union([ + import_shapeshift12.s.bigint().transform((value) => value.toString()), + import_shapeshift12.s.number().safeInt().transform((value) => value.toString()), + import_shapeshift12.s.string().regex(/^\d+$/) +]).nullish(); +function validateDefaultMemberPermissions2(permissions) { + return memberPermissionPredicate2.parse(permissions); +} +__name(validateDefaultMemberPermissions2, "validateDefaultMemberPermissions"); +var contextsPredicate2 = import_shapeshift12.s.array( + import_shapeshift12.s.nativeEnum(import_v1026.InteractionContextType).setValidationEnabled(isValidationEnabled) +); +var integrationTypesPredicate2 = import_shapeshift12.s.array( + import_shapeshift12.s.nativeEnum(import_v1026.ApplicationIntegrationType).setValidationEnabled(isValidationEnabled) +); + +// src/interactions/contextMenuCommands/ContextMenuCommandBuilder.ts +var ContextMenuCommandBuilder = class { + static { + __name(this, "ContextMenuCommandBuilder"); + } + /** + * The name of this command. + */ + name = void 0; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The type of this command. + */ + type = void 0; + /** + * The contexts for this command. + */ + contexts; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + default_permission = void 0; + /** + * The set of permissions represented as a bit set for the command. + */ + default_member_permissions = void 0; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link ContextMenuCommandBuilder.contexts} instead. + */ + dm_permission = void 0; + /** + * The integration types for this command. + */ + integration_types; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts) { + Reflect.set(this, "contexts", contextsPredicate2.parse(normalizeArray(contexts))); + return this; + } + /** + * Sets integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes) { + Reflect.set(this, "integration_types", integrationTypesPredicate2.parse(normalizeArray(integrationTypes))); + return this; + } + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name) { + validateName2(name); + Reflect.set(this, "name", name); + return this; + } + /** + * Sets the type of this command. + * + * @param type - The type to use + */ + setType(type) { + validateType(type); + Reflect.set(this, "type", type); + return this; + } + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + setDefaultPermission(value) { + validateDefaultPermission2(value); + Reflect.set(this, "default_permission", value); + return this; + } + /** + * Sets the default permissions a member should have in order to run this command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions) { + const permissionValue = validateDefaultMemberPermissions2(permissions); + Reflect.set(this, "default_member_permissions", permissionValue); + return this; + } + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead. + */ + setDMPermission(enabled) { + validateDMPermission2(enabled); + Reflect.set(this, "dm_permission", enabled); + return this; + } + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale, localizedName) { + if (!this.name_localizations) { + Reflect.set(this, "name_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedName === null) { + this.name_localizations[parsedLocale] = null; + return this; + } + validateName2(localizedName); + this.name_localizations[parsedLocale] = localizedName; + return this; + } + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames) { + if (localizedNames === null) { + Reflect.set(this, "name_localizations", null); + return this; + } + Reflect.set(this, "name_localizations", {}); + for (const args of Object.entries(localizedNames)) + this.setNameLocalization(...args); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters4(this.name, this.type); + validateLocalizationMap(this.name_localizations); + return { ...this }; + } +}; + +// src/util/componentUtil.ts +function embedLength(data) { + return (data.title?.length ?? 0) + (data.description?.length ?? 0) + (data.fields?.reduce((prev, curr) => prev + curr.name.length + curr.value.length, 0) ?? 0) + (data.footer?.text.length ?? 0) + (data.author?.name.length ?? 0); +} +__name(embedLength, "embedLength"); + +// src/index.ts +var version = "1.10.1"; +// Annotate the CommonJS export names for ESM import in node: +0 && (module.exports = { + ActionRowBuilder, + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionBase, + ApplicationCommandOptionChannelTypesMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin, + BaseSelectMenuBuilder, + ButtonBuilder, + ChannelSelectMenuBuilder, + ComponentAssertions, + ComponentBuilder, + ContextMenuCommandAssertions, + ContextMenuCommandBuilder, + EmbedAssertions, + EmbedBuilder, + MentionableSelectMenuBuilder, + ModalAssertions, + ModalBuilder, + RoleSelectMenuBuilder, + SelectMenuBuilder, + SelectMenuOptionBuilder, + SharedNameAndDescription, + SharedSlashCommand, + SharedSlashCommandOptions, + SharedSlashCommandSubcommands, + SlashCommandAssertions, + SlashCommandAttachmentOption, + SlashCommandBooleanOption, + SlashCommandBuilder, + SlashCommandChannelOption, + SlashCommandIntegerOption, + SlashCommandMentionableOption, + SlashCommandNumberOption, + SlashCommandRoleOption, + SlashCommandStringOption, + SlashCommandSubcommandBuilder, + SlashCommandSubcommandGroupBuilder, + SlashCommandUserOption, + StringSelectMenuBuilder, + StringSelectMenuOptionBuilder, + TextInputAssertions, + TextInputBuilder, + UserSelectMenuBuilder, + createComponentBuilder, + disableValidators, + embedLength, + enableValidators, + isValidationEnabled, + normalizeArray, + version, + ...require("@discordjs/formatters") +}); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js.map b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js.map new file mode 100644 index 0000000..93c6468 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/index.ts","../src/messages/embed/Assertions.ts","../src/util/validation.ts","../src/util/normalizeArray.ts","../src/messages/embed/Embed.ts","../src/components/Assertions.ts","../src/components/selectMenu/StringSelectMenuOption.ts","../src/components/ActionRow.ts","../src/components/Component.ts","../src/components/Components.ts","../src/components/button/Button.ts","../src/components/selectMenu/ChannelSelectMenu.ts","../src/components/selectMenu/BaseSelectMenu.ts","../src/components/selectMenu/MentionableSelectMenu.ts","../src/components/selectMenu/RoleSelectMenu.ts","../src/components/selectMenu/StringSelectMenu.ts","../src/components/selectMenu/UserSelectMenu.ts","../src/components/textInput/TextInput.ts","../src/components/textInput/Assertions.ts","../src/interactions/modals/Assertions.ts","../src/interactions/modals/Modal.ts","../src/interactions/slashCommands/Assertions.ts","../src/interactions/slashCommands/SlashCommandBuilder.ts","../src/interactions/slashCommands/mixins/NameAndDescription.ts","../src/interactions/slashCommands/mixins/SharedSlashCommand.ts","../src/interactions/slashCommands/options/attachment.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionBase.ts","../src/interactions/slashCommands/options/boolean.ts","../src/interactions/slashCommands/options/channel.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.ts","../src/interactions/slashCommands/options/integer.ts","../src/interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.ts","../src/interactions/slashCommands/options/mentionable.ts","../src/interactions/slashCommands/options/number.ts","../src/interactions/slashCommands/options/role.ts","../src/interactions/slashCommands/options/string.ts","../src/interactions/slashCommands/options/user.ts","../src/interactions/slashCommands/mixins/SharedSlashCommandOptions.ts","../src/interactions/slashCommands/SlashCommandSubcommands.ts","../src/interactions/slashCommands/mixins/SharedSubcommands.ts","../src/interactions/contextMenuCommands/Assertions.ts","../src/interactions/contextMenuCommands/ContextMenuCommandBuilder.ts","../src/util/componentUtil.ts"],"sourcesContent":["export * as EmbedAssertions from './messages/embed/Assertions.js';\nexport * from './messages/embed/Embed.js';\n// TODO: Consider removing this dep in the next major version\nexport * from '@discordjs/formatters';\n\nexport * as ComponentAssertions from './components/Assertions.js';\nexport * from './components/ActionRow.js';\nexport * from './components/button/Button.js';\nexport * from './components/Component.js';\nexport * from './components/Components.js';\nexport * from './components/textInput/TextInput.js';\nexport * as TextInputAssertions from './components/textInput/Assertions.js';\nexport * from './interactions/modals/Modal.js';\nexport * as ModalAssertions from './interactions/modals/Assertions.js';\n\nexport * from './components/selectMenu/BaseSelectMenu.js';\nexport * from './components/selectMenu/ChannelSelectMenu.js';\nexport * from './components/selectMenu/MentionableSelectMenu.js';\nexport * from './components/selectMenu/RoleSelectMenu.js';\nexport * from './components/selectMenu/StringSelectMenu.js';\n// TODO: Remove those aliases in v2\nexport {\n\t/**\n\t * @deprecated Will be removed in the next major version, use {@link StringSelectMenuBuilder} instead.\n\t */\n\tStringSelectMenuBuilder as SelectMenuBuilder,\n} from './components/selectMenu/StringSelectMenu.js';\nexport {\n\t/**\n\t * @deprecated Will be removed in the next major version, use {@link StringSelectMenuOptionBuilder} instead.\n\t */\n\tStringSelectMenuOptionBuilder as SelectMenuOptionBuilder,\n} from './components/selectMenu/StringSelectMenuOption.js';\nexport * from './components/selectMenu/StringSelectMenuOption.js';\nexport * from './components/selectMenu/UserSelectMenu.js';\n\nexport * as SlashCommandAssertions from './interactions/slashCommands/Assertions.js';\nexport * from './interactions/slashCommands/SlashCommandBuilder.js';\nexport * from './interactions/slashCommands/SlashCommandSubcommands.js';\nexport * from './interactions/slashCommands/options/boolean.js';\nexport * from './interactions/slashCommands/options/channel.js';\nexport * from './interactions/slashCommands/options/integer.js';\nexport * from './interactions/slashCommands/options/mentionable.js';\nexport * from './interactions/slashCommands/options/number.js';\nexport * from './interactions/slashCommands/options/role.js';\nexport * from './interactions/slashCommands/options/attachment.js';\nexport * from './interactions/slashCommands/options/string.js';\nexport * from './interactions/slashCommands/options/user.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionBase.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.js';\nexport * from './interactions/slashCommands/mixins/NameAndDescription.js';\nexport * from './interactions/slashCommands/mixins/SharedSlashCommandOptions.js';\nexport * from './interactions/slashCommands/mixins/SharedSubcommands.js';\nexport * from './interactions/slashCommands/mixins/SharedSlashCommand.js';\n\nexport * as ContextMenuCommandAssertions from './interactions/contextMenuCommands/Assertions.js';\nexport * from './interactions/contextMenuCommands/ContextMenuCommandBuilder.js';\n\nexport * from './util/componentUtil.js';\nexport * from './util/normalizeArray.js';\nexport * from './util/validation.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/builders#readme | @discordjs/builders} version\n * that you are currently using.\n *\n * @privateRemarks This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild.\n */\nexport const version = '1.10.1' as string;\n","import { s } from '@sapphire/shapeshift';\nimport type { APIEmbedField } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\n\nexport const fieldNamePredicate = s.string().lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled);\n\nexport const fieldValuePredicate = s.string().lengthLessThanOrEqual(1_024).setValidationEnabled(isValidationEnabled);\n\nexport const fieldInlinePredicate = s.boolean().optional();\n\nexport const embedFieldPredicate = s\n\t.object({\n\t\tname: fieldNamePredicate,\n\t\tvalue: fieldValuePredicate,\n\t\tinline: fieldInlinePredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedFieldsArrayPredicate = embedFieldPredicate.array().setValidationEnabled(isValidationEnabled);\n\nexport const fieldLengthPredicate = s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\n\nexport function validateFieldLength(amountAdding: number, fields?: APIEmbedField[]): void {\n\tfieldLengthPredicate.parse((fields?.length ?? 0) + amountAdding);\n}\n\nexport const authorNamePredicate = fieldNamePredicate\n\t.lengthGreaterThanOrEqual(1)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const imageURLPredicate = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'attachment:'],\n\t})\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const urlPredicate = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:'],\n\t})\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedAuthorPredicate = s\n\t.object({\n\t\tname: authorNamePredicate,\n\t\ticonURL: imageURLPredicate,\n\t\turl: urlPredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const RGBPredicate = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(255)\n\t.setValidationEnabled(isValidationEnabled);\nexport const colorPredicate = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(0xffffff)\n\t.or(s.tuple([RGBPredicate, RGBPredicate, RGBPredicate]))\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const descriptionPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(4_096)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const footerTextPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(2_048)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedFooterPredicate = s\n\t.object({\n\t\ttext: footerTextPredicate,\n\t\ticonURL: imageURLPredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const timestampPredicate = s.union([s.number(), s.date()]).nullable().setValidationEnabled(isValidationEnabled);\n\nexport const titlePredicate = fieldNamePredicate\n\t.lengthGreaterThanOrEqual(1)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n","let validate = true;\n\n/**\n * Enables validators.\n *\n * @returns Whether validation is occurring.\n */\nexport function enableValidators() {\n\treturn (validate = true);\n}\n\n/**\n * Disables validators.\n *\n * @returns Whether validation is occurring.\n */\nexport function disableValidators() {\n\treturn (validate = false);\n}\n\n/**\n * Checks whether validation is occurring.\n */\nexport function isValidationEnabled() {\n\treturn validate;\n}\n","/**\n * Normalizes data that is a rest parameter or an array into an array with a depth of 1.\n *\n * @typeParam ItemType - The data that must satisfy {@link RestOrArray}.\n * @param arr - The (possibly variadic) data to normalize\n */\nexport function normalizeArray(arr: RestOrArray): ItemType[] {\n\tif (Array.isArray(arr[0])) return [...arr[0]];\n\treturn arr as ItemType[];\n}\n\n/**\n * Represents data that may be an array or came from a rest parameter.\n *\n * @remarks\n * This type is used throughout builders to ensure both an array and variadic arguments\n * may be used. It is normalized with {@link normalizeArray}.\n */\nexport type RestOrArray = Type[] | [Type[]];\n","import type { APIEmbed, APIEmbedAuthor, APIEmbedField, APIEmbedFooter, APIEmbedImage } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport {\n\tcolorPredicate,\n\tdescriptionPredicate,\n\tembedAuthorPredicate,\n\tembedFieldsArrayPredicate,\n\tembedFooterPredicate,\n\timageURLPredicate,\n\ttimestampPredicate,\n\ttitlePredicate,\n\turlPredicate,\n\tvalidateFieldLength,\n} from './Assertions.js';\n\n/**\n * A tuple satisfying the RGB color model.\n *\n * @see {@link https://developer.mozilla.org/docs/Glossary/RGB}\n */\nexport type RGBTuple = [red: number, green: number, blue: number];\n\n/**\n * The base icon data typically used in payloads.\n */\nexport interface IconData {\n\t/**\n\t * The URL of the icon.\n\t */\n\ticonURL?: string;\n\t/**\n\t * The proxy URL of the icon.\n\t */\n\tproxyIconURL?: string;\n}\n\n/**\n * Represents the author data of an embed.\n */\nexport interface EmbedAuthorData extends IconData, Omit {}\n\n/**\n * Represents the author options of an embed.\n */\nexport interface EmbedAuthorOptions extends Omit {}\n\n/**\n * Represents the footer data of an embed.\n */\nexport interface EmbedFooterData extends IconData, Omit {}\n\n/**\n * Represents the footer options of an embed.\n */\nexport interface EmbedFooterOptions extends Omit {}\n\n/**\n * Represents the image data of an embed.\n */\nexport interface EmbedImageData extends Omit {\n\t/**\n\t * The proxy URL for the image.\n\t */\n\tproxyURL?: string;\n}\n\n/**\n * A builder that creates API-compatible JSON data for embeds.\n */\nexport class EmbedBuilder {\n\t/**\n\t * The API data associated with this embed.\n\t */\n\tpublic readonly data: APIEmbed;\n\n\t/**\n\t * Creates a new embed from API data.\n\t *\n\t * @param data - The API data to create this embed with\n\t */\n\tpublic constructor(data: APIEmbed = {}) {\n\t\tthis.data = { ...data };\n\t\tif (data.timestamp) this.data.timestamp = new Date(data.timestamp).toISOString();\n\t}\n\n\t/**\n\t * Appends fields to the embed.\n\t *\n\t * @remarks\n\t * This method accepts either an array of fields or a variable number of field parameters.\n\t * The maximum amount of fields that can be added is 25.\n\t * @example\n\t * Using an array:\n\t * ```ts\n\t * const fields: APIEmbedField[] = ...;\n\t * const embed = new EmbedBuilder()\n\t * \t.addFields(fields);\n\t * ```\n\t * @example\n\t * Using rest parameters (variadic):\n\t * ```ts\n\t * const embed = new EmbedBuilder()\n\t * \t.addFields(\n\t * \t\t{ name: 'Field 1', value: 'Value 1' },\n\t * \t\t{ name: 'Field 2', value: 'Value 2' },\n\t * \t);\n\t * ```\n\t * @param fields - The fields to add\n\t */\n\tpublic addFields(...fields: RestOrArray): this {\n\t\tconst normalizedFields = normalizeArray(fields);\n\t\t// Ensure adding these fields won't exceed the 25 field limit\n\t\tvalidateFieldLength(normalizedFields.length, this.data.fields);\n\n\t\t// Data assertions\n\t\tembedFieldsArrayPredicate.parse(normalizedFields);\n\n\t\tif (this.data.fields) this.data.fields.push(...normalizedFields);\n\t\telse this.data.fields = normalizedFields;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Removes, replaces, or inserts fields for this embed.\n\t *\n\t * @remarks\n\t * This method behaves similarly\n\t * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}.\n\t * The maximum amount of fields that can be added is 25.\n\t *\n\t * It's useful for modifying and adjusting order of the already-existing fields of an embed.\n\t * @example\n\t * Remove the first field:\n\t * ```ts\n\t * embed.spliceFields(0, 1);\n\t * ```\n\t * @example\n\t * Remove the first n fields:\n\t * ```ts\n\t * const n = 4;\n\t * embed.spliceFields(0, n);\n\t * ```\n\t * @example\n\t * Remove the last field:\n\t * ```ts\n\t * embed.spliceFields(-1, 1);\n\t * ```\n\t * @param index - The index to start at\n\t * @param deleteCount - The number of fields to remove\n\t * @param fields - The replacing field objects\n\t */\n\tpublic spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this {\n\t\t// Ensure adding these fields won't exceed the 25 field limit\n\t\tvalidateFieldLength(fields.length - deleteCount, this.data.fields);\n\n\t\t// Data assertions\n\t\tembedFieldsArrayPredicate.parse(fields);\n\t\tif (this.data.fields) this.data.fields.splice(index, deleteCount, ...fields);\n\t\telse this.data.fields = fields;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the fields for this embed.\n\t *\n\t * @remarks\n\t * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically,\n\t * it splices the entire array of fields, replacing them with the provided fields.\n\t *\n\t * You can set a maximum of 25 fields.\n\t * @param fields - The fields to set\n\t */\n\tpublic setFields(...fields: RestOrArray): this {\n\t\tthis.spliceFields(0, this.data.fields?.length ?? 0, ...normalizeArray(fields));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the author of this embed.\n\t *\n\t * @param options - The options to use\n\t */\n\n\tpublic setAuthor(options: EmbedAuthorOptions | null): this {\n\t\tif (options === null) {\n\t\t\tthis.data.author = undefined;\n\t\t\treturn this;\n\t\t}\n\n\t\t// Data assertions\n\t\tembedAuthorPredicate.parse(options);\n\n\t\tthis.data.author = { name: options.name, url: options.url, icon_url: options.iconURL };\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the color of this embed.\n\t *\n\t * @param color - The color to use\n\t */\n\tpublic setColor(color: RGBTuple | number | null): this {\n\t\t// Data assertions\n\t\tcolorPredicate.parse(color);\n\n\t\tif (Array.isArray(color)) {\n\t\t\tconst [red, green, blue] = color;\n\t\t\tthis.data.color = (red << 16) + (green << 8) + blue;\n\t\t\treturn this;\n\t\t}\n\n\t\tthis.data.color = color ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description of this embed.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string | null): this {\n\t\t// Data assertions\n\t\tdescriptionPredicate.parse(description);\n\n\t\tthis.data.description = description ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the footer of this embed.\n\t *\n\t * @param options - The footer to use\n\t */\n\tpublic setFooter(options: EmbedFooterOptions | null): this {\n\t\tif (options === null) {\n\t\t\tthis.data.footer = undefined;\n\t\t\treturn this;\n\t\t}\n\n\t\t// Data assertions\n\t\tembedFooterPredicate.parse(options);\n\n\t\tthis.data.footer = { text: options.text, icon_url: options.iconURL };\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the image of this embed.\n\t *\n\t * @param url - The image URL to use\n\t */\n\tpublic setImage(url: string | null): this {\n\t\t// Data assertions\n\t\timageURLPredicate.parse(url);\n\n\t\tthis.data.image = url ? { url } : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the thumbnail of this embed.\n\t *\n\t * @param url - The thumbnail URL to use\n\t */\n\tpublic setThumbnail(url: string | null): this {\n\t\t// Data assertions\n\t\timageURLPredicate.parse(url);\n\n\t\tthis.data.thumbnail = url ? { url } : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the timestamp of this embed.\n\t *\n\t * @param timestamp - The timestamp or date to use\n\t */\n\tpublic setTimestamp(timestamp: Date | number | null = Date.now()): this {\n\t\t// Data assertions\n\t\ttimestampPredicate.parse(timestamp);\n\n\t\tthis.data.timestamp = timestamp ? new Date(timestamp).toISOString() : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the title for this embed.\n\t *\n\t * @param title - The title to use\n\t */\n\tpublic setTitle(title: string | null): this {\n\t\t// Data assertions\n\t\ttitlePredicate.parse(title);\n\n\t\tthis.data.title = title ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the URL of this embed.\n\t *\n\t * @param url - The URL to use\n\t */\n\tpublic setURL(url: string | null): this {\n\t\t// Data assertions\n\t\turlPredicate.parse(url);\n\n\t\tthis.data.url = url ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIEmbed {\n\t\treturn { ...this.data };\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ButtonStyle, ChannelType, type APIMessageComponentEmoji } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../util/validation.js';\nimport { StringSelectMenuOptionBuilder } from './selectMenu/StringSelectMenuOption.js';\n\nexport const customIdValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const emojiValidator = s\n\t.object({\n\t\tid: s.string(),\n\t\tname: s.string(),\n\t\tanimated: s.boolean(),\n\t})\n\t.partial()\n\t.strict()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const disabledValidator = s.boolean();\n\nexport const buttonLabelValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(80)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const buttonStyleValidator = s.nativeEnum(ButtonStyle);\n\nexport const placeholderValidator = s.string().lengthLessThanOrEqual(150).setValidationEnabled(isValidationEnabled);\nexport const minMaxValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const labelValueDescriptionValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const jsonOptionValidator = s\n\t.object({\n\t\tlabel: labelValueDescriptionValidator,\n\t\tvalue: labelValueDescriptionValidator,\n\t\tdescription: labelValueDescriptionValidator.optional(),\n\t\temoji: emojiValidator.optional(),\n\t\tdefault: s.boolean().optional(),\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const optionValidator = s.instance(StringSelectMenuOptionBuilder).setValidationEnabled(isValidationEnabled);\n\nexport const optionsValidator = optionValidator\n\t.array()\n\t.lengthGreaterThanOrEqual(0)\n\t.setValidationEnabled(isValidationEnabled);\nexport const optionsLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredSelectMenuParameters(options: StringSelectMenuOptionBuilder[], customId?: string) {\n\tcustomIdValidator.parse(customId);\n\toptionsValidator.parse(options);\n}\n\nexport const defaultValidator = s.boolean();\n\nexport function validateRequiredSelectMenuOptionParameters(label?: string, value?: string) {\n\tlabelValueDescriptionValidator.parse(label);\n\tlabelValueDescriptionValidator.parse(value);\n}\n\nexport const channelTypesValidator = s.nativeEnum(ChannelType).array().setValidationEnabled(isValidationEnabled);\n\nexport const urlValidator = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'discord:'],\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredButtonParameters(\n\tstyle?: ButtonStyle,\n\tlabel?: string,\n\temoji?: APIMessageComponentEmoji,\n\tcustomId?: string,\n\tskuId?: string,\n\turl?: string,\n) {\n\tif (style === ButtonStyle.Premium) {\n\t\tif (!skuId) {\n\t\t\tthrow new RangeError('Premium buttons must have an SKU id.');\n\t\t}\n\n\t\tif (customId || label || url || emoji) {\n\t\t\tthrow new RangeError('Premium buttons cannot have a custom id, label, URL, or emoji.');\n\t\t}\n\t} else {\n\t\tif (skuId) {\n\t\t\tthrow new RangeError('Non-premium buttons must not have an SKU id.');\n\t\t}\n\n\t\tif (url && customId) {\n\t\t\tthrow new RangeError('URL and custom id are mutually exclusive.');\n\t\t}\n\n\t\tif (!label && !emoji) {\n\t\t\tthrow new RangeError('Non-premium buttons must have a label and/or an emoji.');\n\t\t}\n\n\t\tif (style === ButtonStyle.Link) {\n\t\t\tif (!url) {\n\t\t\t\tthrow new RangeError('Link buttons must have a URL.');\n\t\t\t}\n\t\t} else if (url) {\n\t\t\tthrow new RangeError('Non-premium and non-link buttons cannot have a URL.');\n\t\t}\n\t}\n}\n","import type { JSONEncodable } from '@discordjs/util';\nimport type { APIMessageComponentEmoji, APISelectMenuOption } from 'discord-api-types/v10';\nimport {\n\tdefaultValidator,\n\temojiValidator,\n\tlabelValueDescriptionValidator,\n\tvalidateRequiredSelectMenuOptionParameters,\n} from '../Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for string select menu options.\n */\nexport class StringSelectMenuOptionBuilder implements JSONEncodable {\n\t/**\n\t * Creates a new string select menu option from API data.\n\t *\n\t * @param data - The API data to create this string select menu option with\n\t * @example\n\t * Creating a string select menu option from an API data object:\n\t * ```ts\n\t * const selectMenuOption = new SelectMenuOptionBuilder({\n\t * \tlabel: 'catchy label',\n\t * \tvalue: '1',\n\t * });\n\t * ```\n\t * @example\n\t * Creating a string select menu option using setters and API data:\n\t * ```ts\n\t * const selectMenuOption = new SelectMenuOptionBuilder({\n\t * \tdefault: true,\n\t * \tvalue: '1',\n\t * })\n\t * \t.setLabel('woah');\n\t * ```\n\t */\n\tpublic constructor(public data: Partial = {}) {}\n\n\t/**\n\t * Sets the label for this option.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\tthis.data.label = labelValueDescriptionValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the value for this option.\n\t *\n\t * @param value - The value to use\n\t */\n\tpublic setValue(value: string) {\n\t\tthis.data.value = labelValueDescriptionValidator.parse(value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description for this option.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string) {\n\t\tthis.data.description = labelValueDescriptionValidator.parse(description);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this option is selected by default.\n\t *\n\t * @param isDefault - Whether this option is selected by default\n\t */\n\tpublic setDefault(isDefault = true) {\n\t\tthis.data.default = defaultValidator.parse(isDefault);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the emoji to display for this option.\n\t *\n\t * @param emoji - The emoji to use\n\t */\n\tpublic setEmoji(emoji: APIMessageComponentEmoji) {\n\t\tthis.data.emoji = emojiValidator.parse(emoji);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic toJSON(): APISelectMenuOption {\n\t\tvalidateRequiredSelectMenuOptionParameters(this.data.label, this.data.value);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APISelectMenuOption;\n\t}\n}\n","/* eslint-disable jsdoc/check-param-names */\n\nimport {\n\ttype APIActionRowComponent,\n\tComponentType,\n\ttype APIMessageActionRowComponent,\n\ttype APIModalActionRowComponent,\n\ttype APIActionRowComponentTypes,\n} from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../util/normalizeArray.js';\nimport { ComponentBuilder } from './Component.js';\nimport { createComponentBuilder } from './Components.js';\nimport type { ButtonBuilder } from './button/Button.js';\nimport type { ChannelSelectMenuBuilder } from './selectMenu/ChannelSelectMenu.js';\nimport type { MentionableSelectMenuBuilder } from './selectMenu/MentionableSelectMenu.js';\nimport type { RoleSelectMenuBuilder } from './selectMenu/RoleSelectMenu.js';\nimport type { StringSelectMenuBuilder } from './selectMenu/StringSelectMenu.js';\nimport type { UserSelectMenuBuilder } from './selectMenu/UserSelectMenu.js';\nimport type { TextInputBuilder } from './textInput/TextInput.js';\n\n/**\n * The builders that may be used for messages.\n */\nexport type MessageComponentBuilder =\n\t| ActionRowBuilder\n\t| MessageActionRowComponentBuilder;\n\n/**\n * The builders that may be used for modals.\n */\nexport type ModalComponentBuilder = ActionRowBuilder | ModalActionRowComponentBuilder;\n\n/**\n * The builders that may be used within an action row for messages.\n */\nexport type MessageActionRowComponentBuilder =\n\t| ButtonBuilder\n\t| ChannelSelectMenuBuilder\n\t| MentionableSelectMenuBuilder\n\t| RoleSelectMenuBuilder\n\t| StringSelectMenuBuilder\n\t| UserSelectMenuBuilder;\n\n/**\n * The builders that may be used within an action row for modals.\n */\nexport type ModalActionRowComponentBuilder = TextInputBuilder;\n\n/**\n * Any builder.\n */\nexport type AnyComponentBuilder = MessageActionRowComponentBuilder | ModalActionRowComponentBuilder;\n\n/**\n * A builder that creates API-compatible JSON data for action rows.\n *\n * @typeParam ComponentType - The types of components this action row holds\n */\nexport class ActionRowBuilder extends ComponentBuilder<\n\tAPIActionRowComponent\n> {\n\t/**\n\t * The components within this action row.\n\t */\n\tpublic readonly components: ComponentType[];\n\n\t/**\n\t * Creates a new action row from API data.\n\t *\n\t * @param data - The API data to create this action row with\n\t * @example\n\t * Creating an action row from an API data object:\n\t * ```ts\n\t * const actionRow = new ActionRowBuilder({\n\t * \tcomponents: [\n\t * \t\t{\n\t * \t\t\tcustom_id: \"custom id\",\n\t * \t\t\tlabel: \"Type something\",\n\t * \t\t\tstyle: TextInputStyle.Short,\n\t * \t\t\ttype: ComponentType.TextInput,\n\t * \t\t},\n\t * \t],\n\t * });\n\t * ```\n\t * @example\n\t * Creating an action row using setters and API data:\n\t * ```ts\n\t * const actionRow = new ActionRowBuilder({\n\t * \tcomponents: [\n\t * \t\t{\n\t * \t\t\tcustom_id: \"custom id\",\n\t * \t\t\tlabel: \"Click me\",\n\t * \t\t\tstyle: ButtonStyle.Primary,\n\t * \t\t\ttype: ComponentType.Button,\n\t * \t\t},\n\t * \t],\n\t * })\n\t * \t.addComponents(button2, button3);\n\t * ```\n\t */\n\tpublic constructor({ components, ...data }: Partial> = {}) {\n\t\tsuper({ type: ComponentType.ActionRow, ...data });\n\t\tthis.components = (components?.map((component) => createComponentBuilder(component)) ?? []) as ComponentType[];\n\t}\n\n\t/**\n\t * Adds components to this action row.\n\t *\n\t * @param components - The components to add\n\t */\n\tpublic addComponents(...components: RestOrArray) {\n\t\tthis.components.push(...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets components for this action row.\n\t *\n\t * @param components - The components to set\n\t */\n\tpublic setComponents(...components: RestOrArray) {\n\t\tthis.components.splice(0, this.components.length, ...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIActionRowComponent> {\n\t\treturn {\n\t\t\t...this.data,\n\t\t\tcomponents: this.components.map((component) => component.toJSON()),\n\t\t} as APIActionRowComponent>;\n\t}\n}\n","import type { JSONEncodable } from '@discordjs/util';\nimport type {\n\tAPIActionRowComponent,\n\tAPIActionRowComponentTypes,\n\tAPIBaseComponent,\n\tComponentType,\n} from 'discord-api-types/v10';\n\n/**\n * Any action row component data represented as an object.\n */\nexport type AnyAPIActionRowComponent = APIActionRowComponent | APIActionRowComponentTypes;\n\n/**\n * The base component builder that contains common symbols for all sorts of components.\n *\n * @typeParam DataType - The type of internal API data that is stored within the component\n */\nexport abstract class ComponentBuilder<\n\tDataType extends Partial> = APIBaseComponent,\n> implements JSONEncodable\n{\n\t/**\n\t * The API data associated with this component.\n\t */\n\tpublic readonly data: Partial;\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic abstract toJSON(): AnyAPIActionRowComponent;\n\n\t/**\n\t * Constructs a new kind of component.\n\t *\n\t * @param data - The data to construct a component out of\n\t */\n\tpublic constructor(data: Partial) {\n\t\tthis.data = data;\n\t}\n}\n","import { ComponentType, type APIMessageComponent, type APIModalComponent } from 'discord-api-types/v10';\nimport {\n\tActionRowBuilder,\n\ttype AnyComponentBuilder,\n\ttype MessageComponentBuilder,\n\ttype ModalComponentBuilder,\n} from './ActionRow.js';\nimport { ComponentBuilder } from './Component.js';\nimport { ButtonBuilder } from './button/Button.js';\nimport { ChannelSelectMenuBuilder } from './selectMenu/ChannelSelectMenu.js';\nimport { MentionableSelectMenuBuilder } from './selectMenu/MentionableSelectMenu.js';\nimport { RoleSelectMenuBuilder } from './selectMenu/RoleSelectMenu.js';\nimport { StringSelectMenuBuilder } from './selectMenu/StringSelectMenu.js';\nimport { UserSelectMenuBuilder } from './selectMenu/UserSelectMenu.js';\nimport { TextInputBuilder } from './textInput/TextInput.js';\n\n/**\n * Components here are mapped to their respective builder.\n */\nexport interface MappedComponentTypes {\n\t/**\n\t * The action row component type is associated with an {@link ActionRowBuilder}.\n\t */\n\t[ComponentType.ActionRow]: ActionRowBuilder;\n\t/**\n\t * The button component type is associated with a {@link ButtonBuilder}.\n\t */\n\t[ComponentType.Button]: ButtonBuilder;\n\t/**\n\t * The string select component type is associated with a {@link StringSelectMenuBuilder}.\n\t */\n\t[ComponentType.StringSelect]: StringSelectMenuBuilder;\n\t/**\n\t * The text input component type is associated with a {@link TextInputBuilder}.\n\t */\n\t[ComponentType.TextInput]: TextInputBuilder;\n\t/**\n\t * The user select component type is associated with a {@link UserSelectMenuBuilder}.\n\t */\n\t[ComponentType.UserSelect]: UserSelectMenuBuilder;\n\t/**\n\t * The role select component type is associated with a {@link RoleSelectMenuBuilder}.\n\t */\n\t[ComponentType.RoleSelect]: RoleSelectMenuBuilder;\n\t/**\n\t * The mentionable select component type is associated with a {@link MentionableSelectMenuBuilder}.\n\t */\n\t[ComponentType.MentionableSelect]: MentionableSelectMenuBuilder;\n\t/**\n\t * The channel select component type is associated with a {@link ChannelSelectMenuBuilder}.\n\t */\n\t[ComponentType.ChannelSelect]: ChannelSelectMenuBuilder;\n}\n\n/**\n * Factory for creating components from API data.\n *\n * @typeParam ComponentType - The type of component to use\n * @param data - The API data to transform to a component class\n */\nexport function createComponentBuilder(\n\t// eslint-disable-next-line @typescript-eslint/sort-type-constituents\n\tdata: (APIModalComponent | APIMessageComponent) & { type: ComponentType },\n): MappedComponentTypes[ComponentType];\n\n/**\n * Factory for creating components from API data.\n *\n * @typeParam ComponentBuilder - The type of component to use\n * @param data - The API data to transform to a component class\n */\nexport function createComponentBuilder(\n\tdata: ComponentBuilder,\n): ComponentBuilder;\n\nexport function createComponentBuilder(\n\tdata: APIMessageComponent | APIModalComponent | MessageComponentBuilder,\n): ComponentBuilder {\n\tif (data instanceof ComponentBuilder) {\n\t\treturn data;\n\t}\n\n\tswitch (data.type) {\n\t\tcase ComponentType.ActionRow:\n\t\t\treturn new ActionRowBuilder(data);\n\t\tcase ComponentType.Button:\n\t\t\treturn new ButtonBuilder(data);\n\t\tcase ComponentType.StringSelect:\n\t\t\treturn new StringSelectMenuBuilder(data);\n\t\tcase ComponentType.TextInput:\n\t\t\treturn new TextInputBuilder(data);\n\t\tcase ComponentType.UserSelect:\n\t\t\treturn new UserSelectMenuBuilder(data);\n\t\tcase ComponentType.RoleSelect:\n\t\t\treturn new RoleSelectMenuBuilder(data);\n\t\tcase ComponentType.MentionableSelect:\n\t\t\treturn new MentionableSelectMenuBuilder(data);\n\t\tcase ComponentType.ChannelSelect:\n\t\t\treturn new ChannelSelectMenuBuilder(data);\n\t\tdefault:\n\t\t\t// @ts-expect-error This case can still occur if we get a newer unsupported component type\n\t\t\tthrow new Error(`Cannot properly serialize component type: ${data.type}`);\n\t}\n}\n","import {\n\tComponentType,\n\ttype APIButtonComponent,\n\ttype APIButtonComponentWithCustomId,\n\ttype APIButtonComponentWithSKUId,\n\ttype APIButtonComponentWithURL,\n\ttype APIMessageComponentEmoji,\n\ttype ButtonStyle,\n\ttype Snowflake,\n} from 'discord-api-types/v10';\nimport {\n\tbuttonLabelValidator,\n\tbuttonStyleValidator,\n\tcustomIdValidator,\n\tdisabledValidator,\n\temojiValidator,\n\turlValidator,\n\tvalidateRequiredButtonParameters,\n} from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\n\n/**\n * A builder that creates API-compatible JSON data for buttons.\n */\nexport class ButtonBuilder extends ComponentBuilder {\n\t/**\n\t * Creates a new button from API data.\n\t *\n\t * @param data - The API data to create this button with\n\t * @example\n\t * Creating a button from an API data object:\n\t * ```ts\n\t * const button = new ButtonBuilder({\n\t * \tcustom_id: 'a cool button',\n\t * \tstyle: ButtonStyle.Primary,\n\t * \tlabel: 'Click Me',\n\t * \temoji: {\n\t * \t\tname: 'smile',\n\t * \t\tid: '123456789012345678',\n\t * \t},\n\t * });\n\t * ```\n\t * @example\n\t * Creating a button using setters and API data:\n\t * ```ts\n\t * const button = new ButtonBuilder({\n\t * \tstyle: ButtonStyle.Secondary,\n\t * \tlabel: 'Click Me',\n\t * })\n\t * \t.setEmoji({ name: '🙂' })\n\t * \t.setCustomId('another cool button');\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ type: ComponentType.Button, ...data });\n\t}\n\n\t/**\n\t * Sets the style of this button.\n\t *\n\t * @param style - The style to use\n\t */\n\tpublic setStyle(style: ButtonStyle) {\n\t\tthis.data.style = buttonStyleValidator.parse(style);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the URL for this button.\n\t *\n\t * @remarks\n\t * This method is only available to buttons using the `Link` button style.\n\t * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`.\n\t * @param url - The URL to use\n\t */\n\tpublic setURL(url: string) {\n\t\t(this.data as APIButtonComponentWithURL).url = urlValidator.parse(url);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id for this button.\n\t *\n\t * @remarks\n\t * This method is only applicable to buttons that are not using the `Link` button style.\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\t(this.data as APIButtonComponentWithCustomId).custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the SKU id that represents a purchasable SKU for this button.\n\t *\n\t * @remarks Only available when using premium-style buttons.\n\t * @param skuId - The SKU id to use\n\t */\n\tpublic setSKUId(skuId: Snowflake) {\n\t\t(this.data as APIButtonComponentWithSKUId).sku_id = skuId;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the emoji to display on this button.\n\t *\n\t * @param emoji - The emoji to use\n\t */\n\tpublic setEmoji(emoji: APIMessageComponentEmoji) {\n\t\t(this.data as Exclude).emoji = emojiValidator.parse(emoji);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this button is disabled.\n\t *\n\t * @param disabled - Whether to disable this button\n\t */\n\tpublic setDisabled(disabled = true) {\n\t\tthis.data.disabled = disabledValidator.parse(disabled);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the label for this button.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\t(this.data as Exclude).label = buttonLabelValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIButtonComponent {\n\t\tvalidateRequiredButtonParameters(\n\t\t\tthis.data.style,\n\t\t\t(this.data as Exclude).label,\n\t\t\t(this.data as Exclude).emoji,\n\t\t\t(this.data as APIButtonComponentWithCustomId).custom_id,\n\t\t\t(this.data as APIButtonComponentWithSKUId).sku_id,\n\t\t\t(this.data as APIButtonComponentWithURL).url,\n\t\t);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APIButtonComponent;\n\t}\n}\n","import {\n\ttype APIChannelSelectComponent,\n\ttype ChannelType,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { channelTypesValidator, customIdValidator, optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for channel select menus.\n */\nexport class ChannelSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new ChannelSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new ChannelSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement)\n\t * \t.setMinValues(2);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.ChannelSelect });\n\t}\n\n\t/**\n\t * Adds channel types to this select menu.\n\t *\n\t * @param types - The channel types to use\n\t */\n\tpublic addChannelTypes(...types: RestOrArray) {\n\t\tconst normalizedTypes = normalizeArray(types);\n\t\tthis.data.channel_types ??= [];\n\t\tthis.data.channel_types.push(...channelTypesValidator.parse(normalizedTypes));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets channel types for this select menu.\n\t *\n\t * @param types - The channel types to use\n\t */\n\tpublic setChannelTypes(...types: RestOrArray) {\n\t\tconst normalizedTypes = normalizeArray(types);\n\t\tthis.data.channel_types ??= [];\n\t\tthis.data.channel_types.splice(0, this.data.channel_types.length, ...channelTypesValidator.parse(normalizedTypes));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default channels to this auto populated select menu.\n\t *\n\t * @param channels - The channels to add\n\t */\n\tpublic addDefaultChannels(...channels: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(channels);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Channel as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default channels for this auto populated select menu.\n\t *\n\t * @param channels - The channels to set\n\t */\n\tpublic setDefaultChannels(...channels: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(channels);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.Channel as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic override toJSON(): APIChannelSelectComponent {\n\t\tcustomIdValidator.parse(this.data.custom_id);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APIChannelSelectComponent;\n\t}\n}\n","import type { APISelectMenuComponent } from 'discord-api-types/v10';\nimport { customIdValidator, disabledValidator, minMaxValidator, placeholderValidator } from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\n\n/**\n * The base select menu builder that contains common symbols for select menu builders.\n *\n * @typeParam SelectMenuType - The type of select menu this would be instantiated for.\n */\nexport abstract class BaseSelectMenuBuilder<\n\tSelectMenuType extends APISelectMenuComponent,\n> extends ComponentBuilder {\n\t/**\n\t * Sets the placeholder for this select menu.\n\t *\n\t * @param placeholder - The placeholder to use\n\t */\n\tpublic setPlaceholder(placeholder: string) {\n\t\tthis.data.placeholder = placeholderValidator.parse(placeholder);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum values that must be selected in the select menu.\n\t *\n\t * @param minValues - The minimum values that must be selected\n\t */\n\tpublic setMinValues(minValues: number) {\n\t\tthis.data.min_values = minMaxValidator.parse(minValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the maximum values that must be selected in the select menu.\n\t *\n\t * @param maxValues - The maximum values that must be selected\n\t */\n\tpublic setMaxValues(maxValues: number) {\n\t\tthis.data.max_values = minMaxValidator.parse(maxValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id for this select menu.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this select menu is disabled.\n\t *\n\t * @param disabled - Whether this select menu is disabled\n\t */\n\tpublic setDisabled(disabled = true) {\n\t\tthis.data.disabled = disabledValidator.parse(disabled);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): SelectMenuType {\n\t\tcustomIdValidator.parse(this.data.custom_id);\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as SelectMenuType;\n\t}\n}\n","import {\n\ttype APIMentionableSelectComponent,\n\ttype APISelectMenuDefaultValue,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for mentionable select menus.\n */\nexport class MentionableSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new MentionableSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new MentionableSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.MentionableSelect });\n\t}\n\n\t/**\n\t * Adds default roles to this auto populated select menu.\n\t *\n\t * @param roles - The roles to add\n\t */\n\tpublic addDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default users to this auto populated select menu.\n\t *\n\t * @param users - The users to add\n\t */\n\tpublic addDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default values to this auto populated select menu.\n\t *\n\t * @param values - The values to add\n\t */\n\tpublic addDefaultValues(\n\t\t...values: RestOrArray<\n\t\t\t| APISelectMenuDefaultValue\n\t\t\t| APISelectMenuDefaultValue\n\t\t>\n\t) {\n\t\tconst normalizedValues = normalizeArray(values);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\t\tthis.data.default_values.push(...normalizedValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default values for this auto populated select menu.\n\t *\n\t * @param values - The values to set\n\t */\n\tpublic setDefaultValues(\n\t\t...values: RestOrArray<\n\t\t\t| APISelectMenuDefaultValue\n\t\t\t| APISelectMenuDefaultValue\n\t\t>\n\t) {\n\t\tconst normalizedValues = normalizeArray(values);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\t\tthis.data.default_values = normalizedValues;\n\t\treturn this;\n\t}\n}\n","import {\n\ttype APIRoleSelectComponent,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for role select menus.\n */\nexport class RoleSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new RoleSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new RoleSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.RoleSelect });\n\t}\n\n\t/**\n\t * Adds default roles to this auto populated select menu.\n\t *\n\t * @param roles - The roles to add\n\t */\n\tpublic addDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default roles for this auto populated select menu.\n\t *\n\t * @param roles - The roles to set\n\t */\n\tpublic setDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n}\n","import { ComponentType } from 'discord-api-types/v10';\nimport type { APIStringSelectComponent, APISelectMenuOption } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport { jsonOptionValidator, optionsLengthValidator, validateRequiredSelectMenuParameters } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\nimport { StringSelectMenuOptionBuilder } from './StringSelectMenuOption.js';\n\n/**\n * A builder that creates API-compatible JSON data for string select menus.\n */\nexport class StringSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * The options within this select menu.\n\t */\n\tpublic readonly options: StringSelectMenuOptionBuilder[];\n\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new StringSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * \toptions: [\n\t * \t\t{ label: 'option 1', value: '1' },\n\t * \t\t{ label: 'option 2', value: '2' },\n\t * \t\t{ label: 'option 3', value: '3' },\n\t * \t],\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new StringSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1)\n\t * \t.addOptions({\n\t * \t\tlabel: 'Catchy',\n\t * \t\tvalue: 'catch',\n\t * \t});\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tconst { options, ...initData } = data ?? {};\n\t\tsuper({ ...initData, type: ComponentType.StringSelect });\n\t\tthis.options = options?.map((option: APISelectMenuOption) => new StringSelectMenuOptionBuilder(option)) ?? [];\n\t}\n\n\t/**\n\t * Adds options to this select menu.\n\t *\n\t * @param options - The options to add\n\t */\n\tpublic addOptions(...options: RestOrArray) {\n\t\tconst normalizedOptions = normalizeArray(options);\n\t\toptionsLengthValidator.parse(this.options.length + normalizedOptions.length);\n\t\tthis.options.push(\n\t\t\t...normalizedOptions.map((normalizedOption) =>\n\t\t\t\tnormalizedOption instanceof StringSelectMenuOptionBuilder\n\t\t\t\t\t? normalizedOption\n\t\t\t\t\t: new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)),\n\t\t\t),\n\t\t);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the options for this select menu.\n\t *\n\t * @param options - The options to set\n\t */\n\tpublic setOptions(...options: RestOrArray) {\n\t\treturn this.spliceOptions(0, this.options.length, ...options);\n\t}\n\n\t/**\n\t * Removes, replaces, or inserts options for this select menu.\n\t *\n\t * @remarks\n\t * This method behaves similarly\n\t * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}.\n\t * It's useful for modifying and adjusting the order of existing options.\n\t * @example\n\t * Remove the first option:\n\t * ```ts\n\t * selectMenu.spliceOptions(0, 1);\n\t * ```\n\t * @example\n\t * Remove the first n option:\n\t * ```ts\n\t * const n = 4;\n\t * selectMenu.spliceOptions(0, n);\n\t * ```\n\t * @example\n\t * Remove the last option:\n\t * ```ts\n\t * selectMenu.spliceOptions(-1, 1);\n\t * ```\n\t * @param index - The index to start at\n\t * @param deleteCount - The number of options to remove\n\t * @param options - The replacing option objects or builders\n\t */\n\tpublic spliceOptions(\n\t\tindex: number,\n\t\tdeleteCount: number,\n\t\t...options: RestOrArray\n\t) {\n\t\tconst normalizedOptions = normalizeArray(options);\n\n\t\tconst clone = [...this.options];\n\n\t\tclone.splice(\n\t\t\tindex,\n\t\t\tdeleteCount,\n\t\t\t...normalizedOptions.map((normalizedOption) =>\n\t\t\t\tnormalizedOption instanceof StringSelectMenuOptionBuilder\n\t\t\t\t\t? normalizedOption\n\t\t\t\t\t: new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)),\n\t\t\t),\n\t\t);\n\n\t\toptionsLengthValidator.parse(clone.length);\n\t\tthis.options.splice(0, this.options.length, ...clone);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic override toJSON(): APIStringSelectComponent {\n\t\tvalidateRequiredSelectMenuParameters(this.options, this.data.custom_id);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t} as APIStringSelectComponent;\n\t}\n}\n","import {\n\ttype APIUserSelectComponent,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for user select menus.\n */\nexport class UserSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new UserSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new UserSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.UserSelect });\n\t}\n\n\t/**\n\t * Adds default users to this auto populated select menu.\n\t *\n\t * @param users - The users to add\n\t */\n\tpublic addDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default users for this auto populated select menu.\n\t *\n\t * @param users - The users to set\n\t */\n\tpublic setDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n}\n","import { isJSONEncodable, type Equatable, type JSONEncodable } from '@discordjs/util';\nimport { ComponentType, type TextInputStyle, type APITextInputComponent } from 'discord-api-types/v10';\nimport isEqual from 'fast-deep-equal';\nimport { customIdValidator } from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\nimport {\n\tmaxLengthValidator,\n\tminLengthValidator,\n\tplaceholderValidator,\n\trequiredValidator,\n\tvalueValidator,\n\tvalidateRequiredParameters,\n\tlabelValidator,\n\ttextInputStyleValidator,\n} from './Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for text inputs.\n */\nexport class TextInputBuilder\n\textends ComponentBuilder\n\timplements Equatable>\n{\n\t/**\n\t * Creates a new text input from API data.\n\t *\n\t * @param data - The API data to create this text input with\n\t * @example\n\t * Creating a text input from an API data object:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tcustom_id: 'a cool text input',\n\t * \tlabel: 'Type something',\n\t * \tstyle: TextInputStyle.Short,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a text input using setters and API data:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tlabel: 'Type something else',\n\t * })\n\t * \t.setCustomId('woah')\n\t * \t.setStyle(TextInputStyle.Paragraph);\n\t * ```\n\t */\n\tpublic constructor(data?: APITextInputComponent & { type?: ComponentType.TextInput }) {\n\t\tsuper({ type: ComponentType.TextInput, ...data });\n\t}\n\n\t/**\n\t * Sets the custom id for this text input.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the label for this text input.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\tthis.data.label = labelValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the style for this text input.\n\t *\n\t * @param style - The style to use\n\t */\n\tpublic setStyle(style: TextInputStyle) {\n\t\tthis.data.style = textInputStyleValidator.parse(style);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum length of text for this text input.\n\t *\n\t * @param minLength - The minimum length of text for this text input\n\t */\n\tpublic setMinLength(minLength: number) {\n\t\tthis.data.min_length = minLengthValidator.parse(minLength);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the maximum length of text for this text input.\n\t *\n\t * @param maxLength - The maximum length of text for this text input\n\t */\n\tpublic setMaxLength(maxLength: number) {\n\t\tthis.data.max_length = maxLengthValidator.parse(maxLength);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the placeholder for this text input.\n\t *\n\t * @param placeholder - The placeholder to use\n\t */\n\tpublic setPlaceholder(placeholder: string) {\n\t\tthis.data.placeholder = placeholderValidator.parse(placeholder);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the value for this text input.\n\t *\n\t * @param value - The value to use\n\t */\n\tpublic setValue(value: string) {\n\t\tthis.data.value = valueValidator.parse(value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this text input is required.\n\t *\n\t * @param required - Whether this text input is required\n\t */\n\tpublic setRequired(required = true) {\n\t\tthis.data.required = requiredValidator.parse(required);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APITextInputComponent {\n\t\tvalidateRequiredParameters(this.data.custom_id, this.data.style, this.data.label);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APITextInputComponent;\n\t}\n\n\t/**\n\t * Whether this is equal to another structure.\n\t */\n\tpublic equals(other: APITextInputComponent | JSONEncodable): boolean {\n\t\tif (isJSONEncodable(other)) {\n\t\t\treturn isEqual(other.toJSON(), this.data);\n\t\t}\n\n\t\treturn isEqual(other, this.data);\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { TextInputStyle } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport { customIdValidator } from '../Assertions.js';\n\nexport const textInputStyleValidator = s.nativeEnum(TextInputStyle);\nexport const minLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const maxLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(1)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const requiredValidator = s.boolean();\nexport const valueValidator = s.string().lengthLessThanOrEqual(4_000).setValidationEnabled(isValidationEnabled);\nexport const placeholderValidator = s.string().lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled);\nexport const labelValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredParameters(customId?: string, style?: TextInputStyle, label?: string) {\n\tcustomIdValidator.parse(customId);\n\ttextInputStyleValidator.parse(style);\n\tlabelValidator.parse(label);\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ActionRowBuilder, type ModalActionRowComponentBuilder } from '../../components/ActionRow.js';\nimport { customIdValidator } from '../../components/Assertions.js';\nimport { isValidationEnabled } from '../../util/validation.js';\n\nexport const titleValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\nexport const componentsValidator = s\n\t.instance(ActionRowBuilder)\n\t.array()\n\t.lengthGreaterThanOrEqual(1)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredParameters(\n\tcustomId?: string,\n\ttitle?: string,\n\tcomponents?: ActionRowBuilder[],\n) {\n\tcustomIdValidator.parse(customId);\n\ttitleValidator.parse(title);\n\tcomponentsValidator.parse(components);\n}\n","/* eslint-disable jsdoc/check-param-names */\n\nimport type { JSONEncodable } from '@discordjs/util';\nimport type {\n\tAPIActionRowComponent,\n\tAPIModalActionRowComponent,\n\tAPIModalInteractionResponseCallbackData,\n} from 'discord-api-types/v10';\nimport { ActionRowBuilder, type ModalActionRowComponentBuilder } from '../../components/ActionRow.js';\nimport { customIdValidator } from '../../components/Assertions.js';\nimport { createComponentBuilder } from '../../components/Components.js';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport { titleValidator, validateRequiredParameters } from './Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for modals.\n */\nexport class ModalBuilder implements JSONEncodable {\n\t/**\n\t * The API data associated with this modal.\n\t */\n\tpublic readonly data: Partial;\n\n\t/**\n\t * The components within this modal.\n\t */\n\tpublic readonly components: ActionRowBuilder[] = [];\n\n\t/**\n\t * Creates a new modal from API data.\n\t *\n\t * @param data - The API data to create this modal with\n\t */\n\tpublic constructor({ components, ...data }: Partial = {}) {\n\t\tthis.data = { ...data };\n\t\tthis.components = (components?.map((component) => createComponentBuilder(component)) ??\n\t\t\t[]) as ActionRowBuilder[];\n\t}\n\n\t/**\n\t * Sets the title of this modal.\n\t *\n\t * @param title - The title to use\n\t */\n\tpublic setTitle(title: string) {\n\t\tthis.data.title = titleValidator.parse(title);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id of this modal.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds components to this modal.\n\t *\n\t * @param components - The components to add\n\t */\n\tpublic addComponents(\n\t\t...components: RestOrArray<\n\t\t\tActionRowBuilder | APIActionRowComponent\n\t\t>\n\t) {\n\t\tthis.components.push(\n\t\t\t...normalizeArray(components).map((component) =>\n\t\t\t\tcomponent instanceof ActionRowBuilder\n\t\t\t\t\t? component\n\t\t\t\t\t: new ActionRowBuilder(component),\n\t\t\t),\n\t\t);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets components for this modal.\n\t *\n\t * @param components - The components to set\n\t */\n\tpublic setComponents(...components: RestOrArray>) {\n\t\tthis.components.splice(0, this.components.length, ...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIModalInteractionResponseCallbackData {\n\t\tvalidateRequiredParameters(this.data.custom_id, this.data.title, this.components);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t\tcomponents: this.components.map((component) => component.toJSON()),\n\t\t} as APIModalInteractionResponseCallbackData;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport {\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocale,\n\ttype APIApplicationCommandOptionChoice,\n\ttype LocalizationMap,\n} from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ToAPIApplicationCommandOptions } from './SlashCommandBuilder.js';\nimport type { SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder } from './SlashCommandSubcommands.js';\nimport type { ApplicationCommandOptionBase } from './mixins/ApplicationCommandOptionBase.js';\n\nconst namePredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(32)\n\t.regex(/^[\\p{Ll}\\p{Lm}\\p{Lo}\\p{N}\\p{sc=Devanagari}\\p{sc=Thai}_-]+$/u)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateName(name: unknown): asserts name is string {\n\tnamePredicate.parse(name);\n}\n\nconst descriptionPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\nconst localePredicate = s.nativeEnum(Locale);\n\nexport function validateDescription(description: unknown): asserts description is string {\n\tdescriptionPredicate.parse(description);\n}\n\nconst maxArrayLengthPredicate = s.unknown().array().lengthLessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\nexport function validateLocale(locale: unknown) {\n\treturn localePredicate.parse(locale);\n}\n\nexport function validateMaxOptionsLength(options: unknown): asserts options is ToAPIApplicationCommandOptions[] {\n\tmaxArrayLengthPredicate.parse(options);\n}\n\nexport function validateRequiredParameters(\n\tname: string,\n\tdescription: string,\n\toptions: ToAPIApplicationCommandOptions[],\n) {\n\t// Assert name matches all conditions\n\tvalidateName(name);\n\n\t// Assert description conditions\n\tvalidateDescription(description);\n\n\t// Assert options conditions\n\tvalidateMaxOptionsLength(options);\n}\n\nconst booleanPredicate = s.boolean();\n\nexport function validateDefaultPermission(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport function validateRequired(required: unknown): asserts required is boolean {\n\tbooleanPredicate.parse(required);\n}\n\nconst choicesLengthPredicate = s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\n\nexport function validateChoicesLength(amountAdding: number, choices?: APIApplicationCommandOptionChoice[]): void {\n\tchoicesLengthPredicate.parse((choices?.length ?? 0) + amountAdding);\n}\n\nexport function assertReturnOfBuilder<\n\tReturnType extends ApplicationCommandOptionBase | SlashCommandSubcommandBuilder | SlashCommandSubcommandGroupBuilder,\n>(input: unknown, ExpectedInstanceOf: new () => ReturnType): asserts input is ReturnType {\n\ts.instance(ExpectedInstanceOf).parse(input);\n}\n\nexport const localizationMapPredicate = s\n\t.object(Object.fromEntries(Object.values(Locale).map((locale) => [locale, s.string().nullish()])))\n\t.strict()\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateLocalizationMap(value: unknown): asserts value is LocalizationMap {\n\tlocalizationMapPredicate.parse(value);\n}\n\nconst dmPermissionPredicate = s.boolean().nullish();\n\nexport function validateDMPermission(value: unknown): asserts value is boolean | null | undefined {\n\tdmPermissionPredicate.parse(value);\n}\n\nconst memberPermissionPredicate = s\n\t.union([\n\t\ts.bigint().transform((value) => value.toString()),\n\t\ts\n\t\t\t.number()\n\t\t\t.safeInt()\n\t\t\t.transform((value) => value.toString()),\n\t\ts.string().regex(/^\\d+$/),\n\t])\n\t.nullish();\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n\nexport function validateNSFW(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport const contextsPredicate = s.array(\n\ts.nativeEnum(InteractionContextType).setValidationEnabled(isValidationEnabled),\n);\n\nexport const integrationTypesPredicate = s.array(\n\ts.nativeEnum(ApplicationIntegrationType).setValidationEnabled(isValidationEnabled),\n);\n","import type {\n\tAPIApplicationCommandOption,\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocalizationMap,\n\tPermissions,\n} from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { SharedNameAndDescription } from './mixins/NameAndDescription.js';\nimport { SharedSlashCommand } from './mixins/SharedSlashCommand.js';\nimport { SharedSlashCommandOptions } from './mixins/SharedSlashCommandOptions.js';\nimport { SharedSlashCommandSubcommands } from './mixins/SharedSubcommands.js';\n\n/**\n * A builder that creates API-compatible JSON data for slash commands.\n */\n@mix(SharedSlashCommandOptions, SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand)\nexport class SlashCommandBuilder {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The description of this command.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The description localizations of this command.\n\t */\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\t/**\n\t * The options of this command.\n\t */\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\t/**\n\t * The contexts for this command.\n\t */\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * Whether this command is enabled by default when the application is added to a guild.\n\t *\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The set of permissions represented as a bit set for the command.\n\t */\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * Indicates whether the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This property is only for global commands.\n\t * @deprecated\n\t * Use {@link SlashCommandBuilder.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The integration types for this command.\n\t */\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\t/**\n\t * Whether this command is NSFW.\n\t */\n\tpublic readonly nsfw: boolean | undefined = undefined;\n}\n\nexport interface SlashCommandBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions,\n\t\tSharedSlashCommandSubcommands,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface specifically for slash command subcommands.\n */\nexport interface SlashCommandSubcommandsOnlyBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandSubcommands,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface specifically for slash command options.\n */\nexport interface SlashCommandOptionsOnlyBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface that ensures the `toJSON()` call will return something\n * that can be serialized into API-compatible data.\n */\nexport interface ToAPIApplicationCommandOptions {\n\ttoJSON(): APIApplicationCommandOption;\n}\n","import type { LocaleString, LocalizationMap } from 'discord-api-types/v10';\nimport { validateDescription, validateLocale, validateName } from '../Assertions.js';\n\n/**\n * This mixin holds name and description symbols for slash commands.\n */\nexport class SharedNameAndDescription {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name!: string;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The description of this command.\n\t */\n\tpublic readonly description!: string;\n\n\t/**\n\t * The description localizations of this command.\n\t */\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\t/**\n\t * Sets the name of this command.\n\t *\n\t * @param name - The name to use\n\t */\n\tpublic setName(name: string): this {\n\t\t// Assert the name matches the conditions\n\t\tvalidateName(name);\n\n\t\tReflect.set(this, 'name', name);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description of this command.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string) {\n\t\t// Assert the description matches the conditions\n\t\tvalidateDescription(description);\n\n\t\tReflect.set(this, 'description', description);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a name localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedName - The localized name for the given `locale`\n\t */\n\tpublic setNameLocalization(locale: LocaleString, localizedName: string | null) {\n\t\tif (!this.name_localizations) {\n\t\t\tReflect.set(this, 'name_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedName === null) {\n\t\t\tthis.name_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateName(localizedName);\n\n\t\tthis.name_localizations![parsedLocale] = localizedName;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name localizations for this command.\n\t *\n\t * @param localizedNames - The object of localized names to set\n\t */\n\tpublic setNameLocalizations(localizedNames: LocalizationMap | null) {\n\t\tif (localizedNames === null) {\n\t\t\tReflect.set(this, 'name_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'name_localizations', {});\n\n\t\tfor (const args of Object.entries(localizedNames)) {\n\t\t\tthis.setNameLocalization(...(args as [LocaleString, string | null]));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a description localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedDescription - The localized description for the given locale\n\t */\n\tpublic setDescriptionLocalization(locale: LocaleString, localizedDescription: string | null) {\n\t\tif (!this.description_localizations) {\n\t\t\tReflect.set(this, 'description_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedDescription === null) {\n\t\t\tthis.description_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateDescription(localizedDescription);\n\n\t\tthis.description_localizations![parsedLocale] = localizedDescription;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description localizations for this command.\n\t *\n\t * @param localizedDescriptions - The object of localized descriptions to set\n\t */\n\tpublic setDescriptionLocalizations(localizedDescriptions: LocalizationMap | null) {\n\t\tif (localizedDescriptions === null) {\n\t\t\tReflect.set(this, 'description_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'description_localizations', {});\n\t\tfor (const args of Object.entries(localizedDescriptions)) {\n\t\t\tthis.setDescriptionLocalization(...(args as [LocaleString, string | null]));\n\t\t}\n\n\t\treturn this;\n\t}\n}\n","import {\n\tApplicationCommandType,\n\ttype ApplicationIntegrationType,\n\ttype InteractionContextType,\n\ttype LocalizationMap,\n\ttype Permissions,\n\ttype RESTPostAPIChatInputApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport type { RestOrArray } from '../../../util/normalizeArray.js';\nimport { normalizeArray } from '../../../util/normalizeArray.js';\nimport {\n\tcontextsPredicate,\n\tintegrationTypesPredicate,\n\tvalidateDMPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDefaultPermission,\n\tvalidateLocalizationMap,\n\tvalidateNSFW,\n\tvalidateRequiredParameters,\n} from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder.js';\n\n/**\n * This mixin holds symbols that can be shared in slashcommands independent of options or subcommands.\n */\nexport class SharedSlashCommand {\n\tpublic readonly name: string = undefined!;\n\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\tpublic readonly description: string = undefined!;\n\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * @deprecated Use {@link SharedSlashCommand.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\tpublic readonly nsfw: boolean | undefined = undefined;\n\n\t/**\n\t * Sets the contexts of this command.\n\t *\n\t * @param contexts - The contexts\n\t */\n\tpublic setContexts(...contexts: RestOrArray) {\n\t\tReflect.set(this, 'contexts', contextsPredicate.parse(normalizeArray(contexts)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the integration types of this command.\n\t *\n\t * @param integrationTypes - The integration types\n\t */\n\tpublic setIntegrationTypes(...integrationTypes: RestOrArray) {\n\t\tReflect.set(this, 'integration_types', integrationTypesPredicate.parse(normalizeArray(integrationTypes)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether the command is enabled by default when the application is added to a guild.\n\t *\n\t * @remarks\n\t * If set to `false`, you will have to later `PUT` the permissions for this command.\n\t * @param value - Whether or not to enable this command by default\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic setDefaultPermission(value: boolean) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDefaultPermission(value);\n\n\t\tReflect.set(this, 'default_permission', value);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the default permissions a member should have in order to run the command.\n\t *\n\t * @remarks\n\t * You can set this to `'0'` to disable the command by default.\n\t * @param permissions - The permissions bit field to set\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t */\n\tpublic setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined) {\n\t\t// Assert the value and parse it\n\t\tconst permissionValue = validateDefaultMemberPermissions(permissions);\n\n\t\tReflect.set(this, 'default_member_permissions', permissionValue);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets if the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This method is only for global commands.\n\t * @param enabled - Whether the command should be enabled in direct messages\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated\n\t * Use {@link SharedSlashCommand.setContexts} instead.\n\t */\n\tpublic setDMPermission(enabled: boolean | null | undefined) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDMPermission(enabled);\n\n\t\tReflect.set(this, 'dm_permission', enabled);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this command is NSFW.\n\t *\n\t * @param nsfw - Whether this command is NSFW\n\t */\n\tpublic setNSFW(nsfw = true) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateNSFW(nsfw);\n\t\tReflect.set(this, 'nsfw', nsfw);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): RESTPostAPIChatInputApplicationCommandsJSONBody {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\tvalidateLocalizationMap(this.name_localizations);\n\t\tvalidateLocalizationMap(this.description_localizations);\n\n\t\treturn {\n\t\t\t...this,\n\t\t\ttype: ApplicationCommandType.ChatInput,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandAttachmentOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command attachment option.\n */\nexport class SlashCommandAttachmentOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Attachment as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandAttachmentOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import type { APIApplicationCommandBasicOption, ApplicationCommandOptionType } from 'discord-api-types/v10';\nimport { validateRequiredParameters, validateRequired, validateLocalizationMap } from '../Assertions.js';\nimport { SharedNameAndDescription } from './NameAndDescription.js';\n\n/**\n * The base application command option builder that contains common symbols for application command builders.\n */\nexport abstract class ApplicationCommandOptionBase extends SharedNameAndDescription {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic abstract readonly type: ApplicationCommandOptionType;\n\n\t/**\n\t * Whether this option is required.\n\t *\n\t * @defaultValue `false`\n\t */\n\tpublic readonly required: boolean = false;\n\n\t/**\n\t * Sets whether this option is required.\n\t *\n\t * @param required - Whether this option should be required\n\t */\n\tpublic setRequired(required: boolean) {\n\t\t// Assert that you actually passed a boolean\n\t\tvalidateRequired(required);\n\n\t\tReflect.set(this, 'required', required);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic abstract toJSON(): APIApplicationCommandBasicOption;\n\n\t/**\n\t * This method runs required validators on this builder.\n\t */\n\tprotected runRequiredValidations() {\n\t\tvalidateRequiredParameters(this.name, this.description, []);\n\n\t\t// Validate localizations\n\t\tvalidateLocalizationMap(this.name_localizations);\n\t\tvalidateLocalizationMap(this.description_localizations);\n\n\t\t// Assert that you actually passed a boolean\n\t\tvalidateRequired(this.required);\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandBooleanOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command boolean option.\n */\nexport class SlashCommandBooleanOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Boolean as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandBooleanOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandChannelOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionChannelTypesMixin } from '../mixins/ApplicationCommandOptionChannelTypesMixin.js';\n\n/**\n * A slash command channel option.\n */\n@mix(ApplicationCommandOptionChannelTypesMixin)\nexport class SlashCommandChannelOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Channel as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandChannelOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n\nexport interface SlashCommandChannelOption extends ApplicationCommandOptionChannelTypesMixin {}\n","import { s } from '@sapphire/shapeshift';\nimport { ChannelType } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../../util/normalizeArray';\n\n/**\n * The allowed channel types used for a channel option in a slash command builder.\n *\n * @privateRemarks This can't be dynamic because const enums are erased at runtime.\n * @internal\n */\nconst allowedChannelTypes = [\n\tChannelType.GuildText,\n\tChannelType.GuildVoice,\n\tChannelType.GuildCategory,\n\tChannelType.GuildAnnouncement,\n\tChannelType.AnnouncementThread,\n\tChannelType.PublicThread,\n\tChannelType.PrivateThread,\n\tChannelType.GuildStageVoice,\n\tChannelType.GuildForum,\n\tChannelType.GuildMedia,\n] as const;\n\n/**\n * The type of allowed channel types used for a channel option.\n */\nexport type ApplicationCommandOptionAllowedChannelTypes = (typeof allowedChannelTypes)[number];\n\nconst channelTypesPredicate = s.array(s.union(allowedChannelTypes.map((type) => s.literal(type))));\n\n/**\n * This mixin holds channel type symbols used for options.\n */\nexport class ApplicationCommandOptionChannelTypesMixin {\n\t/**\n\t * The channel types of this option.\n\t */\n\tpublic readonly channel_types?: ApplicationCommandOptionAllowedChannelTypes[];\n\n\t/**\n\t * Adds channel types to this option.\n\t *\n\t * @param channelTypes - The channel types\n\t */\n\tpublic addChannelTypes(...channelTypes: RestOrArray) {\n\t\tif (this.channel_types === undefined) {\n\t\t\tReflect.set(this, 'channel_types', []);\n\t\t}\n\n\t\tthis.channel_types!.push(...channelTypesPredicate.parse(normalizeArray(channelTypes)));\n\n\t\treturn this;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandIntegerOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandNumericOptionMinMaxValueMixin } from '../mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst numberValidator = s.number().int();\n\n/**\n * A slash command integer option.\n */\n@mix(\n\tApplicationCommandNumericOptionMinMaxValueMixin,\n\tApplicationCommandOptionWithAutocompleteMixin,\n\tApplicationCommandOptionWithChoicesMixin,\n)\nexport class SlashCommandIntegerOption\n\textends ApplicationCommandOptionBase\n\timplements ApplicationCommandNumericOptionMinMaxValueMixin\n{\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Integer as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue}\n\t */\n\tpublic setMaxValue(max: number): this {\n\t\tnumberValidator.parse(max);\n\n\t\tReflect.set(this, 'max_value', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue}\n\t */\n\tpublic setMinValue(min: number): this {\n\t\tnumberValidator.parse(min);\n\n\t\tReflect.set(this, 'min_value', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandIntegerOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandIntegerOption;\n\t}\n}\n\nexport interface SlashCommandIntegerOption\n\textends ApplicationCommandNumericOptionMinMaxValueMixin,\n\t\tApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","/**\n * This mixin holds minimum and maximum symbols used for options.\n */\nexport abstract class ApplicationCommandNumericOptionMinMaxValueMixin {\n\t/**\n\t * The maximum value of this option.\n\t */\n\tpublic readonly max_value?: number;\n\n\t/**\n\t * The minimum value of this option.\n\t */\n\tpublic readonly min_value?: number;\n\n\t/**\n\t * Sets the maximum number value of this option.\n\t *\n\t * @param max - The maximum value this option can be\n\t */\n\tpublic abstract setMaxValue(max: number): this;\n\n\t/**\n\t * Sets the minimum number value of this option.\n\t *\n\t * @param min - The minimum value this option can be\n\t */\n\tpublic abstract setMinValue(min: number): this;\n}\n","import { s } from '@sapphire/shapeshift';\nimport type { ApplicationCommandOptionType } from 'discord-api-types/v10';\n\nconst booleanPredicate = s.boolean();\n\n/**\n * This mixin holds choices and autocomplete symbols used for options.\n */\nexport class ApplicationCommandOptionWithAutocompleteMixin {\n\t/**\n\t * Whether this option utilizes autocomplete.\n\t */\n\tpublic readonly autocomplete?: boolean;\n\n\t/**\n\t * The type of this option.\n\t *\n\t * @privateRemarks Since this is present and this is a mixin, this is needed.\n\t */\n\tpublic readonly type!: ApplicationCommandOptionType;\n\n\t/**\n\t * Whether this option uses autocomplete.\n\t *\n\t * @param autocomplete - Whether this option should use autocomplete\n\t */\n\tpublic setAutocomplete(autocomplete: boolean): this {\n\t\t// Assert that you actually passed a boolean\n\t\tbooleanPredicate.parse(autocomplete);\n\n\t\tif (autocomplete && 'choices' in this && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tReflect.set(this, 'autocomplete', autocomplete);\n\n\t\treturn this;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandOptionChoice } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../../util/normalizeArray.js';\nimport { localizationMapPredicate, validateChoicesLength } from '../Assertions.js';\n\nconst stringPredicate = s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100);\nconst numberPredicate = s.number().greaterThan(Number.NEGATIVE_INFINITY).lessThan(Number.POSITIVE_INFINITY);\nconst choicesPredicate = s\n\t.object({\n\t\tname: stringPredicate,\n\t\tname_localizations: localizationMapPredicate,\n\t\tvalue: s.union([stringPredicate, numberPredicate]),\n\t})\n\t.array();\n\n/**\n * This mixin holds choices and autocomplete symbols used for options.\n */\nexport class ApplicationCommandOptionWithChoicesMixin {\n\t/**\n\t * The choices of this option.\n\t */\n\tpublic readonly choices?: APIApplicationCommandOptionChoice[];\n\n\t/**\n\t * The type of this option.\n\t *\n\t * @privateRemarks Since this is present and this is a mixin, this is needed.\n\t */\n\tpublic readonly type!: ApplicationCommandOptionType;\n\n\t/**\n\t * Adds multiple choices to this option.\n\t *\n\t * @param choices - The choices to add\n\t */\n\tpublic addChoices(...choices: RestOrArray>): this {\n\t\tconst normalizedChoices = normalizeArray(choices);\n\t\tif (normalizedChoices.length > 0 && 'autocomplete' in this && this.autocomplete) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tchoicesPredicate.parse(normalizedChoices);\n\n\t\tif (this.choices === undefined) {\n\t\t\tReflect.set(this, 'choices', []);\n\t\t}\n\n\t\tvalidateChoicesLength(normalizedChoices.length, this.choices);\n\n\t\tfor (const { name, name_localizations, value } of normalizedChoices) {\n\t\t\t// Validate the value\n\t\t\tif (this.type === ApplicationCommandOptionType.String) {\n\t\t\t\tstringPredicate.parse(value);\n\t\t\t} else {\n\t\t\t\tnumberPredicate.parse(value);\n\t\t\t}\n\n\t\t\tthis.choices!.push({ name, name_localizations, value });\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets multiple choices for this option.\n\t *\n\t * @param choices - The choices to set\n\t */\n\tpublic setChoices>(...choices: RestOrArray): this {\n\t\tconst normalizedChoices = normalizeArray(choices);\n\t\tif (normalizedChoices.length > 0 && 'autocomplete' in this && this.autocomplete) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tchoicesPredicate.parse(normalizedChoices);\n\n\t\tReflect.set(this, 'choices', []);\n\t\tthis.addChoices(normalizedChoices);\n\n\t\treturn this;\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandMentionableOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command mentionable option.\n */\nexport class SlashCommandMentionableOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Mentionable as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandMentionableOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandNumberOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandNumericOptionMinMaxValueMixin } from '../mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst numberValidator = s.number();\n\n/**\n * A slash command number option.\n */\n@mix(\n\tApplicationCommandNumericOptionMinMaxValueMixin,\n\tApplicationCommandOptionWithAutocompleteMixin,\n\tApplicationCommandOptionWithChoicesMixin,\n)\nexport class SlashCommandNumberOption\n\textends ApplicationCommandOptionBase\n\timplements ApplicationCommandNumericOptionMinMaxValueMixin\n{\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Number as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue}\n\t */\n\tpublic setMaxValue(max: number): this {\n\t\tnumberValidator.parse(max);\n\n\t\tReflect.set(this, 'max_value', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue}\n\t */\n\tpublic setMinValue(min: number): this {\n\t\tnumberValidator.parse(min);\n\n\t\tReflect.set(this, 'min_value', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandNumberOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandNumberOption;\n\t}\n}\n\nexport interface SlashCommandNumberOption\n\textends ApplicationCommandNumericOptionMinMaxValueMixin,\n\t\tApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","import { ApplicationCommandOptionType, type APIApplicationCommandRoleOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command role option.\n */\nexport class SlashCommandRoleOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Role as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandRoleOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandStringOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst minLengthValidator = s.number().greaterThanOrEqual(0).lessThanOrEqual(6_000);\nconst maxLengthValidator = s.number().greaterThanOrEqual(1).lessThanOrEqual(6_000);\n\n/**\n * A slash command string option.\n */\n@mix(ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin)\nexport class SlashCommandStringOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.String as const;\n\n\t/**\n\t * The maximum length of this option.\n\t */\n\tpublic readonly max_length?: number;\n\n\t/**\n\t * The minimum length of this option.\n\t */\n\tpublic readonly min_length?: number;\n\n\t/**\n\t * Sets the maximum length of this string option.\n\t *\n\t * @param max - The maximum length this option can be\n\t */\n\tpublic setMaxLength(max: number): this {\n\t\tmaxLengthValidator.parse(max);\n\n\t\tReflect.set(this, 'max_length', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum length of this string option.\n\t *\n\t * @param min - The minimum length this option can be\n\t */\n\tpublic setMinLength(min: number): this {\n\t\tminLengthValidator.parse(min);\n\n\t\tReflect.set(this, 'min_length', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandStringOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandStringOption;\n\t}\n}\n\nexport interface SlashCommandStringOption\n\textends ApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","import { ApplicationCommandOptionType, type APIApplicationCommandUserOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command user option.\n */\nexport class SlashCommandUserOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.User as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandUserOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { assertReturnOfBuilder, validateMaxOptionsLength } from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder';\nimport { SlashCommandAttachmentOption } from '../options/attachment.js';\nimport { SlashCommandBooleanOption } from '../options/boolean.js';\nimport { SlashCommandChannelOption } from '../options/channel.js';\nimport { SlashCommandIntegerOption } from '../options/integer.js';\nimport { SlashCommandMentionableOption } from '../options/mentionable.js';\nimport { SlashCommandNumberOption } from '../options/number.js';\nimport { SlashCommandRoleOption } from '../options/role.js';\nimport { SlashCommandStringOption } from '../options/string.js';\nimport { SlashCommandUserOption } from '../options/user.js';\nimport type { ApplicationCommandOptionBase } from './ApplicationCommandOptionBase.js';\n\n/**\n * This mixin holds symbols that can be shared in slash command options.\n *\n * @typeParam TypeAfterAddingOptions - The type this class should return after adding an option.\n */\nexport class SharedSlashCommandOptions<\n\tTypeAfterAddingOptions extends SharedSlashCommandOptions,\n> {\n\tpublic readonly options!: ToAPIApplicationCommandOptions[];\n\n\t/**\n\t * Adds a boolean option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addBooleanOption(\n\t\tinput: SlashCommandBooleanOption | ((builder: SlashCommandBooleanOption) => SlashCommandBooleanOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandBooleanOption);\n\t}\n\n\t/**\n\t * Adds a user option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addUserOption(input: SlashCommandUserOption | ((builder: SlashCommandUserOption) => SlashCommandUserOption)) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandUserOption);\n\t}\n\n\t/**\n\t * Adds a channel option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addChannelOption(\n\t\tinput: SlashCommandChannelOption | ((builder: SlashCommandChannelOption) => SlashCommandChannelOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandChannelOption);\n\t}\n\n\t/**\n\t * Adds a role option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addRoleOption(input: SlashCommandRoleOption | ((builder: SlashCommandRoleOption) => SlashCommandRoleOption)) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandRoleOption);\n\t}\n\n\t/**\n\t * Adds an attachment option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addAttachmentOption(\n\t\tinput: SlashCommandAttachmentOption | ((builder: SlashCommandAttachmentOption) => SlashCommandAttachmentOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandAttachmentOption);\n\t}\n\n\t/**\n\t * Adds a mentionable option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addMentionableOption(\n\t\tinput: SlashCommandMentionableOption | ((builder: SlashCommandMentionableOption) => SlashCommandMentionableOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandMentionableOption);\n\t}\n\n\t/**\n\t * Adds a string option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addStringOption(\n\t\tinput: SlashCommandStringOption | ((builder: SlashCommandStringOption) => SlashCommandStringOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandStringOption);\n\t}\n\n\t/**\n\t * Adds an integer option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addIntegerOption(\n\t\tinput: SlashCommandIntegerOption | ((builder: SlashCommandIntegerOption) => SlashCommandIntegerOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandIntegerOption);\n\t}\n\n\t/**\n\t * Adds a number option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addNumberOption(\n\t\tinput: SlashCommandNumberOption | ((builder: SlashCommandNumberOption) => SlashCommandNumberOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandNumberOption);\n\t}\n\n\t/**\n\t * Where the actual adding magic happens. ✨\n\t *\n\t * @param input - The input. What else?\n\t * @param Instance - The instance of whatever is being added\n\t * @internal\n\t */\n\tprivate _sharedAddOptionMethod(\n\t\tinput: OptionBuilder | ((builder: OptionBuilder) => OptionBuilder),\n\t\tInstance: new () => OptionBuilder,\n\t): TypeAfterAddingOptions {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new Instance()) : input;\n\n\t\tassertReturnOfBuilder(result, Instance);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingOptions;\n\t}\n}\n","import {\n\tApplicationCommandOptionType,\n\ttype APIApplicationCommandSubcommandGroupOption,\n\ttype APIApplicationCommandSubcommandOption,\n} from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { assertReturnOfBuilder, validateMaxOptionsLength, validateRequiredParameters } from './Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from './SlashCommandBuilder.js';\nimport type { ApplicationCommandOptionBase } from './mixins/ApplicationCommandOptionBase.js';\nimport { SharedNameAndDescription } from './mixins/NameAndDescription.js';\nimport { SharedSlashCommandOptions } from './mixins/SharedSlashCommandOptions.js';\n\n/**\n * Represents a folder for subcommands.\n *\n * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups}\n */\n@mix(SharedNameAndDescription)\nexport class SlashCommandSubcommandGroupBuilder implements ToAPIApplicationCommandOptions {\n\t/**\n\t * The name of this subcommand group.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The description of this subcommand group.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The subcommands within this subcommand group.\n\t */\n\tpublic readonly options: SlashCommandSubcommandBuilder[] = [];\n\n\t/**\n\t * Adds a new subcommand to this group.\n\t *\n\t * @param input - A function that returns a subcommand builder or an already built builder\n\t */\n\tpublic addSubcommand(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder),\n\t) {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandBuilder()) : input;\n\n\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIApplicationCommandSubcommandGroupOption {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\treturn {\n\t\t\ttype: ApplicationCommandOptionType.SubcommandGroup,\n\t\t\tname: this.name,\n\t\t\tname_localizations: this.name_localizations,\n\t\t\tdescription: this.description,\n\t\t\tdescription_localizations: this.description_localizations,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n\nexport interface SlashCommandSubcommandGroupBuilder extends SharedNameAndDescription {}\n\n/**\n * A builder that creates API-compatible JSON data for slash command subcommands.\n *\n * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups}\n */\n@mix(SharedNameAndDescription, SharedSlashCommandOptions)\nexport class SlashCommandSubcommandBuilder implements ToAPIApplicationCommandOptions {\n\t/**\n\t * The name of this subcommand.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The description of this subcommand.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The options within this subcommand.\n\t */\n\tpublic readonly options: ApplicationCommandOptionBase[] = [];\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIApplicationCommandSubcommandOption {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\treturn {\n\t\t\ttype: ApplicationCommandOptionType.Subcommand,\n\t\t\tname: this.name,\n\t\t\tname_localizations: this.name_localizations,\n\t\t\tdescription: this.description,\n\t\t\tdescription_localizations: this.description_localizations,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n\nexport interface SlashCommandSubcommandBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions {}\n","import { assertReturnOfBuilder, validateMaxOptionsLength } from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder.js';\nimport { SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder } from '../SlashCommandSubcommands.js';\n\n/**\n * This mixin holds symbols that can be shared in slash subcommands.\n *\n * @typeParam TypeAfterAddingSubcommands - The type this class should return after adding a subcommand or subcommand group.\n */\nexport class SharedSlashCommandSubcommands<\n\tTypeAfterAddingSubcommands extends SharedSlashCommandSubcommands,\n> {\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\t/**\n\t * Adds a new subcommand group to this command.\n\t *\n\t * @param input - A function that returns a subcommand group builder or an already built builder\n\t */\n\tpublic addSubcommandGroup(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandGroupBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandGroupBuilder) => SlashCommandSubcommandGroupBuilder),\n\t): TypeAfterAddingSubcommands {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandGroupBuilder()) : input;\n\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandGroupBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingSubcommands;\n\t}\n\n\t/**\n\t * Adds a new subcommand to this command.\n\t *\n\t * @param input - A function that returns a subcommand builder or an already built builder\n\t */\n\tpublic addSubcommand(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder),\n\t): TypeAfterAddingSubcommands {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandBuilder()) : input;\n\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingSubcommands;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandType, ApplicationIntegrationType, InteractionContextType } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ContextMenuCommandType } from './ContextMenuCommandBuilder.js';\n\nconst namePredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(32)\n\t// eslint-disable-next-line prefer-named-capture-group\n\t.regex(/^( *[\\p{P}\\p{L}\\p{N}\\p{sc=Devanagari}\\p{sc=Thai}]+ *)+$/u)\n\t.setValidationEnabled(isValidationEnabled);\nconst typePredicate = s\n\t.union([s.literal(ApplicationCommandType.User), s.literal(ApplicationCommandType.Message)])\n\t.setValidationEnabled(isValidationEnabled);\nconst booleanPredicate = s.boolean();\n\nexport function validateDefaultPermission(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport function validateName(name: unknown): asserts name is string {\n\tnamePredicate.parse(name);\n}\n\nexport function validateType(type: unknown): asserts type is ContextMenuCommandType {\n\ttypePredicate.parse(type);\n}\n\nexport function validateRequiredParameters(name: string, type: number) {\n\t// Assert name matches all conditions\n\tvalidateName(name);\n\n\t// Assert type is valid\n\tvalidateType(type);\n}\n\nconst dmPermissionPredicate = s.boolean().nullish();\n\nexport function validateDMPermission(value: unknown): asserts value is boolean | null | undefined {\n\tdmPermissionPredicate.parse(value);\n}\n\nconst memberPermissionPredicate = s\n\t.union([\n\t\ts.bigint().transform((value) => value.toString()),\n\t\ts\n\t\t\t.number()\n\t\t\t.safeInt()\n\t\t\t.transform((value) => value.toString()),\n\t\ts.string().regex(/^\\d+$/),\n\t])\n\t.nullish();\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n\nexport const contextsPredicate = s.array(\n\ts.nativeEnum(InteractionContextType).setValidationEnabled(isValidationEnabled),\n);\n\nexport const integrationTypesPredicate = s.array(\n\ts.nativeEnum(ApplicationIntegrationType).setValidationEnabled(isValidationEnabled),\n);\n","import type {\n\tApplicationCommandType,\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocaleString,\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIContextMenuApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport type { RestOrArray } from '../../util/normalizeArray.js';\nimport { normalizeArray } from '../../util/normalizeArray.js';\nimport { validateLocale, validateLocalizationMap } from '../slashCommands/Assertions.js';\nimport {\n\tvalidateRequiredParameters,\n\tvalidateName,\n\tvalidateType,\n\tvalidateDefaultPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDMPermission,\n\tcontextsPredicate,\n\tintegrationTypesPredicate,\n} from './Assertions.js';\n\n/**\n * The type a context menu command can be.\n */\nexport type ContextMenuCommandType = ApplicationCommandType.Message | ApplicationCommandType.User;\n\n/**\n * A builder that creates API-compatible JSON data for context menu commands.\n */\nexport class ContextMenuCommandBuilder {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The type of this command.\n\t */\n\tpublic readonly type: ContextMenuCommandType = undefined!;\n\n\t/**\n\t * The contexts for this command.\n\t */\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * Whether this command is enabled by default when the application is added to a guild.\n\t *\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The set of permissions represented as a bit set for the command.\n\t */\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * Indicates whether the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This property is only for global commands.\n\t * @deprecated\n\t * Use {@link ContextMenuCommandBuilder.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The integration types for this command.\n\t */\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\t/**\n\t * Sets the contexts of this command.\n\t *\n\t * @param contexts - The contexts\n\t */\n\tpublic setContexts(...contexts: RestOrArray) {\n\t\tReflect.set(this, 'contexts', contextsPredicate.parse(normalizeArray(contexts)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets integration types of this command.\n\t *\n\t * @param integrationTypes - The integration types\n\t */\n\tpublic setIntegrationTypes(...integrationTypes: RestOrArray) {\n\t\tReflect.set(this, 'integration_types', integrationTypesPredicate.parse(normalizeArray(integrationTypes)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name of this command.\n\t *\n\t * @param name - The name to use\n\t */\n\tpublic setName(name: string) {\n\t\t// Assert the name matches the conditions\n\t\tvalidateName(name);\n\n\t\tReflect.set(this, 'name', name);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the type of this command.\n\t *\n\t * @param type - The type to use\n\t */\n\tpublic setType(type: ContextMenuCommandType) {\n\t\t// Assert the type is valid\n\t\tvalidateType(type);\n\n\t\tReflect.set(this, 'type', type);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether the command is enabled by default when the application is added to a guild.\n\t *\n\t * @remarks\n\t * If set to `false`, you will have to later `PUT` the permissions for this command.\n\t * @param value - Whether to enable this command by default\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead.\n\t */\n\tpublic setDefaultPermission(value: boolean) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDefaultPermission(value);\n\n\t\tReflect.set(this, 'default_permission', value);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the default permissions a member should have in order to run this command.\n\t *\n\t * @remarks\n\t * You can set this to `'0'` to disable the command by default.\n\t * @param permissions - The permissions bit field to set\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t */\n\tpublic setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined) {\n\t\t// Assert the value and parse it\n\t\tconst permissionValue = validateDefaultMemberPermissions(permissions);\n\n\t\tReflect.set(this, 'default_member_permissions', permissionValue);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets if the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This method is only for global commands.\n\t * @param enabled - Whether the command should be enabled in direct messages\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead.\n\t */\n\tpublic setDMPermission(enabled: boolean | null | undefined) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDMPermission(enabled);\n\n\t\tReflect.set(this, 'dm_permission', enabled);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a name localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedName - The localized name for the given `locale`\n\t */\n\tpublic setNameLocalization(locale: LocaleString, localizedName: string | null) {\n\t\tif (!this.name_localizations) {\n\t\t\tReflect.set(this, 'name_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedName === null) {\n\t\t\tthis.name_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateName(localizedName);\n\n\t\tthis.name_localizations![parsedLocale] = localizedName;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name localizations for this command.\n\t *\n\t * @param localizedNames - The object of localized names to set\n\t */\n\tpublic setNameLocalizations(localizedNames: LocalizationMap | null) {\n\t\tif (localizedNames === null) {\n\t\t\tReflect.set(this, 'name_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'name_localizations', {});\n\n\t\tfor (const args of Object.entries(localizedNames))\n\t\t\tthis.setNameLocalization(...(args as [LocaleString, string | null]));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): RESTPostAPIContextMenuApplicationCommandsJSONBody {\n\t\tvalidateRequiredParameters(this.name, this.type);\n\n\t\tvalidateLocalizationMap(this.name_localizations);\n\n\t\treturn { ...this };\n\t}\n}\n","import type { APIEmbed } from 'discord-api-types/v10';\n\n/**\n * Calculates the length of the embed.\n *\n * @param data - The embed data to check\n */\nexport function embedLength(data: APIEmbed) {\n\treturn (\n\t\t(data.title?.length ?? 0) +\n\t\t(data.description?.length ?? 0) +\n\t\t(data.fields?.reduce((prev, curr) => prev + curr.name.length + curr.value.length, 0) ?? 0) +\n\t\t(data.footer?.text.length ?? 0) +\n\t\t(data.author?.name.length ?? 0)\n\t);\n}\n"],"mappings":"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","names":["Assertions_exports","Assertions_exports","import_shapeshift","import_v10","import_v10","import_v10","import_v10","import_v10","import_v10","import_v10","import_v10","import_v10","Assertions_exports","placeholderValidator","import_shapeshift","import_v10","placeholderValidator","placeholderValidator","isEqual","Assertions_exports","validateRequiredParameters","import_shapeshift","validateRequiredParameters","validateRequiredParameters","Assertions_exports","validateRequiredParameters","import_shapeshift","import_v10","descriptionPredicate","validateRequiredParameters","import_ts_mixer","import_v10","validateRequiredParameters","import_v10","validateRequiredParameters","import_v10","import_v10","import_shapeshift","import_v10","import_shapeshift","import_v10","import_ts_mixer","import_shapeshift","booleanPredicate","import_shapeshift","import_v10","import_v10","import_shapeshift","import_v10","import_ts_mixer","numberValidator","import_v10","import_shapeshift","import_v10","import_ts_mixer","minLengthValidator","maxLengthValidator","import_v10","import_v10","import_ts_mixer","validateRequiredParameters","Assertions_exports","contextsPredicate","integrationTypesPredicate","validateDMPermission","validateDefaultMemberPermissions","validateDefaultPermission","validateName","validateRequiredParameters","import_shapeshift","import_v10","namePredicate","booleanPredicate","validateDefaultPermission","validateName","validateRequiredParameters","dmPermissionPredicate","validateDMPermission","memberPermissionPredicate","validateDefaultMemberPermissions","contextsPredicate","integrationTypesPredicate","contextsPredicate","integrationTypesPredicate","validateName","validateDefaultPermission","validateDefaultMemberPermissions","validateDMPermission","validateRequiredParameters"]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs new file mode 100644 index 0000000..1ae27c5 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs @@ -0,0 +1,2859 @@ +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __decorateClass = (decorators, target, key, kind) => { + var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target; + for (var i = decorators.length - 1, decorator; i >= 0; i--) + if (decorator = decorators[i]) + result = (kind ? decorator(target, key, result) : decorator(result)) || result; + if (kind && result) __defProp(target, key, result); + return result; +}; + +// src/messages/embed/Assertions.ts +var Assertions_exports = {}; +__export(Assertions_exports, { + RGBPredicate: () => RGBPredicate, + authorNamePredicate: () => authorNamePredicate, + colorPredicate: () => colorPredicate, + descriptionPredicate: () => descriptionPredicate, + embedAuthorPredicate: () => embedAuthorPredicate, + embedFieldPredicate: () => embedFieldPredicate, + embedFieldsArrayPredicate: () => embedFieldsArrayPredicate, + embedFooterPredicate: () => embedFooterPredicate, + fieldInlinePredicate: () => fieldInlinePredicate, + fieldLengthPredicate: () => fieldLengthPredicate, + fieldNamePredicate: () => fieldNamePredicate, + fieldValuePredicate: () => fieldValuePredicate, + footerTextPredicate: () => footerTextPredicate, + imageURLPredicate: () => imageURLPredicate, + timestampPredicate: () => timestampPredicate, + titlePredicate: () => titlePredicate, + urlPredicate: () => urlPredicate, + validateFieldLength: () => validateFieldLength +}); +import { s } from "@sapphire/shapeshift"; + +// src/util/validation.ts +var validate = true; +function enableValidators() { + return validate = true; +} +__name(enableValidators, "enableValidators"); +function disableValidators() { + return validate = false; +} +__name(disableValidators, "disableValidators"); +function isValidationEnabled() { + return validate; +} +__name(isValidationEnabled, "isValidationEnabled"); + +// src/messages/embed/Assertions.ts +var fieldNamePredicate = s.string().lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled); +var fieldValuePredicate = s.string().lengthLessThanOrEqual(1024).setValidationEnabled(isValidationEnabled); +var fieldInlinePredicate = s.boolean().optional(); +var embedFieldPredicate = s.object({ + name: fieldNamePredicate, + value: fieldValuePredicate, + inline: fieldInlinePredicate +}).setValidationEnabled(isValidationEnabled); +var embedFieldsArrayPredicate = embedFieldPredicate.array().setValidationEnabled(isValidationEnabled); +var fieldLengthPredicate = s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateFieldLength(amountAdding, fields) { + fieldLengthPredicate.parse((fields?.length ?? 0) + amountAdding); +} +__name(validateFieldLength, "validateFieldLength"); +var authorNamePredicate = fieldNamePredicate.lengthGreaterThanOrEqual(1).nullable().setValidationEnabled(isValidationEnabled); +var imageURLPredicate = s.string().url({ + allowedProtocols: ["http:", "https:", "attachment:"] +}).nullish().setValidationEnabled(isValidationEnabled); +var urlPredicate = s.string().url({ + allowedProtocols: ["http:", "https:"] +}).nullish().setValidationEnabled(isValidationEnabled); +var embedAuthorPredicate = s.object({ + name: authorNamePredicate, + iconURL: imageURLPredicate, + url: urlPredicate +}).setValidationEnabled(isValidationEnabled); +var RGBPredicate = s.number().int().greaterThanOrEqual(0).lessThanOrEqual(255).setValidationEnabled(isValidationEnabled); +var colorPredicate = s.number().int().greaterThanOrEqual(0).lessThanOrEqual(16777215).or(s.tuple([RGBPredicate, RGBPredicate, RGBPredicate])).nullable().setValidationEnabled(isValidationEnabled); +var descriptionPredicate = s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(4096).nullable().setValidationEnabled(isValidationEnabled); +var footerTextPredicate = s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(2048).nullable().setValidationEnabled(isValidationEnabled); +var embedFooterPredicate = s.object({ + text: footerTextPredicate, + iconURL: imageURLPredicate +}).setValidationEnabled(isValidationEnabled); +var timestampPredicate = s.union([s.number(), s.date()]).nullable().setValidationEnabled(isValidationEnabled); +var titlePredicate = fieldNamePredicate.lengthGreaterThanOrEqual(1).nullable().setValidationEnabled(isValidationEnabled); + +// src/util/normalizeArray.ts +function normalizeArray(arr) { + if (Array.isArray(arr[0])) return [...arr[0]]; + return arr; +} +__name(normalizeArray, "normalizeArray"); + +// src/messages/embed/Embed.ts +var EmbedBuilder = class { + static { + __name(this, "EmbedBuilder"); + } + /** + * The API data associated with this embed. + */ + data; + /** + * Creates a new embed from API data. + * + * @param data - The API data to create this embed with + */ + constructor(data = {}) { + this.data = { ...data }; + if (data.timestamp) this.data.timestamp = new Date(data.timestamp).toISOString(); + } + /** + * Appends fields to the embed. + * + * @remarks + * This method accepts either an array of fields or a variable number of field parameters. + * The maximum amount of fields that can be added is 25. + * @example + * Using an array: + * ```ts + * const fields: APIEmbedField[] = ...; + * const embed = new EmbedBuilder() + * .addFields(fields); + * ``` + * @example + * Using rest parameters (variadic): + * ```ts + * const embed = new EmbedBuilder() + * .addFields( + * { name: 'Field 1', value: 'Value 1' }, + * { name: 'Field 2', value: 'Value 2' }, + * ); + * ``` + * @param fields - The fields to add + */ + addFields(...fields) { + const normalizedFields = normalizeArray(fields); + validateFieldLength(normalizedFields.length, this.data.fields); + embedFieldsArrayPredicate.parse(normalizedFields); + if (this.data.fields) this.data.fields.push(...normalizedFields); + else this.data.fields = normalizedFields; + return this; + } + /** + * Removes, replaces, or inserts fields for this embed. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}. + * The maximum amount of fields that can be added is 25. + * + * It's useful for modifying and adjusting order of the already-existing fields of an embed. + * @example + * Remove the first field: + * ```ts + * embed.spliceFields(0, 1); + * ``` + * @example + * Remove the first n fields: + * ```ts + * const n = 4; + * embed.spliceFields(0, n); + * ``` + * @example + * Remove the last field: + * ```ts + * embed.spliceFields(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of fields to remove + * @param fields - The replacing field objects + */ + spliceFields(index, deleteCount, ...fields) { + validateFieldLength(fields.length - deleteCount, this.data.fields); + embedFieldsArrayPredicate.parse(fields); + if (this.data.fields) this.data.fields.splice(index, deleteCount, ...fields); + else this.data.fields = fields; + return this; + } + /** + * Sets the fields for this embed. + * + * @remarks + * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically, + * it splices the entire array of fields, replacing them with the provided fields. + * + * You can set a maximum of 25 fields. + * @param fields - The fields to set + */ + setFields(...fields) { + this.spliceFields(0, this.data.fields?.length ?? 0, ...normalizeArray(fields)); + return this; + } + /** + * Sets the author of this embed. + * + * @param options - The options to use + */ + setAuthor(options) { + if (options === null) { + this.data.author = void 0; + return this; + } + embedAuthorPredicate.parse(options); + this.data.author = { name: options.name, url: options.url, icon_url: options.iconURL }; + return this; + } + /** + * Sets the color of this embed. + * + * @param color - The color to use + */ + setColor(color) { + colorPredicate.parse(color); + if (Array.isArray(color)) { + const [red, green, blue] = color; + this.data.color = (red << 16) + (green << 8) + blue; + return this; + } + this.data.color = color ?? void 0; + return this; + } + /** + * Sets the description of this embed. + * + * @param description - The description to use + */ + setDescription(description) { + descriptionPredicate.parse(description); + this.data.description = description ?? void 0; + return this; + } + /** + * Sets the footer of this embed. + * + * @param options - The footer to use + */ + setFooter(options) { + if (options === null) { + this.data.footer = void 0; + return this; + } + embedFooterPredicate.parse(options); + this.data.footer = { text: options.text, icon_url: options.iconURL }; + return this; + } + /** + * Sets the image of this embed. + * + * @param url - The image URL to use + */ + setImage(url) { + imageURLPredicate.parse(url); + this.data.image = url ? { url } : void 0; + return this; + } + /** + * Sets the thumbnail of this embed. + * + * @param url - The thumbnail URL to use + */ + setThumbnail(url) { + imageURLPredicate.parse(url); + this.data.thumbnail = url ? { url } : void 0; + return this; + } + /** + * Sets the timestamp of this embed. + * + * @param timestamp - The timestamp or date to use + */ + setTimestamp(timestamp = Date.now()) { + timestampPredicate.parse(timestamp); + this.data.timestamp = timestamp ? new Date(timestamp).toISOString() : void 0; + return this; + } + /** + * Sets the title for this embed. + * + * @param title - The title to use + */ + setTitle(title) { + titlePredicate.parse(title); + this.data.title = title ?? void 0; + return this; + } + /** + * Sets the URL of this embed. + * + * @param url - The URL to use + */ + setURL(url) { + urlPredicate.parse(url); + this.data.url = url ?? void 0; + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + return { ...this.data }; + } +}; + +// src/index.ts +export * from "@discordjs/formatters"; + +// src/components/Assertions.ts +var Assertions_exports2 = {}; +__export(Assertions_exports2, { + buttonLabelValidator: () => buttonLabelValidator, + buttonStyleValidator: () => buttonStyleValidator, + channelTypesValidator: () => channelTypesValidator, + customIdValidator: () => customIdValidator, + defaultValidator: () => defaultValidator, + disabledValidator: () => disabledValidator, + emojiValidator: () => emojiValidator, + jsonOptionValidator: () => jsonOptionValidator, + labelValueDescriptionValidator: () => labelValueDescriptionValidator, + minMaxValidator: () => minMaxValidator, + optionValidator: () => optionValidator, + optionsLengthValidator: () => optionsLengthValidator, + optionsValidator: () => optionsValidator, + placeholderValidator: () => placeholderValidator, + urlValidator: () => urlValidator, + validateRequiredButtonParameters: () => validateRequiredButtonParameters, + validateRequiredSelectMenuOptionParameters: () => validateRequiredSelectMenuOptionParameters, + validateRequiredSelectMenuParameters: () => validateRequiredSelectMenuParameters +}); +import { s as s2 } from "@sapphire/shapeshift"; +import { ButtonStyle, ChannelType } from "discord-api-types/v10"; + +// src/components/selectMenu/StringSelectMenuOption.ts +var StringSelectMenuOptionBuilder = class { + /** + * Creates a new string select menu option from API data. + * + * @param data - The API data to create this string select menu option with + * @example + * Creating a string select menu option from an API data object: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * label: 'catchy label', + * value: '1', + * }); + * ``` + * @example + * Creating a string select menu option using setters and API data: + * ```ts + * const selectMenuOption = new SelectMenuOptionBuilder({ + * default: true, + * value: '1', + * }) + * .setLabel('woah'); + * ``` + */ + constructor(data = {}) { + this.data = data; + } + static { + __name(this, "StringSelectMenuOptionBuilder"); + } + /** + * Sets the label for this option. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = labelValueDescriptionValidator.parse(label); + return this; + } + /** + * Sets the value for this option. + * + * @param value - The value to use + */ + setValue(value) { + this.data.value = labelValueDescriptionValidator.parse(value); + return this; + } + /** + * Sets the description for this option. + * + * @param description - The description to use + */ + setDescription(description) { + this.data.description = labelValueDescriptionValidator.parse(description); + return this; + } + /** + * Sets whether this option is selected by default. + * + * @param isDefault - Whether this option is selected by default + */ + setDefault(isDefault = true) { + this.data.default = defaultValidator.parse(isDefault); + return this; + } + /** + * Sets the emoji to display for this option. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji) { + this.data.emoji = emojiValidator.parse(emoji); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + validateRequiredSelectMenuOptionParameters(this.data.label, this.data.value); + return { + ...this.data + }; + } +}; + +// src/components/Assertions.ts +var customIdValidator = s2.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var emojiValidator = s2.object({ + id: s2.string(), + name: s2.string(), + animated: s2.boolean() +}).partial().strict().setValidationEnabled(isValidationEnabled); +var disabledValidator = s2.boolean(); +var buttonLabelValidator = s2.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(80).setValidationEnabled(isValidationEnabled); +var buttonStyleValidator = s2.nativeEnum(ButtonStyle); +var placeholderValidator = s2.string().lengthLessThanOrEqual(150).setValidationEnabled(isValidationEnabled); +var minMaxValidator = s2.number().int().greaterThanOrEqual(0).lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +var labelValueDescriptionValidator = s2.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var jsonOptionValidator = s2.object({ + label: labelValueDescriptionValidator, + value: labelValueDescriptionValidator, + description: labelValueDescriptionValidator.optional(), + emoji: emojiValidator.optional(), + default: s2.boolean().optional() +}).setValidationEnabled(isValidationEnabled); +var optionValidator = s2.instance(StringSelectMenuOptionBuilder).setValidationEnabled(isValidationEnabled); +var optionsValidator = optionValidator.array().lengthGreaterThanOrEqual(0).setValidationEnabled(isValidationEnabled); +var optionsLengthValidator = s2.number().int().greaterThanOrEqual(0).lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateRequiredSelectMenuParameters(options, customId) { + customIdValidator.parse(customId); + optionsValidator.parse(options); +} +__name(validateRequiredSelectMenuParameters, "validateRequiredSelectMenuParameters"); +var defaultValidator = s2.boolean(); +function validateRequiredSelectMenuOptionParameters(label, value) { + labelValueDescriptionValidator.parse(label); + labelValueDescriptionValidator.parse(value); +} +__name(validateRequiredSelectMenuOptionParameters, "validateRequiredSelectMenuOptionParameters"); +var channelTypesValidator = s2.nativeEnum(ChannelType).array().setValidationEnabled(isValidationEnabled); +var urlValidator = s2.string().url({ + allowedProtocols: ["http:", "https:", "discord:"] +}).setValidationEnabled(isValidationEnabled); +function validateRequiredButtonParameters(style, label, emoji, customId, skuId, url) { + if (style === ButtonStyle.Premium) { + if (!skuId) { + throw new RangeError("Premium buttons must have an SKU id."); + } + if (customId || label || url || emoji) { + throw new RangeError("Premium buttons cannot have a custom id, label, URL, or emoji."); + } + } else { + if (skuId) { + throw new RangeError("Non-premium buttons must not have an SKU id."); + } + if (url && customId) { + throw new RangeError("URL and custom id are mutually exclusive."); + } + if (!label && !emoji) { + throw new RangeError("Non-premium buttons must have a label and/or an emoji."); + } + if (style === ButtonStyle.Link) { + if (!url) { + throw new RangeError("Link buttons must have a URL."); + } + } else if (url) { + throw new RangeError("Non-premium and non-link buttons cannot have a URL."); + } + } +} +__name(validateRequiredButtonParameters, "validateRequiredButtonParameters"); + +// src/components/ActionRow.ts +import { + ComponentType as ComponentType9 +} from "discord-api-types/v10"; + +// src/components/Component.ts +var ComponentBuilder = class { + static { + __name(this, "ComponentBuilder"); + } + /** + * The API data associated with this component. + */ + data; + /** + * Constructs a new kind of component. + * + * @param data - The data to construct a component out of + */ + constructor(data) { + this.data = data; + } +}; + +// src/components/Components.ts +import { ComponentType as ComponentType8 } from "discord-api-types/v10"; + +// src/components/button/Button.ts +import { + ComponentType +} from "discord-api-types/v10"; +var ButtonBuilder = class extends ComponentBuilder { + static { + __name(this, "ButtonBuilder"); + } + /** + * Creates a new button from API data. + * + * @param data - The API data to create this button with + * @example + * Creating a button from an API data object: + * ```ts + * const button = new ButtonBuilder({ + * custom_id: 'a cool button', + * style: ButtonStyle.Primary, + * label: 'Click Me', + * emoji: { + * name: 'smile', + * id: '123456789012345678', + * }, + * }); + * ``` + * @example + * Creating a button using setters and API data: + * ```ts + * const button = new ButtonBuilder({ + * style: ButtonStyle.Secondary, + * label: 'Click Me', + * }) + * .setEmoji({ name: '🙂' }) + * .setCustomId('another cool button'); + * ``` + */ + constructor(data) { + super({ type: ComponentType.Button, ...data }); + } + /** + * Sets the style of this button. + * + * @param style - The style to use + */ + setStyle(style) { + this.data.style = buttonStyleValidator.parse(style); + return this; + } + /** + * Sets the URL for this button. + * + * @remarks + * This method is only available to buttons using the `Link` button style. + * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`. + * @param url - The URL to use + */ + setURL(url) { + this.data.url = urlValidator.parse(url); + return this; + } + /** + * Sets the custom id for this button. + * + * @remarks + * This method is only applicable to buttons that are not using the `Link` button style. + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets the SKU id that represents a purchasable SKU for this button. + * + * @remarks Only available when using premium-style buttons. + * @param skuId - The SKU id to use + */ + setSKUId(skuId) { + this.data.sku_id = skuId; + return this; + } + /** + * Sets the emoji to display on this button. + * + * @param emoji - The emoji to use + */ + setEmoji(emoji) { + this.data.emoji = emojiValidator.parse(emoji); + return this; + } + /** + * Sets whether this button is disabled. + * + * @param disabled - Whether to disable this button + */ + setDisabled(disabled = true) { + this.data.disabled = disabledValidator.parse(disabled); + return this; + } + /** + * Sets the label for this button. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = buttonLabelValidator.parse(label); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredButtonParameters( + this.data.style, + this.data.label, + this.data.emoji, + this.data.custom_id, + this.data.sku_id, + this.data.url + ); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/ChannelSelectMenu.ts +import { + ComponentType as ComponentType2, + SelectMenuDefaultValueType +} from "discord-api-types/v10"; + +// src/components/selectMenu/BaseSelectMenu.ts +var BaseSelectMenuBuilder = class extends ComponentBuilder { + static { + __name(this, "BaseSelectMenuBuilder"); + } + /** + * Sets the placeholder for this select menu. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder) { + this.data.placeholder = placeholderValidator.parse(placeholder); + return this; + } + /** + * Sets the minimum values that must be selected in the select menu. + * + * @param minValues - The minimum values that must be selected + */ + setMinValues(minValues) { + this.data.min_values = minMaxValidator.parse(minValues); + return this; + } + /** + * Sets the maximum values that must be selected in the select menu. + * + * @param maxValues - The maximum values that must be selected + */ + setMaxValues(maxValues) { + this.data.max_values = minMaxValidator.parse(maxValues); + return this; + } + /** + * Sets the custom id for this select menu. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets whether this select menu is disabled. + * + * @param disabled - Whether this select menu is disabled + */ + setDisabled(disabled = true) { + this.data.disabled = disabledValidator.parse(disabled); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + customIdValidator.parse(this.data.custom_id); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/ChannelSelectMenu.ts +var ChannelSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "ChannelSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new ChannelSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement) + * .setMinValues(2); + * ``` + */ + constructor(data) { + super({ ...data, type: ComponentType2.ChannelSelect }); + } + /** + * Adds channel types to this select menu. + * + * @param types - The channel types to use + */ + addChannelTypes(...types) { + const normalizedTypes = normalizeArray(types); + this.data.channel_types ??= []; + this.data.channel_types.push(...channelTypesValidator.parse(normalizedTypes)); + return this; + } + /** + * Sets channel types for this select menu. + * + * @param types - The channel types to use + */ + setChannelTypes(...types) { + const normalizedTypes = normalizeArray(types); + this.data.channel_types ??= []; + this.data.channel_types.splice(0, this.data.channel_types.length, ...channelTypesValidator.parse(normalizedTypes)); + return this; + } + /** + * Adds default channels to this auto populated select menu. + * + * @param channels - The channels to add + */ + addDefaultChannels(...channels) { + const normalizedValues = normalizeArray(channels); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType.Channel + })) + ); + return this; + } + /** + * Sets default channels for this auto populated select menu. + * + * @param channels - The channels to set + */ + setDefaultChannels(...channels) { + const normalizedValues = normalizeArray(channels); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType.Channel + })); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + customIdValidator.parse(this.data.custom_id); + return { + ...this.data + }; + } +}; + +// src/components/selectMenu/MentionableSelectMenu.ts +import { + ComponentType as ComponentType3, + SelectMenuDefaultValueType as SelectMenuDefaultValueType2 +} from "discord-api-types/v10"; +var MentionableSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "MentionableSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new MentionableSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: ComponentType3.MentionableSelect }); + } + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType2.Role + })) + ); + return this; + } + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType2.User + })) + ); + return this; + } + /** + * Adds default values to this auto populated select menu. + * + * @param values - The values to add + */ + addDefaultValues(...values) { + const normalizedValues = normalizeArray(values); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push(...normalizedValues); + return this; + } + /** + * Sets default values for this auto populated select menu. + * + * @param values - The values to set + */ + setDefaultValues(...values) { + const normalizedValues = normalizeArray(values); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues; + return this; + } +}; + +// src/components/selectMenu/RoleSelectMenu.ts +import { + ComponentType as ComponentType4, + SelectMenuDefaultValueType as SelectMenuDefaultValueType3 +} from "discord-api-types/v10"; +var RoleSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "RoleSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new RoleSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: ComponentType4.RoleSelect }); + } + /** + * Adds default roles to this auto populated select menu. + * + * @param roles - The roles to add + */ + addDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType3.Role + })) + ); + return this; + } + /** + * Sets default roles for this auto populated select menu. + * + * @param roles - The roles to set + */ + setDefaultRoles(...roles) { + const normalizedValues = normalizeArray(roles); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType3.Role + })); + return this; + } +}; + +// src/components/selectMenu/StringSelectMenu.ts +import { ComponentType as ComponentType5 } from "discord-api-types/v10"; +var StringSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "StringSelectMenuBuilder"); + } + /** + * The options within this select menu. + */ + options; + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * options: [ + * { label: 'option 1', value: '1' }, + * { label: 'option 2', value: '2' }, + * { label: 'option 3', value: '3' }, + * ], + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new StringSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1) + * .addOptions({ + * label: 'Catchy', + * value: 'catch', + * }); + * ``` + */ + constructor(data) { + const { options, ...initData } = data ?? {}; + super({ ...initData, type: ComponentType5.StringSelect }); + this.options = options?.map((option) => new StringSelectMenuOptionBuilder(option)) ?? []; + } + /** + * Adds options to this select menu. + * + * @param options - The options to add + */ + addOptions(...options) { + const normalizedOptions = normalizeArray(options); + optionsLengthValidator.parse(this.options.length + normalizedOptions.length); + this.options.push( + ...normalizedOptions.map( + (normalizedOption) => normalizedOption instanceof StringSelectMenuOptionBuilder ? normalizedOption : new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)) + ) + ); + return this; + } + /** + * Sets the options for this select menu. + * + * @param options - The options to set + */ + setOptions(...options) { + return this.spliceOptions(0, this.options.length, ...options); + } + /** + * Removes, replaces, or inserts options for this select menu. + * + * @remarks + * This method behaves similarly + * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}. + * It's useful for modifying and adjusting the order of existing options. + * @example + * Remove the first option: + * ```ts + * selectMenu.spliceOptions(0, 1); + * ``` + * @example + * Remove the first n option: + * ```ts + * const n = 4; + * selectMenu.spliceOptions(0, n); + * ``` + * @example + * Remove the last option: + * ```ts + * selectMenu.spliceOptions(-1, 1); + * ``` + * @param index - The index to start at + * @param deleteCount - The number of options to remove + * @param options - The replacing option objects or builders + */ + spliceOptions(index, deleteCount, ...options) { + const normalizedOptions = normalizeArray(options); + const clone = [...this.options]; + clone.splice( + index, + deleteCount, + ...normalizedOptions.map( + (normalizedOption) => normalizedOption instanceof StringSelectMenuOptionBuilder ? normalizedOption : new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)) + ) + ); + optionsLengthValidator.parse(clone.length); + this.options.splice(0, this.options.length, ...clone); + return this; + } + /** + * {@inheritDoc BaseSelectMenuBuilder.toJSON} + */ + toJSON() { + validateRequiredSelectMenuParameters(this.options, this.data.custom_id); + return { + ...this.data, + options: this.options.map((option) => option.toJSON()) + }; + } +}; + +// src/components/selectMenu/UserSelectMenu.ts +import { + ComponentType as ComponentType6, + SelectMenuDefaultValueType as SelectMenuDefaultValueType4 +} from "discord-api-types/v10"; +var UserSelectMenuBuilder = class extends BaseSelectMenuBuilder { + static { + __name(this, "UserSelectMenuBuilder"); + } + /** + * Creates a new select menu from API data. + * + * @param data - The API data to create this select menu with + * @example + * Creating a select menu from an API data object: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * placeholder: 'select an option', + * max_values: 2, + * }); + * ``` + * @example + * Creating a select menu using setters and API data: + * ```ts + * const selectMenu = new UserSelectMenuBuilder({ + * custom_id: 'a cool select menu', + * }) + * .setMinValues(1); + * ``` + */ + constructor(data) { + super({ ...data, type: ComponentType6.UserSelect }); + } + /** + * Adds default users to this auto populated select menu. + * + * @param users - The users to add + */ + addDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length); + this.data.default_values ??= []; + this.data.default_values.push( + ...normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType4.User + })) + ); + return this; + } + /** + * Sets default users for this auto populated select menu. + * + * @param users - The users to set + */ + setDefaultUsers(...users) { + const normalizedValues = normalizeArray(users); + optionsLengthValidator.parse(normalizedValues.length); + this.data.default_values = normalizedValues.map((id) => ({ + id, + type: SelectMenuDefaultValueType4.User + })); + return this; + } +}; + +// src/components/textInput/TextInput.ts +import { isJSONEncodable } from "@discordjs/util"; +import { ComponentType as ComponentType7 } from "discord-api-types/v10"; +import isEqual from "fast-deep-equal"; + +// src/components/textInput/Assertions.ts +var Assertions_exports3 = {}; +__export(Assertions_exports3, { + labelValidator: () => labelValidator, + maxLengthValidator: () => maxLengthValidator, + minLengthValidator: () => minLengthValidator, + placeholderValidator: () => placeholderValidator2, + requiredValidator: () => requiredValidator, + textInputStyleValidator: () => textInputStyleValidator, + validateRequiredParameters: () => validateRequiredParameters, + valueValidator: () => valueValidator +}); +import { s as s3 } from "@sapphire/shapeshift"; +import { TextInputStyle } from "discord-api-types/v10"; +var textInputStyleValidator = s3.nativeEnum(TextInputStyle); +var minLengthValidator = s3.number().int().greaterThanOrEqual(0).lessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var maxLengthValidator = s3.number().int().greaterThanOrEqual(1).lessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var requiredValidator = s3.boolean(); +var valueValidator = s3.string().lengthLessThanOrEqual(4e3).setValidationEnabled(isValidationEnabled); +var placeholderValidator2 = s3.string().lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var labelValidator = s3.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(45).setValidationEnabled(isValidationEnabled); +function validateRequiredParameters(customId, style, label) { + customIdValidator.parse(customId); + textInputStyleValidator.parse(style); + labelValidator.parse(label); +} +__name(validateRequiredParameters, "validateRequiredParameters"); + +// src/components/textInput/TextInput.ts +var TextInputBuilder = class extends ComponentBuilder { + static { + __name(this, "TextInputBuilder"); + } + /** + * Creates a new text input from API data. + * + * @param data - The API data to create this text input with + * @example + * Creating a text input from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool text input', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a text input using setters and API data: + * ```ts + * const textInput = new TextInputBuilder({ + * label: 'Type something else', + * }) + * .setCustomId('woah') + * .setStyle(TextInputStyle.Paragraph); + * ``` + */ + constructor(data) { + super({ type: ComponentType7.TextInput, ...data }); + } + /** + * Sets the custom id for this text input. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Sets the label for this text input. + * + * @param label - The label to use + */ + setLabel(label) { + this.data.label = labelValidator.parse(label); + return this; + } + /** + * Sets the style for this text input. + * + * @param style - The style to use + */ + setStyle(style) { + this.data.style = textInputStyleValidator.parse(style); + return this; + } + /** + * Sets the minimum length of text for this text input. + * + * @param minLength - The minimum length of text for this text input + */ + setMinLength(minLength) { + this.data.min_length = minLengthValidator.parse(minLength); + return this; + } + /** + * Sets the maximum length of text for this text input. + * + * @param maxLength - The maximum length of text for this text input + */ + setMaxLength(maxLength) { + this.data.max_length = maxLengthValidator.parse(maxLength); + return this; + } + /** + * Sets the placeholder for this text input. + * + * @param placeholder - The placeholder to use + */ + setPlaceholder(placeholder) { + this.data.placeholder = placeholderValidator2.parse(placeholder); + return this; + } + /** + * Sets the value for this text input. + * + * @param value - The value to use + */ + setValue(value) { + this.data.value = valueValidator.parse(value); + return this; + } + /** + * Sets whether this text input is required. + * + * @param required - Whether this text input is required + */ + setRequired(required = true) { + this.data.required = requiredValidator.parse(required); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredParameters(this.data.custom_id, this.data.style, this.data.label); + return { + ...this.data + }; + } + /** + * Whether this is equal to another structure. + */ + equals(other) { + if (isJSONEncodable(other)) { + return isEqual(other.toJSON(), this.data); + } + return isEqual(other, this.data); + } +}; + +// src/components/Components.ts +function createComponentBuilder(data) { + if (data instanceof ComponentBuilder) { + return data; + } + switch (data.type) { + case ComponentType8.ActionRow: + return new ActionRowBuilder(data); + case ComponentType8.Button: + return new ButtonBuilder(data); + case ComponentType8.StringSelect: + return new StringSelectMenuBuilder(data); + case ComponentType8.TextInput: + return new TextInputBuilder(data); + case ComponentType8.UserSelect: + return new UserSelectMenuBuilder(data); + case ComponentType8.RoleSelect: + return new RoleSelectMenuBuilder(data); + case ComponentType8.MentionableSelect: + return new MentionableSelectMenuBuilder(data); + case ComponentType8.ChannelSelect: + return new ChannelSelectMenuBuilder(data); + default: + throw new Error(`Cannot properly serialize component type: ${data.type}`); + } +} +__name(createComponentBuilder, "createComponentBuilder"); + +// src/components/ActionRow.ts +var ActionRowBuilder = class extends ComponentBuilder { + static { + __name(this, "ActionRowBuilder"); + } + /** + * The components within this action row. + */ + components; + /** + * Creates a new action row from API data. + * + * @param data - The API data to create this action row with + * @example + * Creating an action row from an API data object: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Type something", + * style: TextInputStyle.Short, + * type: ComponentType.TextInput, + * }, + * ], + * }); + * ``` + * @example + * Creating an action row using setters and API data: + * ```ts + * const actionRow = new ActionRowBuilder({ + * components: [ + * { + * custom_id: "custom id", + * label: "Click me", + * style: ButtonStyle.Primary, + * type: ComponentType.Button, + * }, + * ], + * }) + * .addComponents(button2, button3); + * ``` + */ + constructor({ components, ...data } = {}) { + super({ type: ComponentType9.ActionRow, ...data }); + this.components = components?.map((component) => createComponentBuilder(component)) ?? []; + } + /** + * Adds components to this action row. + * + * @param components - The components to add + */ + addComponents(...components) { + this.components.push(...normalizeArray(components)); + return this; + } + /** + * Sets components for this action row. + * + * @param components - The components to set + */ + setComponents(...components) { + this.components.splice(0, this.components.length, ...normalizeArray(components)); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + return { + ...this.data, + components: this.components.map((component) => component.toJSON()) + }; + } +}; + +// src/interactions/modals/Assertions.ts +var Assertions_exports4 = {}; +__export(Assertions_exports4, { + componentsValidator: () => componentsValidator, + titleValidator: () => titleValidator, + validateRequiredParameters: () => validateRequiredParameters2 +}); +import { s as s4 } from "@sapphire/shapeshift"; +var titleValidator = s4.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(45).setValidationEnabled(isValidationEnabled); +var componentsValidator = s4.instance(ActionRowBuilder).array().lengthGreaterThanOrEqual(1).setValidationEnabled(isValidationEnabled); +function validateRequiredParameters2(customId, title, components) { + customIdValidator.parse(customId); + titleValidator.parse(title); + componentsValidator.parse(components); +} +__name(validateRequiredParameters2, "validateRequiredParameters"); + +// src/interactions/modals/Modal.ts +var ModalBuilder = class { + static { + __name(this, "ModalBuilder"); + } + /** + * The API data associated with this modal. + */ + data; + /** + * The components within this modal. + */ + components = []; + /** + * Creates a new modal from API data. + * + * @param data - The API data to create this modal with + */ + constructor({ components, ...data } = {}) { + this.data = { ...data }; + this.components = components?.map((component) => createComponentBuilder(component)) ?? []; + } + /** + * Sets the title of this modal. + * + * @param title - The title to use + */ + setTitle(title) { + this.data.title = titleValidator.parse(title); + return this; + } + /** + * Sets the custom id of this modal. + * + * @param customId - The custom id to use + */ + setCustomId(customId) { + this.data.custom_id = customIdValidator.parse(customId); + return this; + } + /** + * Adds components to this modal. + * + * @param components - The components to add + */ + addComponents(...components) { + this.components.push( + ...normalizeArray(components).map( + (component) => component instanceof ActionRowBuilder ? component : new ActionRowBuilder(component) + ) + ); + return this; + } + /** + * Sets components for this modal. + * + * @param components - The components to set + */ + setComponents(...components) { + this.components.splice(0, this.components.length, ...normalizeArray(components)); + return this; + } + /** + * {@inheritDoc ComponentBuilder.toJSON} + */ + toJSON() { + validateRequiredParameters2(this.data.custom_id, this.data.title, this.components); + return { + ...this.data, + components: this.components.map((component) => component.toJSON()) + }; + } +}; + +// src/interactions/slashCommands/Assertions.ts +var Assertions_exports5 = {}; +__export(Assertions_exports5, { + assertReturnOfBuilder: () => assertReturnOfBuilder, + contextsPredicate: () => contextsPredicate, + integrationTypesPredicate: () => integrationTypesPredicate, + localizationMapPredicate: () => localizationMapPredicate, + validateChoicesLength: () => validateChoicesLength, + validateDMPermission: () => validateDMPermission, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions, + validateDefaultPermission: () => validateDefaultPermission, + validateDescription: () => validateDescription, + validateLocale: () => validateLocale, + validateLocalizationMap: () => validateLocalizationMap, + validateMaxOptionsLength: () => validateMaxOptionsLength, + validateNSFW: () => validateNSFW, + validateName: () => validateName, + validateRequired: () => validateRequired, + validateRequiredParameters: () => validateRequiredParameters3 +}); +import { s as s5 } from "@sapphire/shapeshift"; +import { + ApplicationIntegrationType, + InteractionContextType, + Locale +} from "discord-api-types/v10"; +var namePredicate = s5.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(32).regex(/^[\p{Ll}\p{Lm}\p{Lo}\p{N}\p{sc=Devanagari}\p{sc=Thai}_-]+$/u).setValidationEnabled(isValidationEnabled); +function validateName(name) { + namePredicate.parse(name); +} +__name(validateName, "validateName"); +var descriptionPredicate2 = s5.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled); +var localePredicate = s5.nativeEnum(Locale); +function validateDescription(description) { + descriptionPredicate2.parse(description); +} +__name(validateDescription, "validateDescription"); +var maxArrayLengthPredicate = s5.unknown().array().lengthLessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateLocale(locale) { + return localePredicate.parse(locale); +} +__name(validateLocale, "validateLocale"); +function validateMaxOptionsLength(options) { + maxArrayLengthPredicate.parse(options); +} +__name(validateMaxOptionsLength, "validateMaxOptionsLength"); +function validateRequiredParameters3(name, description, options) { + validateName(name); + validateDescription(description); + validateMaxOptionsLength(options); +} +__name(validateRequiredParameters3, "validateRequiredParameters"); +var booleanPredicate = s5.boolean(); +function validateDefaultPermission(value) { + booleanPredicate.parse(value); +} +__name(validateDefaultPermission, "validateDefaultPermission"); +function validateRequired(required) { + booleanPredicate.parse(required); +} +__name(validateRequired, "validateRequired"); +var choicesLengthPredicate = s5.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled); +function validateChoicesLength(amountAdding, choices) { + choicesLengthPredicate.parse((choices?.length ?? 0) + amountAdding); +} +__name(validateChoicesLength, "validateChoicesLength"); +function assertReturnOfBuilder(input, ExpectedInstanceOf) { + s5.instance(ExpectedInstanceOf).parse(input); +} +__name(assertReturnOfBuilder, "assertReturnOfBuilder"); +var localizationMapPredicate = s5.object(Object.fromEntries(Object.values(Locale).map((locale) => [locale, s5.string().nullish()]))).strict().nullish().setValidationEnabled(isValidationEnabled); +function validateLocalizationMap(value) { + localizationMapPredicate.parse(value); +} +__name(validateLocalizationMap, "validateLocalizationMap"); +var dmPermissionPredicate = s5.boolean().nullish(); +function validateDMPermission(value) { + dmPermissionPredicate.parse(value); +} +__name(validateDMPermission, "validateDMPermission"); +var memberPermissionPredicate = s5.union([ + s5.bigint().transform((value) => value.toString()), + s5.number().safeInt().transform((value) => value.toString()), + s5.string().regex(/^\d+$/) +]).nullish(); +function validateDefaultMemberPermissions(permissions) { + return memberPermissionPredicate.parse(permissions); +} +__name(validateDefaultMemberPermissions, "validateDefaultMemberPermissions"); +function validateNSFW(value) { + booleanPredicate.parse(value); +} +__name(validateNSFW, "validateNSFW"); +var contextsPredicate = s5.array( + s5.nativeEnum(InteractionContextType).setValidationEnabled(isValidationEnabled) +); +var integrationTypesPredicate = s5.array( + s5.nativeEnum(ApplicationIntegrationType).setValidationEnabled(isValidationEnabled) +); + +// src/interactions/slashCommands/SlashCommandBuilder.ts +import { mix as mix6 } from "ts-mixer"; + +// src/interactions/slashCommands/mixins/NameAndDescription.ts +var SharedNameAndDescription = class { + static { + __name(this, "SharedNameAndDescription"); + } + /** + * The name of this command. + */ + name; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The description of this command. + */ + description; + /** + * The description localizations of this command. + */ + description_localizations; + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name) { + validateName(name); + Reflect.set(this, "name", name); + return this; + } + /** + * Sets the description of this command. + * + * @param description - The description to use + */ + setDescription(description) { + validateDescription(description); + Reflect.set(this, "description", description); + return this; + } + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale, localizedName) { + if (!this.name_localizations) { + Reflect.set(this, "name_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedName === null) { + this.name_localizations[parsedLocale] = null; + return this; + } + validateName(localizedName); + this.name_localizations[parsedLocale] = localizedName; + return this; + } + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames) { + if (localizedNames === null) { + Reflect.set(this, "name_localizations", null); + return this; + } + Reflect.set(this, "name_localizations", {}); + for (const args of Object.entries(localizedNames)) { + this.setNameLocalization(...args); + } + return this; + } + /** + * Sets a description localization for this command. + * + * @param locale - The locale to set + * @param localizedDescription - The localized description for the given locale + */ + setDescriptionLocalization(locale, localizedDescription) { + if (!this.description_localizations) { + Reflect.set(this, "description_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedDescription === null) { + this.description_localizations[parsedLocale] = null; + return this; + } + validateDescription(localizedDescription); + this.description_localizations[parsedLocale] = localizedDescription; + return this; + } + /** + * Sets the description localizations for this command. + * + * @param localizedDescriptions - The object of localized descriptions to set + */ + setDescriptionLocalizations(localizedDescriptions) { + if (localizedDescriptions === null) { + Reflect.set(this, "description_localizations", null); + return this; + } + Reflect.set(this, "description_localizations", {}); + for (const args of Object.entries(localizedDescriptions)) { + this.setDescriptionLocalization(...args); + } + return this; + } +}; + +// src/interactions/slashCommands/mixins/SharedSlashCommand.ts +import { + ApplicationCommandType +} from "discord-api-types/v10"; +var SharedSlashCommand = class { + static { + __name(this, "SharedSlashCommand"); + } + name = void 0; + name_localizations; + description = void 0; + description_localizations; + options = []; + contexts; + /** + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + default_permission = void 0; + default_member_permissions = void 0; + /** + * @deprecated Use {@link SharedSlashCommand.contexts} instead. + */ + dm_permission = void 0; + integration_types; + nsfw = void 0; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts) { + Reflect.set(this, "contexts", contextsPredicate.parse(normalizeArray(contexts))); + return this; + } + /** + * Sets the integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes) { + Reflect.set(this, "integration_types", integrationTypesPredicate.parse(normalizeArray(integrationTypes))); + return this; + } + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether or not to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + setDefaultPermission(value) { + validateDefaultPermission(value); + Reflect.set(this, "default_permission", value); + return this; + } + /** + * Sets the default permissions a member should have in order to run the command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions) { + const permissionValue = validateDefaultMemberPermissions(permissions); + Reflect.set(this, "default_member_permissions", permissionValue); + return this; + } + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated + * Use {@link SharedSlashCommand.setContexts} instead. + */ + setDMPermission(enabled) { + validateDMPermission(enabled); + Reflect.set(this, "dm_permission", enabled); + return this; + } + /** + * Sets whether this command is NSFW. + * + * @param nsfw - Whether this command is NSFW + */ + setNSFW(nsfw = true) { + validateNSFW(nsfw); + Reflect.set(this, "nsfw", nsfw); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + validateLocalizationMap(this.name_localizations); + validateLocalizationMap(this.description_localizations); + return { + ...this, + type: ApplicationCommandType.ChatInput, + options: this.options.map((option) => option.toJSON()) + }; + } +}; + +// src/interactions/slashCommands/options/attachment.ts +import { ApplicationCommandOptionType } from "discord-api-types/v10"; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionBase.ts +var ApplicationCommandOptionBase = class extends SharedNameAndDescription { + static { + __name(this, "ApplicationCommandOptionBase"); + } + /** + * Whether this option is required. + * + * @defaultValue `false` + */ + required = false; + /** + * Sets whether this option is required. + * + * @param required - Whether this option should be required + */ + setRequired(required) { + validateRequired(required); + Reflect.set(this, "required", required); + return this; + } + /** + * This method runs required validators on this builder. + */ + runRequiredValidations() { + validateRequiredParameters3(this.name, this.description, []); + validateLocalizationMap(this.name_localizations); + validateLocalizationMap(this.description_localizations); + validateRequired(this.required); + } +}; + +// src/interactions/slashCommands/options/attachment.ts +var SlashCommandAttachmentOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandAttachmentOption"); + } + /** + * The type of this option. + */ + type = ApplicationCommandOptionType.Attachment; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/boolean.ts +import { ApplicationCommandOptionType as ApplicationCommandOptionType2 } from "discord-api-types/v10"; +var SlashCommandBooleanOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandBooleanOption"); + } + /** + * The type of this option. + */ + type = ApplicationCommandOptionType2.Boolean; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/channel.ts +import { ApplicationCommandOptionType as ApplicationCommandOptionType3 } from "discord-api-types/v10"; +import { mix } from "ts-mixer"; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.ts +import { s as s6 } from "@sapphire/shapeshift"; +import { ChannelType as ChannelType2 } from "discord-api-types/v10"; +var allowedChannelTypes = [ + ChannelType2.GuildText, + ChannelType2.GuildVoice, + ChannelType2.GuildCategory, + ChannelType2.GuildAnnouncement, + ChannelType2.AnnouncementThread, + ChannelType2.PublicThread, + ChannelType2.PrivateThread, + ChannelType2.GuildStageVoice, + ChannelType2.GuildForum, + ChannelType2.GuildMedia +]; +var channelTypesPredicate = s6.array(s6.union(allowedChannelTypes.map((type) => s6.literal(type)))); +var ApplicationCommandOptionChannelTypesMixin = class { + static { + __name(this, "ApplicationCommandOptionChannelTypesMixin"); + } + /** + * The channel types of this option. + */ + channel_types; + /** + * Adds channel types to this option. + * + * @param channelTypes - The channel types + */ + addChannelTypes(...channelTypes) { + if (this.channel_types === void 0) { + Reflect.set(this, "channel_types", []); + } + this.channel_types.push(...channelTypesPredicate.parse(normalizeArray(channelTypes))); + return this; + } +}; + +// src/interactions/slashCommands/options/channel.ts +var SlashCommandChannelOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = ApplicationCommandOptionType3.Channel; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; +__name(SlashCommandChannelOption, "SlashCommandChannelOption"); +SlashCommandChannelOption = __decorateClass([ + mix(ApplicationCommandOptionChannelTypesMixin) +], SlashCommandChannelOption); + +// src/interactions/slashCommands/options/integer.ts +import { s as s9 } from "@sapphire/shapeshift"; +import { ApplicationCommandOptionType as ApplicationCommandOptionType5 } from "discord-api-types/v10"; +import { mix as mix2 } from "ts-mixer"; + +// src/interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.ts +var ApplicationCommandNumericOptionMinMaxValueMixin = class { + static { + __name(this, "ApplicationCommandNumericOptionMinMaxValueMixin"); + } + /** + * The maximum value of this option. + */ + max_value; + /** + * The minimum value of this option. + */ + min_value; +}; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.ts +import { s as s7 } from "@sapphire/shapeshift"; +var booleanPredicate2 = s7.boolean(); +var ApplicationCommandOptionWithAutocompleteMixin = class { + static { + __name(this, "ApplicationCommandOptionWithAutocompleteMixin"); + } + /** + * Whether this option utilizes autocomplete. + */ + autocomplete; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + type; + /** + * Whether this option uses autocomplete. + * + * @param autocomplete - Whether this option should use autocomplete + */ + setAutocomplete(autocomplete) { + booleanPredicate2.parse(autocomplete); + if (autocomplete && "choices" in this && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + Reflect.set(this, "autocomplete", autocomplete); + return this; + } +}; + +// src/interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.ts +import { s as s8 } from "@sapphire/shapeshift"; +import { ApplicationCommandOptionType as ApplicationCommandOptionType4 } from "discord-api-types/v10"; +var stringPredicate = s8.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100); +var numberPredicate = s8.number().greaterThan(Number.NEGATIVE_INFINITY).lessThan(Number.POSITIVE_INFINITY); +var choicesPredicate = s8.object({ + name: stringPredicate, + name_localizations: localizationMapPredicate, + value: s8.union([stringPredicate, numberPredicate]) +}).array(); +var ApplicationCommandOptionWithChoicesMixin = class { + static { + __name(this, "ApplicationCommandOptionWithChoicesMixin"); + } + /** + * The choices of this option. + */ + choices; + /** + * The type of this option. + * + * @privateRemarks Since this is present and this is a mixin, this is needed. + */ + type; + /** + * Adds multiple choices to this option. + * + * @param choices - The choices to add + */ + addChoices(...choices) { + const normalizedChoices = normalizeArray(choices); + if (normalizedChoices.length > 0 && "autocomplete" in this && this.autocomplete) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + choicesPredicate.parse(normalizedChoices); + if (this.choices === void 0) { + Reflect.set(this, "choices", []); + } + validateChoicesLength(normalizedChoices.length, this.choices); + for (const { name, name_localizations, value } of normalizedChoices) { + if (this.type === ApplicationCommandOptionType4.String) { + stringPredicate.parse(value); + } else { + numberPredicate.parse(value); + } + this.choices.push({ name, name_localizations, value }); + } + return this; + } + /** + * Sets multiple choices for this option. + * + * @param choices - The choices to set + */ + setChoices(...choices) { + const normalizedChoices = normalizeArray(choices); + if (normalizedChoices.length > 0 && "autocomplete" in this && this.autocomplete) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + choicesPredicate.parse(normalizedChoices); + Reflect.set(this, "choices", []); + this.addChoices(normalizedChoices); + return this; + } +}; + +// src/interactions/slashCommands/options/integer.ts +var numberValidator = s9.number().int(); +var SlashCommandIntegerOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = ApplicationCommandOptionType5.Integer; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max) { + numberValidator.parse(max); + Reflect.set(this, "max_value", max); + return this; + } + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min) { + numberValidator.parse(min); + Reflect.set(this, "min_value", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandIntegerOption, "SlashCommandIntegerOption"); +SlashCommandIntegerOption = __decorateClass([ + mix2( + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin + ) +], SlashCommandIntegerOption); + +// src/interactions/slashCommands/options/mentionable.ts +import { ApplicationCommandOptionType as ApplicationCommandOptionType6 } from "discord-api-types/v10"; +var SlashCommandMentionableOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandMentionableOption"); + } + /** + * The type of this option. + */ + type = ApplicationCommandOptionType6.Mentionable; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/number.ts +import { s as s10 } from "@sapphire/shapeshift"; +import { ApplicationCommandOptionType as ApplicationCommandOptionType7 } from "discord-api-types/v10"; +import { mix as mix3 } from "ts-mixer"; +var numberValidator2 = s10.number(); +var SlashCommandNumberOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = ApplicationCommandOptionType7.Number; + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue} + */ + setMaxValue(max) { + numberValidator2.parse(max); + Reflect.set(this, "max_value", max); + return this; + } + /** + * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue} + */ + setMinValue(min) { + numberValidator2.parse(min); + Reflect.set(this, "min_value", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandNumberOption, "SlashCommandNumberOption"); +SlashCommandNumberOption = __decorateClass([ + mix3( + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin + ) +], SlashCommandNumberOption); + +// src/interactions/slashCommands/options/role.ts +import { ApplicationCommandOptionType as ApplicationCommandOptionType8 } from "discord-api-types/v10"; +var SlashCommandRoleOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandRoleOption"); + } + /** + * The type of this option. + */ + type = ApplicationCommandOptionType8.Role; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/string.ts +import { s as s11 } from "@sapphire/shapeshift"; +import { ApplicationCommandOptionType as ApplicationCommandOptionType9 } from "discord-api-types/v10"; +import { mix as mix4 } from "ts-mixer"; +var minLengthValidator2 = s11.number().greaterThanOrEqual(0).lessThanOrEqual(6e3); +var maxLengthValidator2 = s11.number().greaterThanOrEqual(1).lessThanOrEqual(6e3); +var SlashCommandStringOption = class extends ApplicationCommandOptionBase { + /** + * The type of this option. + */ + type = ApplicationCommandOptionType9.String; + /** + * The maximum length of this option. + */ + max_length; + /** + * The minimum length of this option. + */ + min_length; + /** + * Sets the maximum length of this string option. + * + * @param max - The maximum length this option can be + */ + setMaxLength(max) { + maxLengthValidator2.parse(max); + Reflect.set(this, "max_length", max); + return this; + } + /** + * Sets the minimum length of this string option. + * + * @param min - The minimum length this option can be + */ + setMinLength(min) { + minLengthValidator2.parse(min); + Reflect.set(this, "min_length", min); + return this; + } + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + if (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) { + throw new RangeError("Autocomplete and choices are mutually exclusive to each other."); + } + return { ...this }; + } +}; +__name(SlashCommandStringOption, "SlashCommandStringOption"); +SlashCommandStringOption = __decorateClass([ + mix4(ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin) +], SlashCommandStringOption); + +// src/interactions/slashCommands/options/user.ts +import { ApplicationCommandOptionType as ApplicationCommandOptionType10 } from "discord-api-types/v10"; +var SlashCommandUserOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandUserOption"); + } + /** + * The type of this option. + */ + type = ApplicationCommandOptionType10.User; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/mixins/SharedSlashCommandOptions.ts +var SharedSlashCommandOptions = class { + static { + __name(this, "SharedSlashCommandOptions"); + } + options; + /** + * Adds a boolean option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addBooleanOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandBooleanOption); + } + /** + * Adds a user option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addUserOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandUserOption); + } + /** + * Adds a channel option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addChannelOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandChannelOption); + } + /** + * Adds a role option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addRoleOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandRoleOption); + } + /** + * Adds an attachment option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addAttachmentOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandAttachmentOption); + } + /** + * Adds a mentionable option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addMentionableOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandMentionableOption); + } + /** + * Adds a string option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addStringOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandStringOption); + } + /** + * Adds an integer option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addIntegerOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandIntegerOption); + } + /** + * Adds a number option. + * + * @param input - A function that returns an option builder or an already built builder + */ + addNumberOption(input) { + return this._sharedAddOptionMethod(input, SlashCommandNumberOption); + } + /** + * Where the actual adding magic happens. ✨ + * + * @param input - The input. What else? + * @param Instance - The instance of whatever is being added + * @internal + */ + _sharedAddOptionMethod(input, Instance) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new Instance()) : input; + assertReturnOfBuilder(result, Instance); + options.push(result); + return this; + } +}; + +// src/interactions/slashCommands/SlashCommandSubcommands.ts +import { + ApplicationCommandOptionType as ApplicationCommandOptionType11 +} from "discord-api-types/v10"; +import { mix as mix5 } from "ts-mixer"; +var SlashCommandSubcommandGroupBuilder = class { + /** + * The name of this subcommand group. + */ + name = void 0; + /** + * The description of this subcommand group. + */ + description = void 0; + /** + * The subcommands within this subcommand group. + */ + options = []; + /** + * Adds a new subcommand to this group. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandBuilder); + options.push(result); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + return { + type: ApplicationCommandOptionType11.SubcommandGroup, + name: this.name, + name_localizations: this.name_localizations, + description: this.description, + description_localizations: this.description_localizations, + options: this.options.map((option) => option.toJSON()) + }; + } +}; +__name(SlashCommandSubcommandGroupBuilder, "SlashCommandSubcommandGroupBuilder"); +SlashCommandSubcommandGroupBuilder = __decorateClass([ + mix5(SharedNameAndDescription) +], SlashCommandSubcommandGroupBuilder); +var SlashCommandSubcommandBuilder = class { + /** + * The name of this subcommand. + */ + name = void 0; + /** + * The description of this subcommand. + */ + description = void 0; + /** + * The options within this subcommand. + */ + options = []; + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters3(this.name, this.description, this.options); + return { + type: ApplicationCommandOptionType11.Subcommand, + name: this.name, + name_localizations: this.name_localizations, + description: this.description, + description_localizations: this.description_localizations, + options: this.options.map((option) => option.toJSON()) + }; + } +}; +__name(SlashCommandSubcommandBuilder, "SlashCommandSubcommandBuilder"); +SlashCommandSubcommandBuilder = __decorateClass([ + mix5(SharedNameAndDescription, SharedSlashCommandOptions) +], SlashCommandSubcommandBuilder); + +// src/interactions/slashCommands/mixins/SharedSubcommands.ts +var SharedSlashCommandSubcommands = class { + static { + __name(this, "SharedSlashCommandSubcommands"); + } + options = []; + /** + * Adds a new subcommand group to this command. + * + * @param input - A function that returns a subcommand group builder or an already built builder + */ + addSubcommandGroup(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandGroupBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandGroupBuilder); + options.push(result); + return this; + } + /** + * Adds a new subcommand to this command. + * + * @param input - A function that returns a subcommand builder or an already built builder + */ + addSubcommand(input) { + const { options } = this; + validateMaxOptionsLength(options); + const result = typeof input === "function" ? input(new SlashCommandSubcommandBuilder()) : input; + assertReturnOfBuilder(result, SlashCommandSubcommandBuilder); + options.push(result); + return this; + } +}; + +// src/interactions/slashCommands/SlashCommandBuilder.ts +var SlashCommandBuilder = class { + /** + * The name of this command. + */ + name = void 0; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The description of this command. + */ + description = void 0; + /** + * The description localizations of this command. + */ + description_localizations; + /** + * The options of this command. + */ + options = []; + /** + * The contexts for this command. + */ + contexts; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead. + */ + default_permission = void 0; + /** + * The set of permissions represented as a bit set for the command. + */ + default_member_permissions = void 0; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link SlashCommandBuilder.contexts} instead. + */ + dm_permission = void 0; + /** + * The integration types for this command. + */ + integration_types; + /** + * Whether this command is NSFW. + */ + nsfw = void 0; +}; +__name(SlashCommandBuilder, "SlashCommandBuilder"); +SlashCommandBuilder = __decorateClass([ + mix6(SharedSlashCommandOptions, SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand) +], SlashCommandBuilder); + +// src/interactions/contextMenuCommands/Assertions.ts +var Assertions_exports6 = {}; +__export(Assertions_exports6, { + contextsPredicate: () => contextsPredicate2, + integrationTypesPredicate: () => integrationTypesPredicate2, + validateDMPermission: () => validateDMPermission2, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions2, + validateDefaultPermission: () => validateDefaultPermission2, + validateName: () => validateName2, + validateRequiredParameters: () => validateRequiredParameters4, + validateType: () => validateType +}); +import { s as s12 } from "@sapphire/shapeshift"; +import { ApplicationCommandType as ApplicationCommandType2, ApplicationIntegrationType as ApplicationIntegrationType2, InteractionContextType as InteractionContextType2 } from "discord-api-types/v10"; +var namePredicate2 = s12.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(32).regex(/^( *[\p{P}\p{L}\p{N}\p{sc=Devanagari}\p{sc=Thai}]+ *)+$/u).setValidationEnabled(isValidationEnabled); +var typePredicate = s12.union([s12.literal(ApplicationCommandType2.User), s12.literal(ApplicationCommandType2.Message)]).setValidationEnabled(isValidationEnabled); +var booleanPredicate3 = s12.boolean(); +function validateDefaultPermission2(value) { + booleanPredicate3.parse(value); +} +__name(validateDefaultPermission2, "validateDefaultPermission"); +function validateName2(name) { + namePredicate2.parse(name); +} +__name(validateName2, "validateName"); +function validateType(type) { + typePredicate.parse(type); +} +__name(validateType, "validateType"); +function validateRequiredParameters4(name, type) { + validateName2(name); + validateType(type); +} +__name(validateRequiredParameters4, "validateRequiredParameters"); +var dmPermissionPredicate2 = s12.boolean().nullish(); +function validateDMPermission2(value) { + dmPermissionPredicate2.parse(value); +} +__name(validateDMPermission2, "validateDMPermission"); +var memberPermissionPredicate2 = s12.union([ + s12.bigint().transform((value) => value.toString()), + s12.number().safeInt().transform((value) => value.toString()), + s12.string().regex(/^\d+$/) +]).nullish(); +function validateDefaultMemberPermissions2(permissions) { + return memberPermissionPredicate2.parse(permissions); +} +__name(validateDefaultMemberPermissions2, "validateDefaultMemberPermissions"); +var contextsPredicate2 = s12.array( + s12.nativeEnum(InteractionContextType2).setValidationEnabled(isValidationEnabled) +); +var integrationTypesPredicate2 = s12.array( + s12.nativeEnum(ApplicationIntegrationType2).setValidationEnabled(isValidationEnabled) +); + +// src/interactions/contextMenuCommands/ContextMenuCommandBuilder.ts +var ContextMenuCommandBuilder = class { + static { + __name(this, "ContextMenuCommandBuilder"); + } + /** + * The name of this command. + */ + name = void 0; + /** + * The name localizations of this command. + */ + name_localizations; + /** + * The type of this command. + */ + type = void 0; + /** + * The contexts for this command. + */ + contexts; + /** + * Whether this command is enabled by default when the application is added to a guild. + * + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + default_permission = void 0; + /** + * The set of permissions represented as a bit set for the command. + */ + default_member_permissions = void 0; + /** + * Indicates whether the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This property is only for global commands. + * @deprecated + * Use {@link ContextMenuCommandBuilder.contexts} instead. + */ + dm_permission = void 0; + /** + * The integration types for this command. + */ + integration_types; + /** + * Sets the contexts of this command. + * + * @param contexts - The contexts + */ + setContexts(...contexts) { + Reflect.set(this, "contexts", contextsPredicate2.parse(normalizeArray(contexts))); + return this; + } + /** + * Sets integration types of this command. + * + * @param integrationTypes - The integration types + */ + setIntegrationTypes(...integrationTypes) { + Reflect.set(this, "integration_types", integrationTypesPredicate2.parse(normalizeArray(integrationTypes))); + return this; + } + /** + * Sets the name of this command. + * + * @param name - The name to use + */ + setName(name) { + validateName2(name); + Reflect.set(this, "name", name); + return this; + } + /** + * Sets the type of this command. + * + * @param type - The type to use + */ + setType(type) { + validateType(type); + Reflect.set(this, "type", type); + return this; + } + /** + * Sets whether the command is enabled by default when the application is added to a guild. + * + * @remarks + * If set to `false`, you will have to later `PUT` the permissions for this command. + * @param value - Whether to enable this command by default + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead. + */ + setDefaultPermission(value) { + validateDefaultPermission2(value); + Reflect.set(this, "default_permission", value); + return this; + } + /** + * Sets the default permissions a member should have in order to run this command. + * + * @remarks + * You can set this to `'0'` to disable the command by default. + * @param permissions - The permissions bit field to set + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + */ + setDefaultMemberPermissions(permissions) { + const permissionValue = validateDefaultMemberPermissions2(permissions); + Reflect.set(this, "default_member_permissions", permissionValue); + return this; + } + /** + * Sets if the command is available in direct messages with the application. + * + * @remarks + * By default, commands are visible. This method is only for global commands. + * @param enabled - Whether the command should be enabled in direct messages + * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions} + * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead. + */ + setDMPermission(enabled) { + validateDMPermission2(enabled); + Reflect.set(this, "dm_permission", enabled); + return this; + } + /** + * Sets a name localization for this command. + * + * @param locale - The locale to set + * @param localizedName - The localized name for the given `locale` + */ + setNameLocalization(locale, localizedName) { + if (!this.name_localizations) { + Reflect.set(this, "name_localizations", {}); + } + const parsedLocale = validateLocale(locale); + if (localizedName === null) { + this.name_localizations[parsedLocale] = null; + return this; + } + validateName2(localizedName); + this.name_localizations[parsedLocale] = localizedName; + return this; + } + /** + * Sets the name localizations for this command. + * + * @param localizedNames - The object of localized names to set + */ + setNameLocalizations(localizedNames) { + if (localizedNames === null) { + Reflect.set(this, "name_localizations", null); + return this; + } + Reflect.set(this, "name_localizations", {}); + for (const args of Object.entries(localizedNames)) + this.setNameLocalization(...args); + return this; + } + /** + * Serializes this builder to API-compatible JSON data. + * + * @remarks + * This method runs validations on the data before serializing it. + * As such, it may throw an error if the data is invalid. + */ + toJSON() { + validateRequiredParameters4(this.name, this.type); + validateLocalizationMap(this.name_localizations); + return { ...this }; + } +}; + +// src/util/componentUtil.ts +function embedLength(data) { + return (data.title?.length ?? 0) + (data.description?.length ?? 0) + (data.fields?.reduce((prev, curr) => prev + curr.name.length + curr.value.length, 0) ?? 0) + (data.footer?.text.length ?? 0) + (data.author?.name.length ?? 0); +} +__name(embedLength, "embedLength"); + +// src/index.ts +var version = "1.10.1"; +export { + ActionRowBuilder, + ApplicationCommandNumericOptionMinMaxValueMixin, + ApplicationCommandOptionBase, + ApplicationCommandOptionChannelTypesMixin, + ApplicationCommandOptionWithAutocompleteMixin, + ApplicationCommandOptionWithChoicesMixin, + BaseSelectMenuBuilder, + ButtonBuilder, + ChannelSelectMenuBuilder, + Assertions_exports2 as ComponentAssertions, + ComponentBuilder, + Assertions_exports6 as ContextMenuCommandAssertions, + ContextMenuCommandBuilder, + Assertions_exports as EmbedAssertions, + EmbedBuilder, + MentionableSelectMenuBuilder, + Assertions_exports4 as ModalAssertions, + ModalBuilder, + RoleSelectMenuBuilder, + StringSelectMenuBuilder as SelectMenuBuilder, + StringSelectMenuOptionBuilder as SelectMenuOptionBuilder, + SharedNameAndDescription, + SharedSlashCommand, + SharedSlashCommandOptions, + SharedSlashCommandSubcommands, + Assertions_exports5 as SlashCommandAssertions, + SlashCommandAttachmentOption, + SlashCommandBooleanOption, + SlashCommandBuilder, + SlashCommandChannelOption, + SlashCommandIntegerOption, + SlashCommandMentionableOption, + SlashCommandNumberOption, + SlashCommandRoleOption, + SlashCommandStringOption, + SlashCommandSubcommandBuilder, + SlashCommandSubcommandGroupBuilder, + SlashCommandUserOption, + StringSelectMenuBuilder, + StringSelectMenuOptionBuilder, + Assertions_exports3 as TextInputAssertions, + TextInputBuilder, + UserSelectMenuBuilder, + createComponentBuilder, + disableValidators, + embedLength, + enableValidators, + isValidationEnabled, + normalizeArray, + version +}; +//# sourceMappingURL=index.mjs.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs.map b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs.map new file mode 100644 index 0000000..6900d59 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/dist/index.mjs.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/messages/embed/Assertions.ts","../src/util/validation.ts","../src/util/normalizeArray.ts","../src/messages/embed/Embed.ts","../src/index.ts","../src/components/Assertions.ts","../src/components/selectMenu/StringSelectMenuOption.ts","../src/components/ActionRow.ts","../src/components/Component.ts","../src/components/Components.ts","../src/components/button/Button.ts","../src/components/selectMenu/ChannelSelectMenu.ts","../src/components/selectMenu/BaseSelectMenu.ts","../src/components/selectMenu/MentionableSelectMenu.ts","../src/components/selectMenu/RoleSelectMenu.ts","../src/components/selectMenu/StringSelectMenu.ts","../src/components/selectMenu/UserSelectMenu.ts","../src/components/textInput/TextInput.ts","../src/components/textInput/Assertions.ts","../src/interactions/modals/Assertions.ts","../src/interactions/modals/Modal.ts","../src/interactions/slashCommands/Assertions.ts","../src/interactions/slashCommands/SlashCommandBuilder.ts","../src/interactions/slashCommands/mixins/NameAndDescription.ts","../src/interactions/slashCommands/mixins/SharedSlashCommand.ts","../src/interactions/slashCommands/options/attachment.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionBase.ts","../src/interactions/slashCommands/options/boolean.ts","../src/interactions/slashCommands/options/channel.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.ts","../src/interactions/slashCommands/options/integer.ts","../src/interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.ts","../src/interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.ts","../src/interactions/slashCommands/options/mentionable.ts","../src/interactions/slashCommands/options/number.ts","../src/interactions/slashCommands/options/role.ts","../src/interactions/slashCommands/options/string.ts","../src/interactions/slashCommands/options/user.ts","../src/interactions/slashCommands/mixins/SharedSlashCommandOptions.ts","../src/interactions/slashCommands/SlashCommandSubcommands.ts","../src/interactions/slashCommands/mixins/SharedSubcommands.ts","../src/interactions/contextMenuCommands/Assertions.ts","../src/interactions/contextMenuCommands/ContextMenuCommandBuilder.ts","../src/util/componentUtil.ts"],"sourcesContent":["import { s } from '@sapphire/shapeshift';\nimport type { APIEmbedField } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\n\nexport const fieldNamePredicate = s.string().lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled);\n\nexport const fieldValuePredicate = s.string().lengthLessThanOrEqual(1_024).setValidationEnabled(isValidationEnabled);\n\nexport const fieldInlinePredicate = s.boolean().optional();\n\nexport const embedFieldPredicate = s\n\t.object({\n\t\tname: fieldNamePredicate,\n\t\tvalue: fieldValuePredicate,\n\t\tinline: fieldInlinePredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedFieldsArrayPredicate = embedFieldPredicate.array().setValidationEnabled(isValidationEnabled);\n\nexport const fieldLengthPredicate = s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\n\nexport function validateFieldLength(amountAdding: number, fields?: APIEmbedField[]): void {\n\tfieldLengthPredicate.parse((fields?.length ?? 0) + amountAdding);\n}\n\nexport const authorNamePredicate = fieldNamePredicate\n\t.lengthGreaterThanOrEqual(1)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const imageURLPredicate = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'attachment:'],\n\t})\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const urlPredicate = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:'],\n\t})\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedAuthorPredicate = s\n\t.object({\n\t\tname: authorNamePredicate,\n\t\ticonURL: imageURLPredicate,\n\t\turl: urlPredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const RGBPredicate = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(255)\n\t.setValidationEnabled(isValidationEnabled);\nexport const colorPredicate = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(0xffffff)\n\t.or(s.tuple([RGBPredicate, RGBPredicate, RGBPredicate]))\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const descriptionPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(4_096)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const footerTextPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(2_048)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const embedFooterPredicate = s\n\t.object({\n\t\ttext: footerTextPredicate,\n\t\ticonURL: imageURLPredicate,\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const timestampPredicate = s.union([s.number(), s.date()]).nullable().setValidationEnabled(isValidationEnabled);\n\nexport const titlePredicate = fieldNamePredicate\n\t.lengthGreaterThanOrEqual(1)\n\t.nullable()\n\t.setValidationEnabled(isValidationEnabled);\n","let validate = true;\n\n/**\n * Enables validators.\n *\n * @returns Whether validation is occurring.\n */\nexport function enableValidators() {\n\treturn (validate = true);\n}\n\n/**\n * Disables validators.\n *\n * @returns Whether validation is occurring.\n */\nexport function disableValidators() {\n\treturn (validate = false);\n}\n\n/**\n * Checks whether validation is occurring.\n */\nexport function isValidationEnabled() {\n\treturn validate;\n}\n","/**\n * Normalizes data that is a rest parameter or an array into an array with a depth of 1.\n *\n * @typeParam ItemType - The data that must satisfy {@link RestOrArray}.\n * @param arr - The (possibly variadic) data to normalize\n */\nexport function normalizeArray(arr: RestOrArray): ItemType[] {\n\tif (Array.isArray(arr[0])) return [...arr[0]];\n\treturn arr as ItemType[];\n}\n\n/**\n * Represents data that may be an array or came from a rest parameter.\n *\n * @remarks\n * This type is used throughout builders to ensure both an array and variadic arguments\n * may be used. It is normalized with {@link normalizeArray}.\n */\nexport type RestOrArray = Type[] | [Type[]];\n","import type { APIEmbed, APIEmbedAuthor, APIEmbedField, APIEmbedFooter, APIEmbedImage } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport {\n\tcolorPredicate,\n\tdescriptionPredicate,\n\tembedAuthorPredicate,\n\tembedFieldsArrayPredicate,\n\tembedFooterPredicate,\n\timageURLPredicate,\n\ttimestampPredicate,\n\ttitlePredicate,\n\turlPredicate,\n\tvalidateFieldLength,\n} from './Assertions.js';\n\n/**\n * A tuple satisfying the RGB color model.\n *\n * @see {@link https://developer.mozilla.org/docs/Glossary/RGB}\n */\nexport type RGBTuple = [red: number, green: number, blue: number];\n\n/**\n * The base icon data typically used in payloads.\n */\nexport interface IconData {\n\t/**\n\t * The URL of the icon.\n\t */\n\ticonURL?: string;\n\t/**\n\t * The proxy URL of the icon.\n\t */\n\tproxyIconURL?: string;\n}\n\n/**\n * Represents the author data of an embed.\n */\nexport interface EmbedAuthorData extends IconData, Omit {}\n\n/**\n * Represents the author options of an embed.\n */\nexport interface EmbedAuthorOptions extends Omit {}\n\n/**\n * Represents the footer data of an embed.\n */\nexport interface EmbedFooterData extends IconData, Omit {}\n\n/**\n * Represents the footer options of an embed.\n */\nexport interface EmbedFooterOptions extends Omit {}\n\n/**\n * Represents the image data of an embed.\n */\nexport interface EmbedImageData extends Omit {\n\t/**\n\t * The proxy URL for the image.\n\t */\n\tproxyURL?: string;\n}\n\n/**\n * A builder that creates API-compatible JSON data for embeds.\n */\nexport class EmbedBuilder {\n\t/**\n\t * The API data associated with this embed.\n\t */\n\tpublic readonly data: APIEmbed;\n\n\t/**\n\t * Creates a new embed from API data.\n\t *\n\t * @param data - The API data to create this embed with\n\t */\n\tpublic constructor(data: APIEmbed = {}) {\n\t\tthis.data = { ...data };\n\t\tif (data.timestamp) this.data.timestamp = new Date(data.timestamp).toISOString();\n\t}\n\n\t/**\n\t * Appends fields to the embed.\n\t *\n\t * @remarks\n\t * This method accepts either an array of fields or a variable number of field parameters.\n\t * The maximum amount of fields that can be added is 25.\n\t * @example\n\t * Using an array:\n\t * ```ts\n\t * const fields: APIEmbedField[] = ...;\n\t * const embed = new EmbedBuilder()\n\t * \t.addFields(fields);\n\t * ```\n\t * @example\n\t * Using rest parameters (variadic):\n\t * ```ts\n\t * const embed = new EmbedBuilder()\n\t * \t.addFields(\n\t * \t\t{ name: 'Field 1', value: 'Value 1' },\n\t * \t\t{ name: 'Field 2', value: 'Value 2' },\n\t * \t);\n\t * ```\n\t * @param fields - The fields to add\n\t */\n\tpublic addFields(...fields: RestOrArray): this {\n\t\tconst normalizedFields = normalizeArray(fields);\n\t\t// Ensure adding these fields won't exceed the 25 field limit\n\t\tvalidateFieldLength(normalizedFields.length, this.data.fields);\n\n\t\t// Data assertions\n\t\tembedFieldsArrayPredicate.parse(normalizedFields);\n\n\t\tif (this.data.fields) this.data.fields.push(...normalizedFields);\n\t\telse this.data.fields = normalizedFields;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Removes, replaces, or inserts fields for this embed.\n\t *\n\t * @remarks\n\t * This method behaves similarly\n\t * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/splice | Array.prototype.splice()}.\n\t * The maximum amount of fields that can be added is 25.\n\t *\n\t * It's useful for modifying and adjusting order of the already-existing fields of an embed.\n\t * @example\n\t * Remove the first field:\n\t * ```ts\n\t * embed.spliceFields(0, 1);\n\t * ```\n\t * @example\n\t * Remove the first n fields:\n\t * ```ts\n\t * const n = 4;\n\t * embed.spliceFields(0, n);\n\t * ```\n\t * @example\n\t * Remove the last field:\n\t * ```ts\n\t * embed.spliceFields(-1, 1);\n\t * ```\n\t * @param index - The index to start at\n\t * @param deleteCount - The number of fields to remove\n\t * @param fields - The replacing field objects\n\t */\n\tpublic spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this {\n\t\t// Ensure adding these fields won't exceed the 25 field limit\n\t\tvalidateFieldLength(fields.length - deleteCount, this.data.fields);\n\n\t\t// Data assertions\n\t\tembedFieldsArrayPredicate.parse(fields);\n\t\tif (this.data.fields) this.data.fields.splice(index, deleteCount, ...fields);\n\t\telse this.data.fields = fields;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the fields for this embed.\n\t *\n\t * @remarks\n\t * This method is an alias for {@link EmbedBuilder.spliceFields}. More specifically,\n\t * it splices the entire array of fields, replacing them with the provided fields.\n\t *\n\t * You can set a maximum of 25 fields.\n\t * @param fields - The fields to set\n\t */\n\tpublic setFields(...fields: RestOrArray): this {\n\t\tthis.spliceFields(0, this.data.fields?.length ?? 0, ...normalizeArray(fields));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the author of this embed.\n\t *\n\t * @param options - The options to use\n\t */\n\n\tpublic setAuthor(options: EmbedAuthorOptions | null): this {\n\t\tif (options === null) {\n\t\t\tthis.data.author = undefined;\n\t\t\treturn this;\n\t\t}\n\n\t\t// Data assertions\n\t\tembedAuthorPredicate.parse(options);\n\n\t\tthis.data.author = { name: options.name, url: options.url, icon_url: options.iconURL };\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the color of this embed.\n\t *\n\t * @param color - The color to use\n\t */\n\tpublic setColor(color: RGBTuple | number | null): this {\n\t\t// Data assertions\n\t\tcolorPredicate.parse(color);\n\n\t\tif (Array.isArray(color)) {\n\t\t\tconst [red, green, blue] = color;\n\t\t\tthis.data.color = (red << 16) + (green << 8) + blue;\n\t\t\treturn this;\n\t\t}\n\n\t\tthis.data.color = color ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description of this embed.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string | null): this {\n\t\t// Data assertions\n\t\tdescriptionPredicate.parse(description);\n\n\t\tthis.data.description = description ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the footer of this embed.\n\t *\n\t * @param options - The footer to use\n\t */\n\tpublic setFooter(options: EmbedFooterOptions | null): this {\n\t\tif (options === null) {\n\t\t\tthis.data.footer = undefined;\n\t\t\treturn this;\n\t\t}\n\n\t\t// Data assertions\n\t\tembedFooterPredicate.parse(options);\n\n\t\tthis.data.footer = { text: options.text, icon_url: options.iconURL };\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the image of this embed.\n\t *\n\t * @param url - The image URL to use\n\t */\n\tpublic setImage(url: string | null): this {\n\t\t// Data assertions\n\t\timageURLPredicate.parse(url);\n\n\t\tthis.data.image = url ? { url } : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the thumbnail of this embed.\n\t *\n\t * @param url - The thumbnail URL to use\n\t */\n\tpublic setThumbnail(url: string | null): this {\n\t\t// Data assertions\n\t\timageURLPredicate.parse(url);\n\n\t\tthis.data.thumbnail = url ? { url } : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the timestamp of this embed.\n\t *\n\t * @param timestamp - The timestamp or date to use\n\t */\n\tpublic setTimestamp(timestamp: Date | number | null = Date.now()): this {\n\t\t// Data assertions\n\t\ttimestampPredicate.parse(timestamp);\n\n\t\tthis.data.timestamp = timestamp ? new Date(timestamp).toISOString() : undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the title for this embed.\n\t *\n\t * @param title - The title to use\n\t */\n\tpublic setTitle(title: string | null): this {\n\t\t// Data assertions\n\t\ttitlePredicate.parse(title);\n\n\t\tthis.data.title = title ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the URL of this embed.\n\t *\n\t * @param url - The URL to use\n\t */\n\tpublic setURL(url: string | null): this {\n\t\t// Data assertions\n\t\turlPredicate.parse(url);\n\n\t\tthis.data.url = url ?? undefined;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIEmbed {\n\t\treturn { ...this.data };\n\t}\n}\n","export * as EmbedAssertions from './messages/embed/Assertions.js';\nexport * from './messages/embed/Embed.js';\n// TODO: Consider removing this dep in the next major version\nexport * from '@discordjs/formatters';\n\nexport * as ComponentAssertions from './components/Assertions.js';\nexport * from './components/ActionRow.js';\nexport * from './components/button/Button.js';\nexport * from './components/Component.js';\nexport * from './components/Components.js';\nexport * from './components/textInput/TextInput.js';\nexport * as TextInputAssertions from './components/textInput/Assertions.js';\nexport * from './interactions/modals/Modal.js';\nexport * as ModalAssertions from './interactions/modals/Assertions.js';\n\nexport * from './components/selectMenu/BaseSelectMenu.js';\nexport * from './components/selectMenu/ChannelSelectMenu.js';\nexport * from './components/selectMenu/MentionableSelectMenu.js';\nexport * from './components/selectMenu/RoleSelectMenu.js';\nexport * from './components/selectMenu/StringSelectMenu.js';\n// TODO: Remove those aliases in v2\nexport {\n\t/**\n\t * @deprecated Will be removed in the next major version, use {@link StringSelectMenuBuilder} instead.\n\t */\n\tStringSelectMenuBuilder as SelectMenuBuilder,\n} from './components/selectMenu/StringSelectMenu.js';\nexport {\n\t/**\n\t * @deprecated Will be removed in the next major version, use {@link StringSelectMenuOptionBuilder} instead.\n\t */\n\tStringSelectMenuOptionBuilder as SelectMenuOptionBuilder,\n} from './components/selectMenu/StringSelectMenuOption.js';\nexport * from './components/selectMenu/StringSelectMenuOption.js';\nexport * from './components/selectMenu/UserSelectMenu.js';\n\nexport * as SlashCommandAssertions from './interactions/slashCommands/Assertions.js';\nexport * from './interactions/slashCommands/SlashCommandBuilder.js';\nexport * from './interactions/slashCommands/SlashCommandSubcommands.js';\nexport * from './interactions/slashCommands/options/boolean.js';\nexport * from './interactions/slashCommands/options/channel.js';\nexport * from './interactions/slashCommands/options/integer.js';\nexport * from './interactions/slashCommands/options/mentionable.js';\nexport * from './interactions/slashCommands/options/number.js';\nexport * from './interactions/slashCommands/options/role.js';\nexport * from './interactions/slashCommands/options/attachment.js';\nexport * from './interactions/slashCommands/options/string.js';\nexport * from './interactions/slashCommands/options/user.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionBase.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionChannelTypesMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nexport * from './interactions/slashCommands/mixins/ApplicationCommandOptionWithChoicesMixin.js';\nexport * from './interactions/slashCommands/mixins/NameAndDescription.js';\nexport * from './interactions/slashCommands/mixins/SharedSlashCommandOptions.js';\nexport * from './interactions/slashCommands/mixins/SharedSubcommands.js';\nexport * from './interactions/slashCommands/mixins/SharedSlashCommand.js';\n\nexport * as ContextMenuCommandAssertions from './interactions/contextMenuCommands/Assertions.js';\nexport * from './interactions/contextMenuCommands/ContextMenuCommandBuilder.js';\n\nexport * from './util/componentUtil.js';\nexport * from './util/normalizeArray.js';\nexport * from './util/validation.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/builders#readme | @discordjs/builders} version\n * that you are currently using.\n *\n * @privateRemarks This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild.\n */\nexport const version = '1.10.1' as string;\n","import { s } from '@sapphire/shapeshift';\nimport { ButtonStyle, ChannelType, type APIMessageComponentEmoji } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../util/validation.js';\nimport { StringSelectMenuOptionBuilder } from './selectMenu/StringSelectMenuOption.js';\n\nexport const customIdValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const emojiValidator = s\n\t.object({\n\t\tid: s.string(),\n\t\tname: s.string(),\n\t\tanimated: s.boolean(),\n\t})\n\t.partial()\n\t.strict()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const disabledValidator = s.boolean();\n\nexport const buttonLabelValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(80)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const buttonStyleValidator = s.nativeEnum(ButtonStyle);\n\nexport const placeholderValidator = s.string().lengthLessThanOrEqual(150).setValidationEnabled(isValidationEnabled);\nexport const minMaxValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const labelValueDescriptionValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const jsonOptionValidator = s\n\t.object({\n\t\tlabel: labelValueDescriptionValidator,\n\t\tvalue: labelValueDescriptionValidator,\n\t\tdescription: labelValueDescriptionValidator.optional(),\n\t\temoji: emojiValidator.optional(),\n\t\tdefault: s.boolean().optional(),\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const optionValidator = s.instance(StringSelectMenuOptionBuilder).setValidationEnabled(isValidationEnabled);\n\nexport const optionsValidator = optionValidator\n\t.array()\n\t.lengthGreaterThanOrEqual(0)\n\t.setValidationEnabled(isValidationEnabled);\nexport const optionsLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredSelectMenuParameters(options: StringSelectMenuOptionBuilder[], customId?: string) {\n\tcustomIdValidator.parse(customId);\n\toptionsValidator.parse(options);\n}\n\nexport const defaultValidator = s.boolean();\n\nexport function validateRequiredSelectMenuOptionParameters(label?: string, value?: string) {\n\tlabelValueDescriptionValidator.parse(label);\n\tlabelValueDescriptionValidator.parse(value);\n}\n\nexport const channelTypesValidator = s.nativeEnum(ChannelType).array().setValidationEnabled(isValidationEnabled);\n\nexport const urlValidator = s\n\t.string()\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'discord:'],\n\t})\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredButtonParameters(\n\tstyle?: ButtonStyle,\n\tlabel?: string,\n\temoji?: APIMessageComponentEmoji,\n\tcustomId?: string,\n\tskuId?: string,\n\turl?: string,\n) {\n\tif (style === ButtonStyle.Premium) {\n\t\tif (!skuId) {\n\t\t\tthrow new RangeError('Premium buttons must have an SKU id.');\n\t\t}\n\n\t\tif (customId || label || url || emoji) {\n\t\t\tthrow new RangeError('Premium buttons cannot have a custom id, label, URL, or emoji.');\n\t\t}\n\t} else {\n\t\tif (skuId) {\n\t\t\tthrow new RangeError('Non-premium buttons must not have an SKU id.');\n\t\t}\n\n\t\tif (url && customId) {\n\t\t\tthrow new RangeError('URL and custom id are mutually exclusive.');\n\t\t}\n\n\t\tif (!label && !emoji) {\n\t\t\tthrow new RangeError('Non-premium buttons must have a label and/or an emoji.');\n\t\t}\n\n\t\tif (style === ButtonStyle.Link) {\n\t\t\tif (!url) {\n\t\t\t\tthrow new RangeError('Link buttons must have a URL.');\n\t\t\t}\n\t\t} else if (url) {\n\t\t\tthrow new RangeError('Non-premium and non-link buttons cannot have a URL.');\n\t\t}\n\t}\n}\n","import type { JSONEncodable } from '@discordjs/util';\nimport type { APIMessageComponentEmoji, APISelectMenuOption } from 'discord-api-types/v10';\nimport {\n\tdefaultValidator,\n\temojiValidator,\n\tlabelValueDescriptionValidator,\n\tvalidateRequiredSelectMenuOptionParameters,\n} from '../Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for string select menu options.\n */\nexport class StringSelectMenuOptionBuilder implements JSONEncodable {\n\t/**\n\t * Creates a new string select menu option from API data.\n\t *\n\t * @param data - The API data to create this string select menu option with\n\t * @example\n\t * Creating a string select menu option from an API data object:\n\t * ```ts\n\t * const selectMenuOption = new SelectMenuOptionBuilder({\n\t * \tlabel: 'catchy label',\n\t * \tvalue: '1',\n\t * });\n\t * ```\n\t * @example\n\t * Creating a string select menu option using setters and API data:\n\t * ```ts\n\t * const selectMenuOption = new SelectMenuOptionBuilder({\n\t * \tdefault: true,\n\t * \tvalue: '1',\n\t * })\n\t * \t.setLabel('woah');\n\t * ```\n\t */\n\tpublic constructor(public data: Partial = {}) {}\n\n\t/**\n\t * Sets the label for this option.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\tthis.data.label = labelValueDescriptionValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the value for this option.\n\t *\n\t * @param value - The value to use\n\t */\n\tpublic setValue(value: string) {\n\t\tthis.data.value = labelValueDescriptionValidator.parse(value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description for this option.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string) {\n\t\tthis.data.description = labelValueDescriptionValidator.parse(description);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this option is selected by default.\n\t *\n\t * @param isDefault - Whether this option is selected by default\n\t */\n\tpublic setDefault(isDefault = true) {\n\t\tthis.data.default = defaultValidator.parse(isDefault);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the emoji to display for this option.\n\t *\n\t * @param emoji - The emoji to use\n\t */\n\tpublic setEmoji(emoji: APIMessageComponentEmoji) {\n\t\tthis.data.emoji = emojiValidator.parse(emoji);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic toJSON(): APISelectMenuOption {\n\t\tvalidateRequiredSelectMenuOptionParameters(this.data.label, this.data.value);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APISelectMenuOption;\n\t}\n}\n","/* eslint-disable jsdoc/check-param-names */\n\nimport {\n\ttype APIActionRowComponent,\n\tComponentType,\n\ttype APIMessageActionRowComponent,\n\ttype APIModalActionRowComponent,\n\ttype APIActionRowComponentTypes,\n} from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../util/normalizeArray.js';\nimport { ComponentBuilder } from './Component.js';\nimport { createComponentBuilder } from './Components.js';\nimport type { ButtonBuilder } from './button/Button.js';\nimport type { ChannelSelectMenuBuilder } from './selectMenu/ChannelSelectMenu.js';\nimport type { MentionableSelectMenuBuilder } from './selectMenu/MentionableSelectMenu.js';\nimport type { RoleSelectMenuBuilder } from './selectMenu/RoleSelectMenu.js';\nimport type { StringSelectMenuBuilder } from './selectMenu/StringSelectMenu.js';\nimport type { UserSelectMenuBuilder } from './selectMenu/UserSelectMenu.js';\nimport type { TextInputBuilder } from './textInput/TextInput.js';\n\n/**\n * The builders that may be used for messages.\n */\nexport type MessageComponentBuilder =\n\t| ActionRowBuilder\n\t| MessageActionRowComponentBuilder;\n\n/**\n * The builders that may be used for modals.\n */\nexport type ModalComponentBuilder = ActionRowBuilder | ModalActionRowComponentBuilder;\n\n/**\n * The builders that may be used within an action row for messages.\n */\nexport type MessageActionRowComponentBuilder =\n\t| ButtonBuilder\n\t| ChannelSelectMenuBuilder\n\t| MentionableSelectMenuBuilder\n\t| RoleSelectMenuBuilder\n\t| StringSelectMenuBuilder\n\t| UserSelectMenuBuilder;\n\n/**\n * The builders that may be used within an action row for modals.\n */\nexport type ModalActionRowComponentBuilder = TextInputBuilder;\n\n/**\n * Any builder.\n */\nexport type AnyComponentBuilder = MessageActionRowComponentBuilder | ModalActionRowComponentBuilder;\n\n/**\n * A builder that creates API-compatible JSON data for action rows.\n *\n * @typeParam ComponentType - The types of components this action row holds\n */\nexport class ActionRowBuilder extends ComponentBuilder<\n\tAPIActionRowComponent\n> {\n\t/**\n\t * The components within this action row.\n\t */\n\tpublic readonly components: ComponentType[];\n\n\t/**\n\t * Creates a new action row from API data.\n\t *\n\t * @param data - The API data to create this action row with\n\t * @example\n\t * Creating an action row from an API data object:\n\t * ```ts\n\t * const actionRow = new ActionRowBuilder({\n\t * \tcomponents: [\n\t * \t\t{\n\t * \t\t\tcustom_id: \"custom id\",\n\t * \t\t\tlabel: \"Type something\",\n\t * \t\t\tstyle: TextInputStyle.Short,\n\t * \t\t\ttype: ComponentType.TextInput,\n\t * \t\t},\n\t * \t],\n\t * });\n\t * ```\n\t * @example\n\t * Creating an action row using setters and API data:\n\t * ```ts\n\t * const actionRow = new ActionRowBuilder({\n\t * \tcomponents: [\n\t * \t\t{\n\t * \t\t\tcustom_id: \"custom id\",\n\t * \t\t\tlabel: \"Click me\",\n\t * \t\t\tstyle: ButtonStyle.Primary,\n\t * \t\t\ttype: ComponentType.Button,\n\t * \t\t},\n\t * \t],\n\t * })\n\t * \t.addComponents(button2, button3);\n\t * ```\n\t */\n\tpublic constructor({ components, ...data }: Partial> = {}) {\n\t\tsuper({ type: ComponentType.ActionRow, ...data });\n\t\tthis.components = (components?.map((component) => createComponentBuilder(component)) ?? []) as ComponentType[];\n\t}\n\n\t/**\n\t * Adds components to this action row.\n\t *\n\t * @param components - The components to add\n\t */\n\tpublic addComponents(...components: RestOrArray) {\n\t\tthis.components.push(...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets components for this action row.\n\t *\n\t * @param components - The components to set\n\t */\n\tpublic setComponents(...components: RestOrArray) {\n\t\tthis.components.splice(0, this.components.length, ...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIActionRowComponent> {\n\t\treturn {\n\t\t\t...this.data,\n\t\t\tcomponents: this.components.map((component) => component.toJSON()),\n\t\t} as APIActionRowComponent>;\n\t}\n}\n","import type { JSONEncodable } from '@discordjs/util';\nimport type {\n\tAPIActionRowComponent,\n\tAPIActionRowComponentTypes,\n\tAPIBaseComponent,\n\tComponentType,\n} from 'discord-api-types/v10';\n\n/**\n * Any action row component data represented as an object.\n */\nexport type AnyAPIActionRowComponent = APIActionRowComponent | APIActionRowComponentTypes;\n\n/**\n * The base component builder that contains common symbols for all sorts of components.\n *\n * @typeParam DataType - The type of internal API data that is stored within the component\n */\nexport abstract class ComponentBuilder<\n\tDataType extends Partial> = APIBaseComponent,\n> implements JSONEncodable\n{\n\t/**\n\t * The API data associated with this component.\n\t */\n\tpublic readonly data: Partial;\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic abstract toJSON(): AnyAPIActionRowComponent;\n\n\t/**\n\t * Constructs a new kind of component.\n\t *\n\t * @param data - The data to construct a component out of\n\t */\n\tpublic constructor(data: Partial) {\n\t\tthis.data = data;\n\t}\n}\n","import { ComponentType, type APIMessageComponent, type APIModalComponent } from 'discord-api-types/v10';\nimport {\n\tActionRowBuilder,\n\ttype AnyComponentBuilder,\n\ttype MessageComponentBuilder,\n\ttype ModalComponentBuilder,\n} from './ActionRow.js';\nimport { ComponentBuilder } from './Component.js';\nimport { ButtonBuilder } from './button/Button.js';\nimport { ChannelSelectMenuBuilder } from './selectMenu/ChannelSelectMenu.js';\nimport { MentionableSelectMenuBuilder } from './selectMenu/MentionableSelectMenu.js';\nimport { RoleSelectMenuBuilder } from './selectMenu/RoleSelectMenu.js';\nimport { StringSelectMenuBuilder } from './selectMenu/StringSelectMenu.js';\nimport { UserSelectMenuBuilder } from './selectMenu/UserSelectMenu.js';\nimport { TextInputBuilder } from './textInput/TextInput.js';\n\n/**\n * Components here are mapped to their respective builder.\n */\nexport interface MappedComponentTypes {\n\t/**\n\t * The action row component type is associated with an {@link ActionRowBuilder}.\n\t */\n\t[ComponentType.ActionRow]: ActionRowBuilder;\n\t/**\n\t * The button component type is associated with a {@link ButtonBuilder}.\n\t */\n\t[ComponentType.Button]: ButtonBuilder;\n\t/**\n\t * The string select component type is associated with a {@link StringSelectMenuBuilder}.\n\t */\n\t[ComponentType.StringSelect]: StringSelectMenuBuilder;\n\t/**\n\t * The text input component type is associated with a {@link TextInputBuilder}.\n\t */\n\t[ComponentType.TextInput]: TextInputBuilder;\n\t/**\n\t * The user select component type is associated with a {@link UserSelectMenuBuilder}.\n\t */\n\t[ComponentType.UserSelect]: UserSelectMenuBuilder;\n\t/**\n\t * The role select component type is associated with a {@link RoleSelectMenuBuilder}.\n\t */\n\t[ComponentType.RoleSelect]: RoleSelectMenuBuilder;\n\t/**\n\t * The mentionable select component type is associated with a {@link MentionableSelectMenuBuilder}.\n\t */\n\t[ComponentType.MentionableSelect]: MentionableSelectMenuBuilder;\n\t/**\n\t * The channel select component type is associated with a {@link ChannelSelectMenuBuilder}.\n\t */\n\t[ComponentType.ChannelSelect]: ChannelSelectMenuBuilder;\n}\n\n/**\n * Factory for creating components from API data.\n *\n * @typeParam ComponentType - The type of component to use\n * @param data - The API data to transform to a component class\n */\nexport function createComponentBuilder(\n\t// eslint-disable-next-line @typescript-eslint/sort-type-constituents\n\tdata: (APIModalComponent | APIMessageComponent) & { type: ComponentType },\n): MappedComponentTypes[ComponentType];\n\n/**\n * Factory for creating components from API data.\n *\n * @typeParam ComponentBuilder - The type of component to use\n * @param data - The API data to transform to a component class\n */\nexport function createComponentBuilder(\n\tdata: ComponentBuilder,\n): ComponentBuilder;\n\nexport function createComponentBuilder(\n\tdata: APIMessageComponent | APIModalComponent | MessageComponentBuilder,\n): ComponentBuilder {\n\tif (data instanceof ComponentBuilder) {\n\t\treturn data;\n\t}\n\n\tswitch (data.type) {\n\t\tcase ComponentType.ActionRow:\n\t\t\treturn new ActionRowBuilder(data);\n\t\tcase ComponentType.Button:\n\t\t\treturn new ButtonBuilder(data);\n\t\tcase ComponentType.StringSelect:\n\t\t\treturn new StringSelectMenuBuilder(data);\n\t\tcase ComponentType.TextInput:\n\t\t\treturn new TextInputBuilder(data);\n\t\tcase ComponentType.UserSelect:\n\t\t\treturn new UserSelectMenuBuilder(data);\n\t\tcase ComponentType.RoleSelect:\n\t\t\treturn new RoleSelectMenuBuilder(data);\n\t\tcase ComponentType.MentionableSelect:\n\t\t\treturn new MentionableSelectMenuBuilder(data);\n\t\tcase ComponentType.ChannelSelect:\n\t\t\treturn new ChannelSelectMenuBuilder(data);\n\t\tdefault:\n\t\t\t// @ts-expect-error This case can still occur if we get a newer unsupported component type\n\t\t\tthrow new Error(`Cannot properly serialize component type: ${data.type}`);\n\t}\n}\n","import {\n\tComponentType,\n\ttype APIButtonComponent,\n\ttype APIButtonComponentWithCustomId,\n\ttype APIButtonComponentWithSKUId,\n\ttype APIButtonComponentWithURL,\n\ttype APIMessageComponentEmoji,\n\ttype ButtonStyle,\n\ttype Snowflake,\n} from 'discord-api-types/v10';\nimport {\n\tbuttonLabelValidator,\n\tbuttonStyleValidator,\n\tcustomIdValidator,\n\tdisabledValidator,\n\temojiValidator,\n\turlValidator,\n\tvalidateRequiredButtonParameters,\n} from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\n\n/**\n * A builder that creates API-compatible JSON data for buttons.\n */\nexport class ButtonBuilder extends ComponentBuilder {\n\t/**\n\t * Creates a new button from API data.\n\t *\n\t * @param data - The API data to create this button with\n\t * @example\n\t * Creating a button from an API data object:\n\t * ```ts\n\t * const button = new ButtonBuilder({\n\t * \tcustom_id: 'a cool button',\n\t * \tstyle: ButtonStyle.Primary,\n\t * \tlabel: 'Click Me',\n\t * \temoji: {\n\t * \t\tname: 'smile',\n\t * \t\tid: '123456789012345678',\n\t * \t},\n\t * });\n\t * ```\n\t * @example\n\t * Creating a button using setters and API data:\n\t * ```ts\n\t * const button = new ButtonBuilder({\n\t * \tstyle: ButtonStyle.Secondary,\n\t * \tlabel: 'Click Me',\n\t * })\n\t * \t.setEmoji({ name: '🙂' })\n\t * \t.setCustomId('another cool button');\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ type: ComponentType.Button, ...data });\n\t}\n\n\t/**\n\t * Sets the style of this button.\n\t *\n\t * @param style - The style to use\n\t */\n\tpublic setStyle(style: ButtonStyle) {\n\t\tthis.data.style = buttonStyleValidator.parse(style);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the URL for this button.\n\t *\n\t * @remarks\n\t * This method is only available to buttons using the `Link` button style.\n\t * Only three types of URL schemes are currently supported: `https://`, `http://`, and `discord://`.\n\t * @param url - The URL to use\n\t */\n\tpublic setURL(url: string) {\n\t\t(this.data as APIButtonComponentWithURL).url = urlValidator.parse(url);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id for this button.\n\t *\n\t * @remarks\n\t * This method is only applicable to buttons that are not using the `Link` button style.\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\t(this.data as APIButtonComponentWithCustomId).custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the SKU id that represents a purchasable SKU for this button.\n\t *\n\t * @remarks Only available when using premium-style buttons.\n\t * @param skuId - The SKU id to use\n\t */\n\tpublic setSKUId(skuId: Snowflake) {\n\t\t(this.data as APIButtonComponentWithSKUId).sku_id = skuId;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the emoji to display on this button.\n\t *\n\t * @param emoji - The emoji to use\n\t */\n\tpublic setEmoji(emoji: APIMessageComponentEmoji) {\n\t\t(this.data as Exclude).emoji = emojiValidator.parse(emoji);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this button is disabled.\n\t *\n\t * @param disabled - Whether to disable this button\n\t */\n\tpublic setDisabled(disabled = true) {\n\t\tthis.data.disabled = disabledValidator.parse(disabled);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the label for this button.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\t(this.data as Exclude).label = buttonLabelValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIButtonComponent {\n\t\tvalidateRequiredButtonParameters(\n\t\t\tthis.data.style,\n\t\t\t(this.data as Exclude).label,\n\t\t\t(this.data as Exclude).emoji,\n\t\t\t(this.data as APIButtonComponentWithCustomId).custom_id,\n\t\t\t(this.data as APIButtonComponentWithSKUId).sku_id,\n\t\t\t(this.data as APIButtonComponentWithURL).url,\n\t\t);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APIButtonComponent;\n\t}\n}\n","import {\n\ttype APIChannelSelectComponent,\n\ttype ChannelType,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { channelTypesValidator, customIdValidator, optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for channel select menus.\n */\nexport class ChannelSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new ChannelSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new ChannelSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.addChannelTypes(ChannelType.GuildText, ChannelType.GuildAnnouncement)\n\t * \t.setMinValues(2);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.ChannelSelect });\n\t}\n\n\t/**\n\t * Adds channel types to this select menu.\n\t *\n\t * @param types - The channel types to use\n\t */\n\tpublic addChannelTypes(...types: RestOrArray) {\n\t\tconst normalizedTypes = normalizeArray(types);\n\t\tthis.data.channel_types ??= [];\n\t\tthis.data.channel_types.push(...channelTypesValidator.parse(normalizedTypes));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets channel types for this select menu.\n\t *\n\t * @param types - The channel types to use\n\t */\n\tpublic setChannelTypes(...types: RestOrArray) {\n\t\tconst normalizedTypes = normalizeArray(types);\n\t\tthis.data.channel_types ??= [];\n\t\tthis.data.channel_types.splice(0, this.data.channel_types.length, ...channelTypesValidator.parse(normalizedTypes));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default channels to this auto populated select menu.\n\t *\n\t * @param channels - The channels to add\n\t */\n\tpublic addDefaultChannels(...channels: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(channels);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Channel as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default channels for this auto populated select menu.\n\t *\n\t * @param channels - The channels to set\n\t */\n\tpublic setDefaultChannels(...channels: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(channels);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.Channel as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic override toJSON(): APIChannelSelectComponent {\n\t\tcustomIdValidator.parse(this.data.custom_id);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APIChannelSelectComponent;\n\t}\n}\n","import type { APISelectMenuComponent } from 'discord-api-types/v10';\nimport { customIdValidator, disabledValidator, minMaxValidator, placeholderValidator } from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\n\n/**\n * The base select menu builder that contains common symbols for select menu builders.\n *\n * @typeParam SelectMenuType - The type of select menu this would be instantiated for.\n */\nexport abstract class BaseSelectMenuBuilder<\n\tSelectMenuType extends APISelectMenuComponent,\n> extends ComponentBuilder {\n\t/**\n\t * Sets the placeholder for this select menu.\n\t *\n\t * @param placeholder - The placeholder to use\n\t */\n\tpublic setPlaceholder(placeholder: string) {\n\t\tthis.data.placeholder = placeholderValidator.parse(placeholder);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum values that must be selected in the select menu.\n\t *\n\t * @param minValues - The minimum values that must be selected\n\t */\n\tpublic setMinValues(minValues: number) {\n\t\tthis.data.min_values = minMaxValidator.parse(minValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the maximum values that must be selected in the select menu.\n\t *\n\t * @param maxValues - The maximum values that must be selected\n\t */\n\tpublic setMaxValues(maxValues: number) {\n\t\tthis.data.max_values = minMaxValidator.parse(maxValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id for this select menu.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this select menu is disabled.\n\t *\n\t * @param disabled - Whether this select menu is disabled\n\t */\n\tpublic setDisabled(disabled = true) {\n\t\tthis.data.disabled = disabledValidator.parse(disabled);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): SelectMenuType {\n\t\tcustomIdValidator.parse(this.data.custom_id);\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as SelectMenuType;\n\t}\n}\n","import {\n\ttype APIMentionableSelectComponent,\n\ttype APISelectMenuDefaultValue,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for mentionable select menus.\n */\nexport class MentionableSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new MentionableSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new MentionableSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.MentionableSelect });\n\t}\n\n\t/**\n\t * Adds default roles to this auto populated select menu.\n\t *\n\t * @param roles - The roles to add\n\t */\n\tpublic addDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default users to this auto populated select menu.\n\t *\n\t * @param users - The users to add\n\t */\n\tpublic addDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds default values to this auto populated select menu.\n\t *\n\t * @param values - The values to add\n\t */\n\tpublic addDefaultValues(\n\t\t...values: RestOrArray<\n\t\t\t| APISelectMenuDefaultValue\n\t\t\t| APISelectMenuDefaultValue\n\t\t>\n\t) {\n\t\tconst normalizedValues = normalizeArray(values);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\t\tthis.data.default_values.push(...normalizedValues);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default values for this auto populated select menu.\n\t *\n\t * @param values - The values to set\n\t */\n\tpublic setDefaultValues(\n\t\t...values: RestOrArray<\n\t\t\t| APISelectMenuDefaultValue\n\t\t\t| APISelectMenuDefaultValue\n\t\t>\n\t) {\n\t\tconst normalizedValues = normalizeArray(values);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\t\tthis.data.default_values = normalizedValues;\n\t\treturn this;\n\t}\n}\n","import {\n\ttype APIRoleSelectComponent,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for role select menus.\n */\nexport class RoleSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new RoleSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new RoleSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.RoleSelect });\n\t}\n\n\t/**\n\t * Adds default roles to this auto populated select menu.\n\t *\n\t * @param roles - The roles to add\n\t */\n\tpublic addDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default roles for this auto populated select menu.\n\t *\n\t * @param roles - The roles to set\n\t */\n\tpublic setDefaultRoles(...roles: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(roles);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.Role as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n}\n","import { ComponentType } from 'discord-api-types/v10';\nimport type { APIStringSelectComponent, APISelectMenuOption } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport { jsonOptionValidator, optionsLengthValidator, validateRequiredSelectMenuParameters } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\nimport { StringSelectMenuOptionBuilder } from './StringSelectMenuOption.js';\n\n/**\n * A builder that creates API-compatible JSON data for string select menus.\n */\nexport class StringSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * The options within this select menu.\n\t */\n\tpublic readonly options: StringSelectMenuOptionBuilder[];\n\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new StringSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * \toptions: [\n\t * \t\t{ label: 'option 1', value: '1' },\n\t * \t\t{ label: 'option 2', value: '2' },\n\t * \t\t{ label: 'option 3', value: '3' },\n\t * \t],\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new StringSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1)\n\t * \t.addOptions({\n\t * \t\tlabel: 'Catchy',\n\t * \t\tvalue: 'catch',\n\t * \t});\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tconst { options, ...initData } = data ?? {};\n\t\tsuper({ ...initData, type: ComponentType.StringSelect });\n\t\tthis.options = options?.map((option: APISelectMenuOption) => new StringSelectMenuOptionBuilder(option)) ?? [];\n\t}\n\n\t/**\n\t * Adds options to this select menu.\n\t *\n\t * @param options - The options to add\n\t */\n\tpublic addOptions(...options: RestOrArray) {\n\t\tconst normalizedOptions = normalizeArray(options);\n\t\toptionsLengthValidator.parse(this.options.length + normalizedOptions.length);\n\t\tthis.options.push(\n\t\t\t...normalizedOptions.map((normalizedOption) =>\n\t\t\t\tnormalizedOption instanceof StringSelectMenuOptionBuilder\n\t\t\t\t\t? normalizedOption\n\t\t\t\t\t: new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)),\n\t\t\t),\n\t\t);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the options for this select menu.\n\t *\n\t * @param options - The options to set\n\t */\n\tpublic setOptions(...options: RestOrArray) {\n\t\treturn this.spliceOptions(0, this.options.length, ...options);\n\t}\n\n\t/**\n\t * Removes, replaces, or inserts options for this select menu.\n\t *\n\t * @remarks\n\t * This method behaves similarly\n\t * to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice | Array.prototype.splice()}.\n\t * It's useful for modifying and adjusting the order of existing options.\n\t * @example\n\t * Remove the first option:\n\t * ```ts\n\t * selectMenu.spliceOptions(0, 1);\n\t * ```\n\t * @example\n\t * Remove the first n option:\n\t * ```ts\n\t * const n = 4;\n\t * selectMenu.spliceOptions(0, n);\n\t * ```\n\t * @example\n\t * Remove the last option:\n\t * ```ts\n\t * selectMenu.spliceOptions(-1, 1);\n\t * ```\n\t * @param index - The index to start at\n\t * @param deleteCount - The number of options to remove\n\t * @param options - The replacing option objects or builders\n\t */\n\tpublic spliceOptions(\n\t\tindex: number,\n\t\tdeleteCount: number,\n\t\t...options: RestOrArray\n\t) {\n\t\tconst normalizedOptions = normalizeArray(options);\n\n\t\tconst clone = [...this.options];\n\n\t\tclone.splice(\n\t\t\tindex,\n\t\t\tdeleteCount,\n\t\t\t...normalizedOptions.map((normalizedOption) =>\n\t\t\t\tnormalizedOption instanceof StringSelectMenuOptionBuilder\n\t\t\t\t\t? normalizedOption\n\t\t\t\t\t: new StringSelectMenuOptionBuilder(jsonOptionValidator.parse(normalizedOption)),\n\t\t\t),\n\t\t);\n\n\t\toptionsLengthValidator.parse(clone.length);\n\t\tthis.options.splice(0, this.options.length, ...clone);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc BaseSelectMenuBuilder.toJSON}\n\t */\n\tpublic override toJSON(): APIStringSelectComponent {\n\t\tvalidateRequiredSelectMenuParameters(this.options, this.data.custom_id);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t} as APIStringSelectComponent;\n\t}\n}\n","import {\n\ttype APIUserSelectComponent,\n\ttype Snowflake,\n\tComponentType,\n\tSelectMenuDefaultValueType,\n} from 'discord-api-types/v10';\nimport { type RestOrArray, normalizeArray } from '../../util/normalizeArray.js';\nimport { optionsLengthValidator } from '../Assertions.js';\nimport { BaseSelectMenuBuilder } from './BaseSelectMenu.js';\n\n/**\n * A builder that creates API-compatible JSON data for user select menus.\n */\nexport class UserSelectMenuBuilder extends BaseSelectMenuBuilder {\n\t/**\n\t * Creates a new select menu from API data.\n\t *\n\t * @param data - The API data to create this select menu with\n\t * @example\n\t * Creating a select menu from an API data object:\n\t * ```ts\n\t * const selectMenu = new UserSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tplaceholder: 'select an option',\n\t * \tmax_values: 2,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu using setters and API data:\n\t * ```ts\n\t * const selectMenu = new UserSelectMenuBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * })\n\t * \t.setMinValues(1);\n\t * ```\n\t */\n\tpublic constructor(data?: Partial) {\n\t\tsuper({ ...data, type: ComponentType.UserSelect });\n\t}\n\n\t/**\n\t * Adds default users to this auto populated select menu.\n\t *\n\t * @param users - The users to add\n\t */\n\tpublic addDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse((this.data.default_values?.length ?? 0) + normalizedValues.length);\n\t\tthis.data.default_values ??= [];\n\n\t\tthis.data.default_values.push(\n\t\t\t...normalizedValues.map((id) => ({\n\t\t\t\tid,\n\t\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t\t})),\n\t\t);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets default users for this auto populated select menu.\n\t *\n\t * @param users - The users to set\n\t */\n\tpublic setDefaultUsers(...users: RestOrArray) {\n\t\tconst normalizedValues = normalizeArray(users);\n\t\toptionsLengthValidator.parse(normalizedValues.length);\n\n\t\tthis.data.default_values = normalizedValues.map((id) => ({\n\t\t\tid,\n\t\t\ttype: SelectMenuDefaultValueType.User as const,\n\t\t}));\n\n\t\treturn this;\n\t}\n}\n","import { isJSONEncodable, type Equatable, type JSONEncodable } from '@discordjs/util';\nimport { ComponentType, type TextInputStyle, type APITextInputComponent } from 'discord-api-types/v10';\nimport isEqual from 'fast-deep-equal';\nimport { customIdValidator } from '../Assertions.js';\nimport { ComponentBuilder } from '../Component.js';\nimport {\n\tmaxLengthValidator,\n\tminLengthValidator,\n\tplaceholderValidator,\n\trequiredValidator,\n\tvalueValidator,\n\tvalidateRequiredParameters,\n\tlabelValidator,\n\ttextInputStyleValidator,\n} from './Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for text inputs.\n */\nexport class TextInputBuilder\n\textends ComponentBuilder\n\timplements Equatable>\n{\n\t/**\n\t * Creates a new text input from API data.\n\t *\n\t * @param data - The API data to create this text input with\n\t * @example\n\t * Creating a text input from an API data object:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tcustom_id: 'a cool text input',\n\t * \tlabel: 'Type something',\n\t * \tstyle: TextInputStyle.Short,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a text input using setters and API data:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tlabel: 'Type something else',\n\t * })\n\t * \t.setCustomId('woah')\n\t * \t.setStyle(TextInputStyle.Paragraph);\n\t * ```\n\t */\n\tpublic constructor(data?: APITextInputComponent & { type?: ComponentType.TextInput }) {\n\t\tsuper({ type: ComponentType.TextInput, ...data });\n\t}\n\n\t/**\n\t * Sets the custom id for this text input.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the label for this text input.\n\t *\n\t * @param label - The label to use\n\t */\n\tpublic setLabel(label: string) {\n\t\tthis.data.label = labelValidator.parse(label);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the style for this text input.\n\t *\n\t * @param style - The style to use\n\t */\n\tpublic setStyle(style: TextInputStyle) {\n\t\tthis.data.style = textInputStyleValidator.parse(style);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum length of text for this text input.\n\t *\n\t * @param minLength - The minimum length of text for this text input\n\t */\n\tpublic setMinLength(minLength: number) {\n\t\tthis.data.min_length = minLengthValidator.parse(minLength);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the maximum length of text for this text input.\n\t *\n\t * @param maxLength - The maximum length of text for this text input\n\t */\n\tpublic setMaxLength(maxLength: number) {\n\t\tthis.data.max_length = maxLengthValidator.parse(maxLength);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the placeholder for this text input.\n\t *\n\t * @param placeholder - The placeholder to use\n\t */\n\tpublic setPlaceholder(placeholder: string) {\n\t\tthis.data.placeholder = placeholderValidator.parse(placeholder);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the value for this text input.\n\t *\n\t * @param value - The value to use\n\t */\n\tpublic setValue(value: string) {\n\t\tthis.data.value = valueValidator.parse(value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this text input is required.\n\t *\n\t * @param required - Whether this text input is required\n\t */\n\tpublic setRequired(required = true) {\n\t\tthis.data.required = requiredValidator.parse(required);\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APITextInputComponent {\n\t\tvalidateRequiredParameters(this.data.custom_id, this.data.style, this.data.label);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t} as APITextInputComponent;\n\t}\n\n\t/**\n\t * Whether this is equal to another structure.\n\t */\n\tpublic equals(other: APITextInputComponent | JSONEncodable): boolean {\n\t\tif (isJSONEncodable(other)) {\n\t\t\treturn isEqual(other.toJSON(), this.data);\n\t\t}\n\n\t\treturn isEqual(other, this.data);\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { TextInputStyle } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport { customIdValidator } from '../Assertions.js';\n\nexport const textInputStyleValidator = s.nativeEnum(TextInputStyle);\nexport const minLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const maxLengthValidator = s\n\t.number()\n\t.int()\n\t.greaterThanOrEqual(1)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const requiredValidator = s.boolean();\nexport const valueValidator = s.string().lengthLessThanOrEqual(4_000).setValidationEnabled(isValidationEnabled);\nexport const placeholderValidator = s.string().lengthLessThanOrEqual(100).setValidationEnabled(isValidationEnabled);\nexport const labelValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredParameters(customId?: string, style?: TextInputStyle, label?: string) {\n\tcustomIdValidator.parse(customId);\n\ttextInputStyleValidator.parse(style);\n\tlabelValidator.parse(label);\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ActionRowBuilder, type ModalActionRowComponentBuilder } from '../../components/ActionRow.js';\nimport { customIdValidator } from '../../components/Assertions.js';\nimport { isValidationEnabled } from '../../util/validation.js';\n\nexport const titleValidator = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\nexport const componentsValidator = s\n\t.instance(ActionRowBuilder)\n\t.array()\n\t.lengthGreaterThanOrEqual(1)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateRequiredParameters(\n\tcustomId?: string,\n\ttitle?: string,\n\tcomponents?: ActionRowBuilder[],\n) {\n\tcustomIdValidator.parse(customId);\n\ttitleValidator.parse(title);\n\tcomponentsValidator.parse(components);\n}\n","/* eslint-disable jsdoc/check-param-names */\n\nimport type { JSONEncodable } from '@discordjs/util';\nimport type {\n\tAPIActionRowComponent,\n\tAPIModalActionRowComponent,\n\tAPIModalInteractionResponseCallbackData,\n} from 'discord-api-types/v10';\nimport { ActionRowBuilder, type ModalActionRowComponentBuilder } from '../../components/ActionRow.js';\nimport { customIdValidator } from '../../components/Assertions.js';\nimport { createComponentBuilder } from '../../components/Components.js';\nimport { normalizeArray, type RestOrArray } from '../../util/normalizeArray.js';\nimport { titleValidator, validateRequiredParameters } from './Assertions.js';\n\n/**\n * A builder that creates API-compatible JSON data for modals.\n */\nexport class ModalBuilder implements JSONEncodable {\n\t/**\n\t * The API data associated with this modal.\n\t */\n\tpublic readonly data: Partial;\n\n\t/**\n\t * The components within this modal.\n\t */\n\tpublic readonly components: ActionRowBuilder[] = [];\n\n\t/**\n\t * Creates a new modal from API data.\n\t *\n\t * @param data - The API data to create this modal with\n\t */\n\tpublic constructor({ components, ...data }: Partial = {}) {\n\t\tthis.data = { ...data };\n\t\tthis.components = (components?.map((component) => createComponentBuilder(component)) ??\n\t\t\t[]) as ActionRowBuilder[];\n\t}\n\n\t/**\n\t * Sets the title of this modal.\n\t *\n\t * @param title - The title to use\n\t */\n\tpublic setTitle(title: string) {\n\t\tthis.data.title = titleValidator.parse(title);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the custom id of this modal.\n\t *\n\t * @param customId - The custom id to use\n\t */\n\tpublic setCustomId(customId: string) {\n\t\tthis.data.custom_id = customIdValidator.parse(customId);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds components to this modal.\n\t *\n\t * @param components - The components to add\n\t */\n\tpublic addComponents(\n\t\t...components: RestOrArray<\n\t\t\tActionRowBuilder | APIActionRowComponent\n\t\t>\n\t) {\n\t\tthis.components.push(\n\t\t\t...normalizeArray(components).map((component) =>\n\t\t\t\tcomponent instanceof ActionRowBuilder\n\t\t\t\t\t? component\n\t\t\t\t\t: new ActionRowBuilder(component),\n\t\t\t),\n\t\t);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets components for this modal.\n\t *\n\t * @param components - The components to set\n\t */\n\tpublic setComponents(...components: RestOrArray>) {\n\t\tthis.components.splice(0, this.components.length, ...normalizeArray(components));\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ComponentBuilder.toJSON}\n\t */\n\tpublic toJSON(): APIModalInteractionResponseCallbackData {\n\t\tvalidateRequiredParameters(this.data.custom_id, this.data.title, this.components);\n\n\t\treturn {\n\t\t\t...this.data,\n\t\t\tcomponents: this.components.map((component) => component.toJSON()),\n\t\t} as APIModalInteractionResponseCallbackData;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport {\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocale,\n\ttype APIApplicationCommandOptionChoice,\n\ttype LocalizationMap,\n} from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ToAPIApplicationCommandOptions } from './SlashCommandBuilder.js';\nimport type { SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder } from './SlashCommandSubcommands.js';\nimport type { ApplicationCommandOptionBase } from './mixins/ApplicationCommandOptionBase.js';\n\nconst namePredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(32)\n\t.regex(/^[\\p{Ll}\\p{Lm}\\p{Lo}\\p{N}\\p{sc=Devanagari}\\p{sc=Thai}_-]+$/u)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateName(name: unknown): asserts name is string {\n\tnamePredicate.parse(name);\n}\n\nconst descriptionPredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(100)\n\t.setValidationEnabled(isValidationEnabled);\nconst localePredicate = s.nativeEnum(Locale);\n\nexport function validateDescription(description: unknown): asserts description is string {\n\tdescriptionPredicate.parse(description);\n}\n\nconst maxArrayLengthPredicate = s.unknown().array().lengthLessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\nexport function validateLocale(locale: unknown) {\n\treturn localePredicate.parse(locale);\n}\n\nexport function validateMaxOptionsLength(options: unknown): asserts options is ToAPIApplicationCommandOptions[] {\n\tmaxArrayLengthPredicate.parse(options);\n}\n\nexport function validateRequiredParameters(\n\tname: string,\n\tdescription: string,\n\toptions: ToAPIApplicationCommandOptions[],\n) {\n\t// Assert name matches all conditions\n\tvalidateName(name);\n\n\t// Assert description conditions\n\tvalidateDescription(description);\n\n\t// Assert options conditions\n\tvalidateMaxOptionsLength(options);\n}\n\nconst booleanPredicate = s.boolean();\n\nexport function validateDefaultPermission(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport function validateRequired(required: unknown): asserts required is boolean {\n\tbooleanPredicate.parse(required);\n}\n\nconst choicesLengthPredicate = s.number().lessThanOrEqual(25).setValidationEnabled(isValidationEnabled);\n\nexport function validateChoicesLength(amountAdding: number, choices?: APIApplicationCommandOptionChoice[]): void {\n\tchoicesLengthPredicate.parse((choices?.length ?? 0) + amountAdding);\n}\n\nexport function assertReturnOfBuilder<\n\tReturnType extends ApplicationCommandOptionBase | SlashCommandSubcommandBuilder | SlashCommandSubcommandGroupBuilder,\n>(input: unknown, ExpectedInstanceOf: new () => ReturnType): asserts input is ReturnType {\n\ts.instance(ExpectedInstanceOf).parse(input);\n}\n\nexport const localizationMapPredicate = s\n\t.object(Object.fromEntries(Object.values(Locale).map((locale) => [locale, s.string().nullish()])))\n\t.strict()\n\t.nullish()\n\t.setValidationEnabled(isValidationEnabled);\n\nexport function validateLocalizationMap(value: unknown): asserts value is LocalizationMap {\n\tlocalizationMapPredicate.parse(value);\n}\n\nconst dmPermissionPredicate = s.boolean().nullish();\n\nexport function validateDMPermission(value: unknown): asserts value is boolean | null | undefined {\n\tdmPermissionPredicate.parse(value);\n}\n\nconst memberPermissionPredicate = s\n\t.union([\n\t\ts.bigint().transform((value) => value.toString()),\n\t\ts\n\t\t\t.number()\n\t\t\t.safeInt()\n\t\t\t.transform((value) => value.toString()),\n\t\ts.string().regex(/^\\d+$/),\n\t])\n\t.nullish();\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n\nexport function validateNSFW(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport const contextsPredicate = s.array(\n\ts.nativeEnum(InteractionContextType).setValidationEnabled(isValidationEnabled),\n);\n\nexport const integrationTypesPredicate = s.array(\n\ts.nativeEnum(ApplicationIntegrationType).setValidationEnabled(isValidationEnabled),\n);\n","import type {\n\tAPIApplicationCommandOption,\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocalizationMap,\n\tPermissions,\n} from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { SharedNameAndDescription } from './mixins/NameAndDescription.js';\nimport { SharedSlashCommand } from './mixins/SharedSlashCommand.js';\nimport { SharedSlashCommandOptions } from './mixins/SharedSlashCommandOptions.js';\nimport { SharedSlashCommandSubcommands } from './mixins/SharedSubcommands.js';\n\n/**\n * A builder that creates API-compatible JSON data for slash commands.\n */\n@mix(SharedSlashCommandOptions, SharedNameAndDescription, SharedSlashCommandSubcommands, SharedSlashCommand)\nexport class SlashCommandBuilder {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The description of this command.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The description localizations of this command.\n\t */\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\t/**\n\t * The options of this command.\n\t */\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\t/**\n\t * The contexts for this command.\n\t */\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * Whether this command is enabled by default when the application is added to a guild.\n\t *\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The set of permissions represented as a bit set for the command.\n\t */\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * Indicates whether the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This property is only for global commands.\n\t * @deprecated\n\t * Use {@link SlashCommandBuilder.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The integration types for this command.\n\t */\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\t/**\n\t * Whether this command is NSFW.\n\t */\n\tpublic readonly nsfw: boolean | undefined = undefined;\n}\n\nexport interface SlashCommandBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions,\n\t\tSharedSlashCommandSubcommands,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface specifically for slash command subcommands.\n */\nexport interface SlashCommandSubcommandsOnlyBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandSubcommands,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface specifically for slash command options.\n */\nexport interface SlashCommandOptionsOnlyBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions,\n\t\tSharedSlashCommand {}\n\n/**\n * An interface that ensures the `toJSON()` call will return something\n * that can be serialized into API-compatible data.\n */\nexport interface ToAPIApplicationCommandOptions {\n\ttoJSON(): APIApplicationCommandOption;\n}\n","import type { LocaleString, LocalizationMap } from 'discord-api-types/v10';\nimport { validateDescription, validateLocale, validateName } from '../Assertions.js';\n\n/**\n * This mixin holds name and description symbols for slash commands.\n */\nexport class SharedNameAndDescription {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name!: string;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The description of this command.\n\t */\n\tpublic readonly description!: string;\n\n\t/**\n\t * The description localizations of this command.\n\t */\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\t/**\n\t * Sets the name of this command.\n\t *\n\t * @param name - The name to use\n\t */\n\tpublic setName(name: string): this {\n\t\t// Assert the name matches the conditions\n\t\tvalidateName(name);\n\n\t\tReflect.set(this, 'name', name);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description of this command.\n\t *\n\t * @param description - The description to use\n\t */\n\tpublic setDescription(description: string) {\n\t\t// Assert the description matches the conditions\n\t\tvalidateDescription(description);\n\n\t\tReflect.set(this, 'description', description);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a name localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedName - The localized name for the given `locale`\n\t */\n\tpublic setNameLocalization(locale: LocaleString, localizedName: string | null) {\n\t\tif (!this.name_localizations) {\n\t\t\tReflect.set(this, 'name_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedName === null) {\n\t\t\tthis.name_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateName(localizedName);\n\n\t\tthis.name_localizations![parsedLocale] = localizedName;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name localizations for this command.\n\t *\n\t * @param localizedNames - The object of localized names to set\n\t */\n\tpublic setNameLocalizations(localizedNames: LocalizationMap | null) {\n\t\tif (localizedNames === null) {\n\t\t\tReflect.set(this, 'name_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'name_localizations', {});\n\n\t\tfor (const args of Object.entries(localizedNames)) {\n\t\t\tthis.setNameLocalization(...(args as [LocaleString, string | null]));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a description localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedDescription - The localized description for the given locale\n\t */\n\tpublic setDescriptionLocalization(locale: LocaleString, localizedDescription: string | null) {\n\t\tif (!this.description_localizations) {\n\t\t\tReflect.set(this, 'description_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedDescription === null) {\n\t\t\tthis.description_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateDescription(localizedDescription);\n\n\t\tthis.description_localizations![parsedLocale] = localizedDescription;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the description localizations for this command.\n\t *\n\t * @param localizedDescriptions - The object of localized descriptions to set\n\t */\n\tpublic setDescriptionLocalizations(localizedDescriptions: LocalizationMap | null) {\n\t\tif (localizedDescriptions === null) {\n\t\t\tReflect.set(this, 'description_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'description_localizations', {});\n\t\tfor (const args of Object.entries(localizedDescriptions)) {\n\t\t\tthis.setDescriptionLocalization(...(args as [LocaleString, string | null]));\n\t\t}\n\n\t\treturn this;\n\t}\n}\n","import {\n\tApplicationCommandType,\n\ttype ApplicationIntegrationType,\n\ttype InteractionContextType,\n\ttype LocalizationMap,\n\ttype Permissions,\n\ttype RESTPostAPIChatInputApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport type { RestOrArray } from '../../../util/normalizeArray.js';\nimport { normalizeArray } from '../../../util/normalizeArray.js';\nimport {\n\tcontextsPredicate,\n\tintegrationTypesPredicate,\n\tvalidateDMPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDefaultPermission,\n\tvalidateLocalizationMap,\n\tvalidateNSFW,\n\tvalidateRequiredParameters,\n} from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder.js';\n\n/**\n * This mixin holds symbols that can be shared in slashcommands independent of options or subcommands.\n */\nexport class SharedSlashCommand {\n\tpublic readonly name: string = undefined!;\n\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\tpublic readonly description: string = undefined!;\n\n\tpublic readonly description_localizations?: LocalizationMap;\n\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * @deprecated Use {@link SharedSlashCommand.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\tpublic readonly nsfw: boolean | undefined = undefined;\n\n\t/**\n\t * Sets the contexts of this command.\n\t *\n\t * @param contexts - The contexts\n\t */\n\tpublic setContexts(...contexts: RestOrArray) {\n\t\tReflect.set(this, 'contexts', contextsPredicate.parse(normalizeArray(contexts)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the integration types of this command.\n\t *\n\t * @param integrationTypes - The integration types\n\t */\n\tpublic setIntegrationTypes(...integrationTypes: RestOrArray) {\n\t\tReflect.set(this, 'integration_types', integrationTypesPredicate.parse(normalizeArray(integrationTypes)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether the command is enabled by default when the application is added to a guild.\n\t *\n\t * @remarks\n\t * If set to `false`, you will have to later `PUT` the permissions for this command.\n\t * @param value - Whether or not to enable this command by default\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link SharedSlashCommand.setDefaultMemberPermissions} or {@link SharedSlashCommand.setDMPermission} instead.\n\t */\n\tpublic setDefaultPermission(value: boolean) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDefaultPermission(value);\n\n\t\tReflect.set(this, 'default_permission', value);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the default permissions a member should have in order to run the command.\n\t *\n\t * @remarks\n\t * You can set this to `'0'` to disable the command by default.\n\t * @param permissions - The permissions bit field to set\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t */\n\tpublic setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined) {\n\t\t// Assert the value and parse it\n\t\tconst permissionValue = validateDefaultMemberPermissions(permissions);\n\n\t\tReflect.set(this, 'default_member_permissions', permissionValue);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets if the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This method is only for global commands.\n\t * @param enabled - Whether the command should be enabled in direct messages\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated\n\t * Use {@link SharedSlashCommand.setContexts} instead.\n\t */\n\tpublic setDMPermission(enabled: boolean | null | undefined) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDMPermission(enabled);\n\n\t\tReflect.set(this, 'dm_permission', enabled);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether this command is NSFW.\n\t *\n\t * @param nsfw - Whether this command is NSFW\n\t */\n\tpublic setNSFW(nsfw = true) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateNSFW(nsfw);\n\t\tReflect.set(this, 'nsfw', nsfw);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): RESTPostAPIChatInputApplicationCommandsJSONBody {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\tvalidateLocalizationMap(this.name_localizations);\n\t\tvalidateLocalizationMap(this.description_localizations);\n\n\t\treturn {\n\t\t\t...this,\n\t\t\ttype: ApplicationCommandType.ChatInput,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandAttachmentOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command attachment option.\n */\nexport class SlashCommandAttachmentOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Attachment as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandAttachmentOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import type { APIApplicationCommandBasicOption, ApplicationCommandOptionType } from 'discord-api-types/v10';\nimport { validateRequiredParameters, validateRequired, validateLocalizationMap } from '../Assertions.js';\nimport { SharedNameAndDescription } from './NameAndDescription.js';\n\n/**\n * The base application command option builder that contains common symbols for application command builders.\n */\nexport abstract class ApplicationCommandOptionBase extends SharedNameAndDescription {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic abstract readonly type: ApplicationCommandOptionType;\n\n\t/**\n\t * Whether this option is required.\n\t *\n\t * @defaultValue `false`\n\t */\n\tpublic readonly required: boolean = false;\n\n\t/**\n\t * Sets whether this option is required.\n\t *\n\t * @param required - Whether this option should be required\n\t */\n\tpublic setRequired(required: boolean) {\n\t\t// Assert that you actually passed a boolean\n\t\tvalidateRequired(required);\n\n\t\tReflect.set(this, 'required', required);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic abstract toJSON(): APIApplicationCommandBasicOption;\n\n\t/**\n\t * This method runs required validators on this builder.\n\t */\n\tprotected runRequiredValidations() {\n\t\tvalidateRequiredParameters(this.name, this.description, []);\n\n\t\t// Validate localizations\n\t\tvalidateLocalizationMap(this.name_localizations);\n\t\tvalidateLocalizationMap(this.description_localizations);\n\n\t\t// Assert that you actually passed a boolean\n\t\tvalidateRequired(this.required);\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandBooleanOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command boolean option.\n */\nexport class SlashCommandBooleanOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Boolean as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandBooleanOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandChannelOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionChannelTypesMixin } from '../mixins/ApplicationCommandOptionChannelTypesMixin.js';\n\n/**\n * A slash command channel option.\n */\n@mix(ApplicationCommandOptionChannelTypesMixin)\nexport class SlashCommandChannelOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Channel as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandChannelOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n\nexport interface SlashCommandChannelOption extends ApplicationCommandOptionChannelTypesMixin {}\n","import { s } from '@sapphire/shapeshift';\nimport { ChannelType } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../../util/normalizeArray';\n\n/**\n * The allowed channel types used for a channel option in a slash command builder.\n *\n * @privateRemarks This can't be dynamic because const enums are erased at runtime.\n * @internal\n */\nconst allowedChannelTypes = [\n\tChannelType.GuildText,\n\tChannelType.GuildVoice,\n\tChannelType.GuildCategory,\n\tChannelType.GuildAnnouncement,\n\tChannelType.AnnouncementThread,\n\tChannelType.PublicThread,\n\tChannelType.PrivateThread,\n\tChannelType.GuildStageVoice,\n\tChannelType.GuildForum,\n\tChannelType.GuildMedia,\n] as const;\n\n/**\n * The type of allowed channel types used for a channel option.\n */\nexport type ApplicationCommandOptionAllowedChannelTypes = (typeof allowedChannelTypes)[number];\n\nconst channelTypesPredicate = s.array(s.union(allowedChannelTypes.map((type) => s.literal(type))));\n\n/**\n * This mixin holds channel type symbols used for options.\n */\nexport class ApplicationCommandOptionChannelTypesMixin {\n\t/**\n\t * The channel types of this option.\n\t */\n\tpublic readonly channel_types?: ApplicationCommandOptionAllowedChannelTypes[];\n\n\t/**\n\t * Adds channel types to this option.\n\t *\n\t * @param channelTypes - The channel types\n\t */\n\tpublic addChannelTypes(...channelTypes: RestOrArray) {\n\t\tif (this.channel_types === undefined) {\n\t\t\tReflect.set(this, 'channel_types', []);\n\t\t}\n\n\t\tthis.channel_types!.push(...channelTypesPredicate.parse(normalizeArray(channelTypes)));\n\n\t\treturn this;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandIntegerOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandNumericOptionMinMaxValueMixin } from '../mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst numberValidator = s.number().int();\n\n/**\n * A slash command integer option.\n */\n@mix(\n\tApplicationCommandNumericOptionMinMaxValueMixin,\n\tApplicationCommandOptionWithAutocompleteMixin,\n\tApplicationCommandOptionWithChoicesMixin,\n)\nexport class SlashCommandIntegerOption\n\textends ApplicationCommandOptionBase\n\timplements ApplicationCommandNumericOptionMinMaxValueMixin\n{\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Integer as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue}\n\t */\n\tpublic setMaxValue(max: number): this {\n\t\tnumberValidator.parse(max);\n\n\t\tReflect.set(this, 'max_value', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue}\n\t */\n\tpublic setMinValue(min: number): this {\n\t\tnumberValidator.parse(min);\n\n\t\tReflect.set(this, 'min_value', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandIntegerOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandIntegerOption;\n\t}\n}\n\nexport interface SlashCommandIntegerOption\n\textends ApplicationCommandNumericOptionMinMaxValueMixin,\n\t\tApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","/**\n * This mixin holds minimum and maximum symbols used for options.\n */\nexport abstract class ApplicationCommandNumericOptionMinMaxValueMixin {\n\t/**\n\t * The maximum value of this option.\n\t */\n\tpublic readonly max_value?: number;\n\n\t/**\n\t * The minimum value of this option.\n\t */\n\tpublic readonly min_value?: number;\n\n\t/**\n\t * Sets the maximum number value of this option.\n\t *\n\t * @param max - The maximum value this option can be\n\t */\n\tpublic abstract setMaxValue(max: number): this;\n\n\t/**\n\t * Sets the minimum number value of this option.\n\t *\n\t * @param min - The minimum value this option can be\n\t */\n\tpublic abstract setMinValue(min: number): this;\n}\n","import { s } from '@sapphire/shapeshift';\nimport type { ApplicationCommandOptionType } from 'discord-api-types/v10';\n\nconst booleanPredicate = s.boolean();\n\n/**\n * This mixin holds choices and autocomplete symbols used for options.\n */\nexport class ApplicationCommandOptionWithAutocompleteMixin {\n\t/**\n\t * Whether this option utilizes autocomplete.\n\t */\n\tpublic readonly autocomplete?: boolean;\n\n\t/**\n\t * The type of this option.\n\t *\n\t * @privateRemarks Since this is present and this is a mixin, this is needed.\n\t */\n\tpublic readonly type!: ApplicationCommandOptionType;\n\n\t/**\n\t * Whether this option uses autocomplete.\n\t *\n\t * @param autocomplete - Whether this option should use autocomplete\n\t */\n\tpublic setAutocomplete(autocomplete: boolean): this {\n\t\t// Assert that you actually passed a boolean\n\t\tbooleanPredicate.parse(autocomplete);\n\n\t\tif (autocomplete && 'choices' in this && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tReflect.set(this, 'autocomplete', autocomplete);\n\n\t\treturn this;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandOptionChoice } from 'discord-api-types/v10';\nimport { normalizeArray, type RestOrArray } from '../../../util/normalizeArray.js';\nimport { localizationMapPredicate, validateChoicesLength } from '../Assertions.js';\n\nconst stringPredicate = s.string().lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(100);\nconst numberPredicate = s.number().greaterThan(Number.NEGATIVE_INFINITY).lessThan(Number.POSITIVE_INFINITY);\nconst choicesPredicate = s\n\t.object({\n\t\tname: stringPredicate,\n\t\tname_localizations: localizationMapPredicate,\n\t\tvalue: s.union([stringPredicate, numberPredicate]),\n\t})\n\t.array();\n\n/**\n * This mixin holds choices and autocomplete symbols used for options.\n */\nexport class ApplicationCommandOptionWithChoicesMixin {\n\t/**\n\t * The choices of this option.\n\t */\n\tpublic readonly choices?: APIApplicationCommandOptionChoice[];\n\n\t/**\n\t * The type of this option.\n\t *\n\t * @privateRemarks Since this is present and this is a mixin, this is needed.\n\t */\n\tpublic readonly type!: ApplicationCommandOptionType;\n\n\t/**\n\t * Adds multiple choices to this option.\n\t *\n\t * @param choices - The choices to add\n\t */\n\tpublic addChoices(...choices: RestOrArray>): this {\n\t\tconst normalizedChoices = normalizeArray(choices);\n\t\tif (normalizedChoices.length > 0 && 'autocomplete' in this && this.autocomplete) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tchoicesPredicate.parse(normalizedChoices);\n\n\t\tif (this.choices === undefined) {\n\t\t\tReflect.set(this, 'choices', []);\n\t\t}\n\n\t\tvalidateChoicesLength(normalizedChoices.length, this.choices);\n\n\t\tfor (const { name, name_localizations, value } of normalizedChoices) {\n\t\t\t// Validate the value\n\t\t\tif (this.type === ApplicationCommandOptionType.String) {\n\t\t\t\tstringPredicate.parse(value);\n\t\t\t} else {\n\t\t\t\tnumberPredicate.parse(value);\n\t\t\t}\n\n\t\t\tthis.choices!.push({ name, name_localizations, value });\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets multiple choices for this option.\n\t *\n\t * @param choices - The choices to set\n\t */\n\tpublic setChoices>(...choices: RestOrArray): this {\n\t\tconst normalizedChoices = normalizeArray(choices);\n\t\tif (normalizedChoices.length > 0 && 'autocomplete' in this && this.autocomplete) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\tchoicesPredicate.parse(normalizedChoices);\n\n\t\tReflect.set(this, 'choices', []);\n\t\tthis.addChoices(normalizedChoices);\n\n\t\treturn this;\n\t}\n}\n","import { ApplicationCommandOptionType, type APIApplicationCommandMentionableOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command mentionable option.\n */\nexport class SlashCommandMentionableOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Mentionable as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandMentionableOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandNumberOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandNumericOptionMinMaxValueMixin } from '../mixins/ApplicationCommandNumericOptionMinMaxValueMixin.js';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst numberValidator = s.number();\n\n/**\n * A slash command number option.\n */\n@mix(\n\tApplicationCommandNumericOptionMinMaxValueMixin,\n\tApplicationCommandOptionWithAutocompleteMixin,\n\tApplicationCommandOptionWithChoicesMixin,\n)\nexport class SlashCommandNumberOption\n\textends ApplicationCommandOptionBase\n\timplements ApplicationCommandNumericOptionMinMaxValueMixin\n{\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.Number as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMaxValue}\n\t */\n\tpublic setMaxValue(max: number): this {\n\t\tnumberValidator.parse(max);\n\n\t\tReflect.set(this, 'max_value', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandNumericOptionMinMaxValueMixin.setMinValue}\n\t */\n\tpublic setMinValue(min: number): this {\n\t\tnumberValidator.parse(min);\n\n\t\tReflect.set(this, 'min_value', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandNumberOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandNumberOption;\n\t}\n}\n\nexport interface SlashCommandNumberOption\n\textends ApplicationCommandNumericOptionMinMaxValueMixin,\n\t\tApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","import { ApplicationCommandOptionType, type APIApplicationCommandRoleOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command role option.\n */\nexport class SlashCommandRoleOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic override readonly type = ApplicationCommandOptionType.Role as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandRoleOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandOptionType, type APIApplicationCommandStringOption } from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\nimport { ApplicationCommandOptionWithAutocompleteMixin } from '../mixins/ApplicationCommandOptionWithAutocompleteMixin.js';\nimport { ApplicationCommandOptionWithChoicesMixin } from '../mixins/ApplicationCommandOptionWithChoicesMixin.js';\n\nconst minLengthValidator = s.number().greaterThanOrEqual(0).lessThanOrEqual(6_000);\nconst maxLengthValidator = s.number().greaterThanOrEqual(1).lessThanOrEqual(6_000);\n\n/**\n * A slash command string option.\n */\n@mix(ApplicationCommandOptionWithAutocompleteMixin, ApplicationCommandOptionWithChoicesMixin)\nexport class SlashCommandStringOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.String as const;\n\n\t/**\n\t * The maximum length of this option.\n\t */\n\tpublic readonly max_length?: number;\n\n\t/**\n\t * The minimum length of this option.\n\t */\n\tpublic readonly min_length?: number;\n\n\t/**\n\t * Sets the maximum length of this string option.\n\t *\n\t * @param max - The maximum length this option can be\n\t */\n\tpublic setMaxLength(max: number): this {\n\t\tmaxLengthValidator.parse(max);\n\n\t\tReflect.set(this, 'max_length', max);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the minimum length of this string option.\n\t *\n\t * @param min - The minimum length this option can be\n\t */\n\tpublic setMinLength(min: number): this {\n\t\tminLengthValidator.parse(min);\n\n\t\tReflect.set(this, 'min_length', min);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandStringOption {\n\t\tthis.runRequiredValidations();\n\n\t\tif (this.autocomplete && Array.isArray(this.choices) && this.choices.length > 0) {\n\t\t\tthrow new RangeError('Autocomplete and choices are mutually exclusive to each other.');\n\t\t}\n\n\t\treturn { ...this } as APIApplicationCommandStringOption;\n\t}\n}\n\nexport interface SlashCommandStringOption\n\textends ApplicationCommandOptionWithChoicesMixin,\n\t\tApplicationCommandOptionWithAutocompleteMixin {}\n","import { ApplicationCommandOptionType, type APIApplicationCommandUserOption } from 'discord-api-types/v10';\nimport { ApplicationCommandOptionBase } from '../mixins/ApplicationCommandOptionBase.js';\n\n/**\n * A slash command user option.\n */\nexport class SlashCommandUserOption extends ApplicationCommandOptionBase {\n\t/**\n\t * The type of this option.\n\t */\n\tpublic readonly type = ApplicationCommandOptionType.User as const;\n\n\t/**\n\t * {@inheritDoc ApplicationCommandOptionBase.toJSON}\n\t */\n\tpublic toJSON(): APIApplicationCommandUserOption {\n\t\tthis.runRequiredValidations();\n\n\t\treturn { ...this };\n\t}\n}\n","import { assertReturnOfBuilder, validateMaxOptionsLength } from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder';\nimport { SlashCommandAttachmentOption } from '../options/attachment.js';\nimport { SlashCommandBooleanOption } from '../options/boolean.js';\nimport { SlashCommandChannelOption } from '../options/channel.js';\nimport { SlashCommandIntegerOption } from '../options/integer.js';\nimport { SlashCommandMentionableOption } from '../options/mentionable.js';\nimport { SlashCommandNumberOption } from '../options/number.js';\nimport { SlashCommandRoleOption } from '../options/role.js';\nimport { SlashCommandStringOption } from '../options/string.js';\nimport { SlashCommandUserOption } from '../options/user.js';\nimport type { ApplicationCommandOptionBase } from './ApplicationCommandOptionBase.js';\n\n/**\n * This mixin holds symbols that can be shared in slash command options.\n *\n * @typeParam TypeAfterAddingOptions - The type this class should return after adding an option.\n */\nexport class SharedSlashCommandOptions<\n\tTypeAfterAddingOptions extends SharedSlashCommandOptions,\n> {\n\tpublic readonly options!: ToAPIApplicationCommandOptions[];\n\n\t/**\n\t * Adds a boolean option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addBooleanOption(\n\t\tinput: SlashCommandBooleanOption | ((builder: SlashCommandBooleanOption) => SlashCommandBooleanOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandBooleanOption);\n\t}\n\n\t/**\n\t * Adds a user option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addUserOption(input: SlashCommandUserOption | ((builder: SlashCommandUserOption) => SlashCommandUserOption)) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandUserOption);\n\t}\n\n\t/**\n\t * Adds a channel option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addChannelOption(\n\t\tinput: SlashCommandChannelOption | ((builder: SlashCommandChannelOption) => SlashCommandChannelOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandChannelOption);\n\t}\n\n\t/**\n\t * Adds a role option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addRoleOption(input: SlashCommandRoleOption | ((builder: SlashCommandRoleOption) => SlashCommandRoleOption)) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandRoleOption);\n\t}\n\n\t/**\n\t * Adds an attachment option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addAttachmentOption(\n\t\tinput: SlashCommandAttachmentOption | ((builder: SlashCommandAttachmentOption) => SlashCommandAttachmentOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandAttachmentOption);\n\t}\n\n\t/**\n\t * Adds a mentionable option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addMentionableOption(\n\t\tinput: SlashCommandMentionableOption | ((builder: SlashCommandMentionableOption) => SlashCommandMentionableOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandMentionableOption);\n\t}\n\n\t/**\n\t * Adds a string option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addStringOption(\n\t\tinput: SlashCommandStringOption | ((builder: SlashCommandStringOption) => SlashCommandStringOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandStringOption);\n\t}\n\n\t/**\n\t * Adds an integer option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addIntegerOption(\n\t\tinput: SlashCommandIntegerOption | ((builder: SlashCommandIntegerOption) => SlashCommandIntegerOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandIntegerOption);\n\t}\n\n\t/**\n\t * Adds a number option.\n\t *\n\t * @param input - A function that returns an option builder or an already built builder\n\t */\n\tpublic addNumberOption(\n\t\tinput: SlashCommandNumberOption | ((builder: SlashCommandNumberOption) => SlashCommandNumberOption),\n\t) {\n\t\treturn this._sharedAddOptionMethod(input, SlashCommandNumberOption);\n\t}\n\n\t/**\n\t * Where the actual adding magic happens. ✨\n\t *\n\t * @param input - The input. What else?\n\t * @param Instance - The instance of whatever is being added\n\t * @internal\n\t */\n\tprivate _sharedAddOptionMethod(\n\t\tinput: OptionBuilder | ((builder: OptionBuilder) => OptionBuilder),\n\t\tInstance: new () => OptionBuilder,\n\t): TypeAfterAddingOptions {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new Instance()) : input;\n\n\t\tassertReturnOfBuilder(result, Instance);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingOptions;\n\t}\n}\n","import {\n\tApplicationCommandOptionType,\n\ttype APIApplicationCommandSubcommandGroupOption,\n\ttype APIApplicationCommandSubcommandOption,\n} from 'discord-api-types/v10';\nimport { mix } from 'ts-mixer';\nimport { assertReturnOfBuilder, validateMaxOptionsLength, validateRequiredParameters } from './Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from './SlashCommandBuilder.js';\nimport type { ApplicationCommandOptionBase } from './mixins/ApplicationCommandOptionBase.js';\nimport { SharedNameAndDescription } from './mixins/NameAndDescription.js';\nimport { SharedSlashCommandOptions } from './mixins/SharedSlashCommandOptions.js';\n\n/**\n * Represents a folder for subcommands.\n *\n * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups}\n */\n@mix(SharedNameAndDescription)\nexport class SlashCommandSubcommandGroupBuilder implements ToAPIApplicationCommandOptions {\n\t/**\n\t * The name of this subcommand group.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The description of this subcommand group.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The subcommands within this subcommand group.\n\t */\n\tpublic readonly options: SlashCommandSubcommandBuilder[] = [];\n\n\t/**\n\t * Adds a new subcommand to this group.\n\t *\n\t * @param input - A function that returns a subcommand builder or an already built builder\n\t */\n\tpublic addSubcommand(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder),\n\t) {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandBuilder()) : input;\n\n\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIApplicationCommandSubcommandGroupOption {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\treturn {\n\t\t\ttype: ApplicationCommandOptionType.SubcommandGroup,\n\t\t\tname: this.name,\n\t\t\tname_localizations: this.name_localizations,\n\t\t\tdescription: this.description,\n\t\t\tdescription_localizations: this.description_localizations,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n\nexport interface SlashCommandSubcommandGroupBuilder extends SharedNameAndDescription {}\n\n/**\n * A builder that creates API-compatible JSON data for slash command subcommands.\n *\n * @see {@link https://discord.com/developers/docs/interactions/application-commands#subcommands-and-subcommand-groups}\n */\n@mix(SharedNameAndDescription, SharedSlashCommandOptions)\nexport class SlashCommandSubcommandBuilder implements ToAPIApplicationCommandOptions {\n\t/**\n\t * The name of this subcommand.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The description of this subcommand.\n\t */\n\tpublic readonly description: string = undefined!;\n\n\t/**\n\t * The options within this subcommand.\n\t */\n\tpublic readonly options: ApplicationCommandOptionBase[] = [];\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): APIApplicationCommandSubcommandOption {\n\t\tvalidateRequiredParameters(this.name, this.description, this.options);\n\n\t\treturn {\n\t\t\ttype: ApplicationCommandOptionType.Subcommand,\n\t\t\tname: this.name,\n\t\t\tname_localizations: this.name_localizations,\n\t\t\tdescription: this.description,\n\t\t\tdescription_localizations: this.description_localizations,\n\t\t\toptions: this.options.map((option) => option.toJSON()),\n\t\t};\n\t}\n}\n\nexport interface SlashCommandSubcommandBuilder\n\textends SharedNameAndDescription,\n\t\tSharedSlashCommandOptions {}\n","import { assertReturnOfBuilder, validateMaxOptionsLength } from '../Assertions.js';\nimport type { ToAPIApplicationCommandOptions } from '../SlashCommandBuilder.js';\nimport { SlashCommandSubcommandBuilder, SlashCommandSubcommandGroupBuilder } from '../SlashCommandSubcommands.js';\n\n/**\n * This mixin holds symbols that can be shared in slash subcommands.\n *\n * @typeParam TypeAfterAddingSubcommands - The type this class should return after adding a subcommand or subcommand group.\n */\nexport class SharedSlashCommandSubcommands<\n\tTypeAfterAddingSubcommands extends SharedSlashCommandSubcommands,\n> {\n\tpublic readonly options: ToAPIApplicationCommandOptions[] = [];\n\n\t/**\n\t * Adds a new subcommand group to this command.\n\t *\n\t * @param input - A function that returns a subcommand group builder or an already built builder\n\t */\n\tpublic addSubcommandGroup(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandGroupBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandGroupBuilder) => SlashCommandSubcommandGroupBuilder),\n\t): TypeAfterAddingSubcommands {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandGroupBuilder()) : input;\n\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandGroupBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingSubcommands;\n\t}\n\n\t/**\n\t * Adds a new subcommand to this command.\n\t *\n\t * @param input - A function that returns a subcommand builder or an already built builder\n\t */\n\tpublic addSubcommand(\n\t\tinput:\n\t\t\t| SlashCommandSubcommandBuilder\n\t\t\t| ((subcommandGroup: SlashCommandSubcommandBuilder) => SlashCommandSubcommandBuilder),\n\t): TypeAfterAddingSubcommands {\n\t\tconst { options } = this;\n\n\t\t// First, assert options conditions - we cannot have more than 25 options\n\t\tvalidateMaxOptionsLength(options);\n\n\t\t// Get the final result\n\t\tconst result = typeof input === 'function' ? input(new SlashCommandSubcommandBuilder()) : input;\n\n\t\tassertReturnOfBuilder(result, SlashCommandSubcommandBuilder);\n\n\t\t// Push it\n\t\toptions.push(result);\n\n\t\treturn this as unknown as TypeAfterAddingSubcommands;\n\t}\n}\n","import { s } from '@sapphire/shapeshift';\nimport { ApplicationCommandType, ApplicationIntegrationType, InteractionContextType } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ContextMenuCommandType } from './ContextMenuCommandBuilder.js';\n\nconst namePredicate = s\n\t.string()\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(32)\n\t// eslint-disable-next-line prefer-named-capture-group\n\t.regex(/^( *[\\p{P}\\p{L}\\p{N}\\p{sc=Devanagari}\\p{sc=Thai}]+ *)+$/u)\n\t.setValidationEnabled(isValidationEnabled);\nconst typePredicate = s\n\t.union([s.literal(ApplicationCommandType.User), s.literal(ApplicationCommandType.Message)])\n\t.setValidationEnabled(isValidationEnabled);\nconst booleanPredicate = s.boolean();\n\nexport function validateDefaultPermission(value: unknown): asserts value is boolean {\n\tbooleanPredicate.parse(value);\n}\n\nexport function validateName(name: unknown): asserts name is string {\n\tnamePredicate.parse(name);\n}\n\nexport function validateType(type: unknown): asserts type is ContextMenuCommandType {\n\ttypePredicate.parse(type);\n}\n\nexport function validateRequiredParameters(name: string, type: number) {\n\t// Assert name matches all conditions\n\tvalidateName(name);\n\n\t// Assert type is valid\n\tvalidateType(type);\n}\n\nconst dmPermissionPredicate = s.boolean().nullish();\n\nexport function validateDMPermission(value: unknown): asserts value is boolean | null | undefined {\n\tdmPermissionPredicate.parse(value);\n}\n\nconst memberPermissionPredicate = s\n\t.union([\n\t\ts.bigint().transform((value) => value.toString()),\n\t\ts\n\t\t\t.number()\n\t\t\t.safeInt()\n\t\t\t.transform((value) => value.toString()),\n\t\ts.string().regex(/^\\d+$/),\n\t])\n\t.nullish();\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n\nexport const contextsPredicate = s.array(\n\ts.nativeEnum(InteractionContextType).setValidationEnabled(isValidationEnabled),\n);\n\nexport const integrationTypesPredicate = s.array(\n\ts.nativeEnum(ApplicationIntegrationType).setValidationEnabled(isValidationEnabled),\n);\n","import type {\n\tApplicationCommandType,\n\tApplicationIntegrationType,\n\tInteractionContextType,\n\tLocaleString,\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIContextMenuApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport type { RestOrArray } from '../../util/normalizeArray.js';\nimport { normalizeArray } from '../../util/normalizeArray.js';\nimport { validateLocale, validateLocalizationMap } from '../slashCommands/Assertions.js';\nimport {\n\tvalidateRequiredParameters,\n\tvalidateName,\n\tvalidateType,\n\tvalidateDefaultPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDMPermission,\n\tcontextsPredicate,\n\tintegrationTypesPredicate,\n} from './Assertions.js';\n\n/**\n * The type a context menu command can be.\n */\nexport type ContextMenuCommandType = ApplicationCommandType.Message | ApplicationCommandType.User;\n\n/**\n * A builder that creates API-compatible JSON data for context menu commands.\n */\nexport class ContextMenuCommandBuilder {\n\t/**\n\t * The name of this command.\n\t */\n\tpublic readonly name: string = undefined!;\n\n\t/**\n\t * The name localizations of this command.\n\t */\n\tpublic readonly name_localizations?: LocalizationMap;\n\n\t/**\n\t * The type of this command.\n\t */\n\tpublic readonly type: ContextMenuCommandType = undefined!;\n\n\t/**\n\t * The contexts for this command.\n\t */\n\tpublic readonly contexts?: InteractionContextType[];\n\n\t/**\n\t * Whether this command is enabled by default when the application is added to a guild.\n\t *\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead.\n\t */\n\tpublic readonly default_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The set of permissions represented as a bit set for the command.\n\t */\n\tpublic readonly default_member_permissions: Permissions | null | undefined = undefined;\n\n\t/**\n\t * Indicates whether the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This property is only for global commands.\n\t * @deprecated\n\t * Use {@link ContextMenuCommandBuilder.contexts} instead.\n\t */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\n\n\t/**\n\t * The integration types for this command.\n\t */\n\tpublic readonly integration_types?: ApplicationIntegrationType[];\n\n\t/**\n\t * Sets the contexts of this command.\n\t *\n\t * @param contexts - The contexts\n\t */\n\tpublic setContexts(...contexts: RestOrArray) {\n\t\tReflect.set(this, 'contexts', contextsPredicate.parse(normalizeArray(contexts)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets integration types of this command.\n\t *\n\t * @param integrationTypes - The integration types\n\t */\n\tpublic setIntegrationTypes(...integrationTypes: RestOrArray) {\n\t\tReflect.set(this, 'integration_types', integrationTypesPredicate.parse(normalizeArray(integrationTypes)));\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name of this command.\n\t *\n\t * @param name - The name to use\n\t */\n\tpublic setName(name: string) {\n\t\t// Assert the name matches the conditions\n\t\tvalidateName(name);\n\n\t\tReflect.set(this, 'name', name);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the type of this command.\n\t *\n\t * @param type - The type to use\n\t */\n\tpublic setType(type: ContextMenuCommandType) {\n\t\t// Assert the type is valid\n\t\tvalidateType(type);\n\n\t\tReflect.set(this, 'type', type);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets whether the command is enabled by default when the application is added to a guild.\n\t *\n\t * @remarks\n\t * If set to `false`, you will have to later `PUT` the permissions for this command.\n\t * @param value - Whether to enable this command by default\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setDefaultMemberPermissions} or {@link ContextMenuCommandBuilder.setDMPermission} instead.\n\t */\n\tpublic setDefaultPermission(value: boolean) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDefaultPermission(value);\n\n\t\tReflect.set(this, 'default_permission', value);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the default permissions a member should have in order to run this command.\n\t *\n\t * @remarks\n\t * You can set this to `'0'` to disable the command by default.\n\t * @param permissions - The permissions bit field to set\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t */\n\tpublic setDefaultMemberPermissions(permissions: Permissions | bigint | number | null | undefined) {\n\t\t// Assert the value and parse it\n\t\tconst permissionValue = validateDefaultMemberPermissions(permissions);\n\n\t\tReflect.set(this, 'default_member_permissions', permissionValue);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets if the command is available in direct messages with the application.\n\t *\n\t * @remarks\n\t * By default, commands are visible. This method is only for global commands.\n\t * @param enabled - Whether the command should be enabled in direct messages\n\t * @see {@link https://discord.com/developers/docs/interactions/application-commands#permissions}\n\t * @deprecated Use {@link ContextMenuCommandBuilder.setContexts} instead.\n\t */\n\tpublic setDMPermission(enabled: boolean | null | undefined) {\n\t\t// Assert the value matches the conditions\n\t\tvalidateDMPermission(enabled);\n\n\t\tReflect.set(this, 'dm_permission', enabled);\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets a name localization for this command.\n\t *\n\t * @param locale - The locale to set\n\t * @param localizedName - The localized name for the given `locale`\n\t */\n\tpublic setNameLocalization(locale: LocaleString, localizedName: string | null) {\n\t\tif (!this.name_localizations) {\n\t\t\tReflect.set(this, 'name_localizations', {});\n\t\t}\n\n\t\tconst parsedLocale = validateLocale(locale);\n\n\t\tif (localizedName === null) {\n\t\t\tthis.name_localizations![parsedLocale] = null;\n\t\t\treturn this;\n\t\t}\n\n\t\tvalidateName(localizedName);\n\n\t\tthis.name_localizations![parsedLocale] = localizedName;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Sets the name localizations for this command.\n\t *\n\t * @param localizedNames - The object of localized names to set\n\t */\n\tpublic setNameLocalizations(localizedNames: LocalizationMap | null) {\n\t\tif (localizedNames === null) {\n\t\t\tReflect.set(this, 'name_localizations', null);\n\t\t\treturn this;\n\t\t}\n\n\t\tReflect.set(this, 'name_localizations', {});\n\n\t\tfor (const args of Object.entries(localizedNames))\n\t\t\tthis.setNameLocalization(...(args as [LocaleString, string | null]));\n\t\treturn this;\n\t}\n\n\t/**\n\t * Serializes this builder to API-compatible JSON data.\n\t *\n\t * @remarks\n\t * This method runs validations on the data before serializing it.\n\t * As such, it may throw an error if the data is invalid.\n\t */\n\tpublic toJSON(): RESTPostAPIContextMenuApplicationCommandsJSONBody {\n\t\tvalidateRequiredParameters(this.name, this.type);\n\n\t\tvalidateLocalizationMap(this.name_localizations);\n\n\t\treturn { ...this };\n\t}\n}\n","import type { APIEmbed } from 'discord-api-types/v10';\n\n/**\n * Calculates the length of the embed.\n *\n * @param data - The embed data to check\n */\nexport function embedLength(data: APIEmbed) {\n\treturn (\n\t\t(data.title?.length ?? 0) +\n\t\t(data.description?.length ?? 0) +\n\t\t(data.fields?.reduce((prev, curr) => prev + curr.name.length + curr.value.length, 0) ?? 0) +\n\t\t(data.footer?.text.length ?? 0) +\n\t\t(data.author?.name.length ?? 0)\n\t);\n}\n"],"mappings":"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","names":["Assertions_exports","s","s","ComponentType","ComponentType","ComponentType","ComponentType","ComponentType","SelectMenuDefaultValueType","ComponentType","SelectMenuDefaultValueType","ComponentType","SelectMenuDefaultValueType","ComponentType","SelectMenuDefaultValueType","ComponentType","ComponentType","ComponentType","SelectMenuDefaultValueType","ComponentType","SelectMenuDefaultValueType","ComponentType","Assertions_exports","placeholderValidator","s","s","placeholderValidator","ComponentType","placeholderValidator","ComponentType","ComponentType","Assertions_exports","validateRequiredParameters","s","s","validateRequiredParameters","validateRequiredParameters","Assertions_exports","validateRequiredParameters","s","s","descriptionPredicate","validateRequiredParameters","mix","validateRequiredParameters","validateRequiredParameters","ApplicationCommandOptionType","ApplicationCommandOptionType","ApplicationCommandOptionType","s","ChannelType","ChannelType","s","ApplicationCommandOptionType","s","ApplicationCommandOptionType","mix","s","booleanPredicate","s","s","ApplicationCommandOptionType","s","ApplicationCommandOptionType","s","ApplicationCommandOptionType","mix","ApplicationCommandOptionType","ApplicationCommandOptionType","s","ApplicationCommandOptionType","mix","numberValidator","s","ApplicationCommandOptionType","mix","ApplicationCommandOptionType","ApplicationCommandOptionType","s","ApplicationCommandOptionType","mix","minLengthValidator","s","maxLengthValidator","ApplicationCommandOptionType","mix","ApplicationCommandOptionType","ApplicationCommandOptionType","ApplicationCommandOptionType","mix","validateRequiredParameters","ApplicationCommandOptionType","mix","mix","Assertions_exports","contextsPredicate","integrationTypesPredicate","validateDMPermission","validateDefaultMemberPermissions","validateDefaultPermission","validateName","validateRequiredParameters","s","ApplicationCommandType","ApplicationIntegrationType","InteractionContextType","namePredicate","s","ApplicationCommandType","booleanPredicate","validateDefaultPermission","validateName","validateRequiredParameters","dmPermissionPredicate","validateDMPermission","memberPermissionPredicate","validateDefaultMemberPermissions","contextsPredicate","InteractionContextType","integrationTypesPredicate","ApplicationIntegrationType","contextsPredicate","integrationTypesPredicate","validateName","validateDefaultPermission","validateDefaultMemberPermissions","validateDMPermission","validateRequiredParameters"]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/package.json b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/package.json new file mode 100644 index 0000000..1b92221 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/builders/package.json @@ -0,0 +1,99 @@ +{ + "$schema": "https://json.schemastore.org/package.json", + "name": "@discordjs/builders", + "version": "1.10.1", + "description": "A set of builders that you can use when creating your bot", + "exports": { + ".": { + "require": { + "types": "./dist/index.d.ts", + "default": "./dist/index.js" + }, + "import": { + "types": "./dist/index.d.mts", + "default": "./dist/index.mjs" + } + } + }, + "main": "./dist/index.js", + "module": "./dist/index.mjs", + "types": "./dist/index.d.ts", + "directories": { + "lib": "src", + "test": "__tests__" + }, + "files": [ + "dist" + ], + "contributors": [ + "Vlad Frangu ", + "Crawl ", + "Amish Shah ", + "SpaceEEC ", + "Aura Román " + ], + "license": "Apache-2.0", + "keywords": [ + "discord", + "api", + "bot", + "client", + "node", + "discordapp", + "discordjs" + ], + "repository": { + "type": "git", + "url": "https://github.com/discordjs/discord.js.git", + "directory": "packages/builders" + }, + "bugs": { + "url": "https://github.com/discordjs/discord.js/issues" + }, + "homepage": "https://discord.js.org", + "funding": "https://github.com/discordjs/discord.js?sponsor", + "dependencies": { + "@sapphire/shapeshift": "^4.0.0", + "discord-api-types": "^0.37.119", + "fast-deep-equal": "^3.1.3", + "ts-mixer": "^6.0.4", + "tslib": "^2.6.3", + "@discordjs/util": "^1.1.1", + "@discordjs/formatters": "^0.6.0" + }, + "devDependencies": { + "@favware/cliff-jumper": "^4.1.0", + "@types/node": "^16.18.105", + "@vitest/coverage-v8": "^2.0.5", + "cross-env": "^7.0.3", + "esbuild-plugin-version-injector": "^1.2.1", + "eslint": "^8.57.0", + "eslint-config-neon": "^0.1.62", + "eslint-formatter-pretty": "^6.0.1", + "prettier": "^3.3.3", + "tsup": "^8.2.4", + "turbo": "^2.0.14", + "typescript": "~5.5.4", + "vitest": "^2.0.5", + "@discordjs/api-extractor": "^7.38.1", + "@discordjs/scripts": "^0.1.0" + }, + "engines": { + "node": ">=16.11.0" + }, + "publishConfig": { + "access": "public", + "provenance": true + }, + "scripts": { + "test": "vitest run", + "build": "tsc --noEmit && tsup", + "build:docs": "tsc -p tsconfig.docs.json", + "lint": "prettier --check . && cross-env TIMING=1 eslint --format=pretty src __tests__", + "format": "prettier --write . && cross-env TIMING=1 eslint --fix --format=pretty src __tests__", + "fmt": "pnpm run format", + "docs": "pnpm run build:docs && api-extractor run --local --minify && generate-split-documentation", + "changelog": "git cliff --prepend ./CHANGELOG.md -u -c ./cliff.toml -r ../../ --include-path 'packages/builders/*'", + "release": "cliff-jumper" + } +} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/formatters b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/formatters new file mode 120000 index 0000000..585a877 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/formatters @@ -0,0 +1 @@ +../../../@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/util b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/util new file mode 120000 index 0000000..35ebc7a --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@discordjs/util @@ -0,0 +1 @@ +../../../@discordjs+util@1.1.1/node_modules/@discordjs/util \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@sapphire/shapeshift b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@sapphire/shapeshift new file mode 120000 index 0000000..a17b4d1 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/@sapphire/shapeshift @@ -0,0 +1 @@ +../../../@sapphire+shapeshift@4.0.0/node_modules/@sapphire/shapeshift \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/discord-api-types b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/discord-api-types new file mode 120000 index 0000000..038bf0f --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/discord-api-types @@ -0,0 +1 @@ +../../discord-api-types@0.37.120/node_modules/discord-api-types \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/fast-deep-equal b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/fast-deep-equal new file mode 120000 index 0000000..c61b4c8 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/fast-deep-equal @@ -0,0 +1 @@ +../../fast-deep-equal@3.1.3/node_modules/fast-deep-equal \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/ts-mixer b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/ts-mixer new file mode 120000 index 0000000..edf1776 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/ts-mixer @@ -0,0 +1 @@ +../../ts-mixer@6.0.4/node_modules/ts-mixer \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/tslib b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/tslib new file mode 120000 index 0000000..4edba0e --- /dev/null +++ b/node_modules/.pnpm/@discordjs+builders@1.10.1/node_modules/tslib @@ -0,0 +1 @@ +../../tslib@2.8.1/node_modules/tslib \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/CHANGELOG.md b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/CHANGELOG.md new file mode 100644 index 0000000..2c43057 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/CHANGELOG.md @@ -0,0 +1,190 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +# [@discordjs/collection@1.5.3](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.2...@discordjs/collection@1.5.3) - (2023-08-17) + +## Documentation + +- Update Node.js requirement to 16.11.0 (#9764) ([188877c](https://github.com/discordjs/discord.js/commit/188877c50af70f0d5cffb246620fa277435c6ce6)) + +# [@discordjs/collection@1.5.2](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.1...@discordjs/collection@1.5.2) - (2023-07-31) + +## Refactor + +- **collection:** Reduce `reduce`'s code (#9581) ([b85a3f2](https://github.com/discordjs/discord.js/commit/b85a3f2ddee8fc5974749b95fc07389a03093df2)) + +# [@discordjs/collection@1.5.1](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.0...@discordjs/collection@1.5.1) - (2023-05-01) + +## Bug Fixes + +- Fix external links (#9313) ([a7425c2](https://github.com/discordjs/discord.js/commit/a7425c29c4f23f1b31f4c6a463107ca9eb7fd7e2)) + +## Documentation + +- Generate static imports for types with api-extractor ([98a76db](https://github.com/discordjs/discord.js/commit/98a76db482879f79d6bb2fb2e5fc65ac2c34e2d9)) + +# [@discordjs/collection@1.5.2](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.1...@discordjs/collection@1.5.2) - (2023-07-31) + +## Refactor + +- **collection:** Reduce `reduce`'s code (#9581) ([b85a3f2](https://github.com/discordjs/discord.js/commit/b85a3f2ddee8fc5974749b95fc07389a03093df2)) + +# [@discordjs/collection@1.5.1](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.0...@discordjs/collection@1.5.1) - (2023-05-01) + +## Bug Fixes + +- Fix external links (#9313) ([a7425c2](https://github.com/discordjs/discord.js/commit/a7425c29c4f23f1b31f4c6a463107ca9eb7fd7e2)) + +## Documentation + +- Generate static imports for types with api-extractor ([98a76db](https://github.com/discordjs/discord.js/commit/98a76db482879f79d6bb2fb2e5fc65ac2c34e2d9)) + +# [@discordjs/collection@1.5.1](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.5.0...@discordjs/collection@1.5.1) - (2023-05-01) + +## Bug Fixes + +- Fix external links (#9313) ([a7425c2](https://github.com/discordjs/discord.js/commit/a7425c29c4f23f1b31f4c6a463107ca9eb7fd7e2)) + +## Documentation + +- Generate static imports for types with api-extractor ([98a76db](https://github.com/discordjs/discord.js/commit/98a76db482879f79d6bb2fb2e5fc65ac2c34e2d9)) + +# [@discordjs/collection@1.5.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.4.0...@discordjs/collection@1.5.0) - (2023-04-01) + +## Bug Fixes + +- **scripts:** Accessing tsComment ([d8d5f31](https://github.com/discordjs/discord.js/commit/d8d5f31d3927fd1de62f1fa3a1a6e454243ad87b)) + +## Features + +- **website:** Render syntax and mdx on the server (#9086) ([ee5169e](https://github.com/discordjs/discord.js/commit/ee5169e0aadd7bbfcd752aae614ec0f69602b68b)) + +## Refactor + +- **collection:** Fix/silence linter warnings (#9266) ([d6f4e60](https://github.com/discordjs/discord.js/commit/d6f4e60efd1a1796fc84dbbfbac4f9790e480a1c)) + +# [@discordjs/collection@1.4.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.3.0...@discordjs/collection@1.4.0) - (2023-03-12) + +## Documentation + +- Fix version export (#9049) ([8b70f49](https://github.com/discordjs/discord.js/commit/8b70f497a1207e30edebdecd12b926c981c13d28)) + +## Features + +- **website:** Add support for source file links (#9048) ([f6506e9](https://github.com/discordjs/discord.js/commit/f6506e99c496683ee0ab67db0726b105b929af38)) + +## Refactor + +- Compare with `undefined` directly (#9191) ([869153c](https://github.com/discordjs/discord.js/commit/869153c3fdf155783e7c0ecebd3627b087c3a026)) + +# [@discordjs/collection@1.3.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.2.0...@discordjs/collection@1.3.0) - (2022-11-28) + +## Bug Fixes + +- Pin @types/node version ([9d8179c](https://github.com/discordjs/discord.js/commit/9d8179c6a78e1c7f9976f852804055964d5385d4)) + +## Features + +- Add `Collection#subtract()` (#8393) ([291f36c](https://github.com/discordjs/discord.js/commit/291f36cd736b5dea058145a1335bf7c78ec1d81d)) + +# [@discordjs/collection@1.2.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.1.0...@discordjs/collection@1.2.0) - (2022-10-08) + +## Bug Fixes + +- Footer / sidebar / deprecation alert ([ba3e0ed](https://github.com/discordjs/discord.js/commit/ba3e0ed348258fe8e51eefb4aa7379a1230616a9)) + +## Documentation + +- Change name (#8604) ([dd5a089](https://github.com/discordjs/discord.js/commit/dd5a08944c258a847fc4377f1d5e953264ab47d0)) +- Remove xml tag from collection#find (#8550) ([4032457](https://github.com/discordjs/discord.js/commit/40324574ebea9894cadcc967e0db0e4e21d62768)) + +## Features + +- Web-components (#8715) ([0ac3e76](https://github.com/discordjs/discord.js/commit/0ac3e766bd9dbdeb106483fa4bb085d74de346a2)) + +## Refactor + +- Website components (#8600) ([c334157](https://github.com/discordjs/discord.js/commit/c3341570d983aea9ecc419979d5a01de658c9d67)) +- Use `eslint-config-neon` for packages. (#8579) ([edadb9f](https://github.com/discordjs/discord.js/commit/edadb9fe5dfd9ff51a3cfc9b25cb242d3f9f5241)) + +## Typings + +- **Collection:** Make fn return type unknown (#8676) ([822b7f2](https://github.com/discordjs/discord.js/commit/822b7f234af053c8f917b0a998b82abfccd33801)) + +# [@discordjs/collection@1.1.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@1.0.1...@discordjs/collection@1.1.0) - (2022-08-22) + +## Bug Fixes + +- Use proper format for `@link` text (#8384) ([2655639](https://github.com/discordjs/discord.js/commit/26556390a3800e954974a00c1328ff47d3e67e9a)) + +## Documentation + +- Fence examples in codeblocks ([193b252](https://github.com/discordjs/discord.js/commit/193b252672440a860318d3c2968aedd9cb88e0ce)) +- Use link tags (#8382) ([5494791](https://github.com/discordjs/discord.js/commit/549479131318c659f86f0eb18578d597e22522d3)) + +## Features + +- **website:** Show `constructor` information (#8540) ([e42fd16](https://github.com/discordjs/discord.js/commit/e42fd1636973b10dd7ed6fb4280ee1a4a8f82007)) +- **website:** Show descriptions for `@typeParam` blocks (#8523) ([e475b63](https://github.com/discordjs/discord.js/commit/e475b63f257f6261d73cb89fee9ecbcdd84e2a6b)) + +## Refactor + +- **website:** Adjust typography (#8503) ([0f83402](https://github.com/discordjs/discord.js/commit/0f834029850d2448981596cf082ff59917018d66)) +- Docs design (#8487) ([4ab1d09](https://github.com/discordjs/discord.js/commit/4ab1d09997a18879a9eb9bda39df6f15aa22557e)) + +# [@discordjs/collection@0.8.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@0.7.0...@discordjs/collection@0.8.0) - (2022-07-17) + +## Bug Fixes + +- **Collection:** Make error messages consistent (#8224) ([5bd6b28](https://github.com/discordjs/discord.js/commit/5bd6b28b3ebfced1cb9d23e83bd7c0def7a12404)) +- Check for function type (#8064) ([3bb9c0e](https://github.com/discordjs/discord.js/commit/3bb9c0e5c37311044ff41761b572ac4f91cda57c)) + +## Documentation + +- Add codecov coverage badge to readmes (#8226) ([f6db285](https://github.com/discordjs/discord.js/commit/f6db285c073898a749fe4591cbd4463d1896daf5)) + +## Features + +- Codecov (#8219) ([f10f4cd](https://github.com/discordjs/discord.js/commit/f10f4cdcd88ca6be7ec735ed3a415ba13da83db0)) +- **docgen:** Update typedoc ([b3346f4](https://github.com/discordjs/discord.js/commit/b3346f4b9b3d4f96443506643d4631dc1c6d7b21)) +- Website (#8043) ([127931d](https://github.com/discordjs/discord.js/commit/127931d1df7a2a5c27923c2f2151dbf3824e50cc)) +- **docgen:** Typescript support ([3279b40](https://github.com/discordjs/discord.js/commit/3279b40912e6aa61507bedb7db15a2b8668de44b)) +- Docgen package (#8029) ([8b979c0](https://github.com/discordjs/discord.js/commit/8b979c0245c42fd824d8e98745ee869f5360fc86)) +- Use vitest instead of jest for more speed ([8d8e6c0](https://github.com/discordjs/discord.js/commit/8d8e6c03decd7352a2aa180f6e5bc1a13602539b)) +- Add scripts package for locally used scripts ([f2ae1f9](https://github.com/discordjs/discord.js/commit/f2ae1f9348bfd893332a9060f71a8a5f272a1b8b)) + +## Refactor + +- **collection:** Remove `default` property (#8055) ([c8f1690](https://github.com/discordjs/discord.js/commit/c8f1690896f55f06e05a83704262783cfc2bb91d)) +- **collection:** Remove default export (#8053) ([16810f3](https://github.com/discordjs/discord.js/commit/16810f3e410bf35ed7e6e7412d517ea74c792c5d)) +- Move all the config files to root (#8033) ([769ea0b](https://github.com/discordjs/discord.js/commit/769ea0bfe78c4f1d413c6b397c604ffe91e39c6a)) + +## Testing + +- **collection:** Improve coverage (#8222) ([a51f721](https://github.com/discordjs/discord.js/commit/a51f7215eca67a0f46fba8b2d706f7ec6f6dc228)) + +# [@discordjs/collection@0.7.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@0.6.0...@discordjs/collection@0.7.0) - (2022-06-04) + +## Styling + +- Cleanup tests and tsup configs ([6b8ef20](https://github.com/discordjs/discord.js/commit/6b8ef20cb3af5b5cfd176dd0aa0a1a1e98551629)) + +# [@discordjs/collection@0.6.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@0.5.0...@discordjs/collection@0.6.0) - (2022-04-17) + +## Features + +- Add support for module: NodeNext in TS and ESM (#7598) ([8f1986a](https://github.com/discordjs/discord.js/commit/8f1986a6aa98365e09b00e84ad5f9f354ab61f3d)) +- **builders:** Add attachment command option type (#7203) ([ae0f35f](https://github.com/discordjs/discord.js/commit/ae0f35f51d68dfa5a7dc43d161ef9365171debdb)) +- **Collection:** Add merging functions (#7299) ([e4bd07b](https://github.com/discordjs/discord.js/commit/e4bd07b2394f227ea06b72eb6999de9ab3127b25)) + +# [@discordjs/collection@0.5.0](https://github.com/discordjs/discord.js/compare/@discordjs/collection@0.4.0...@discordjs/collection@0.5.0) - (2022-01-24) + +## Refactor + +- Make `intersect` perform a true intersection (#7211) ([d8efba2](https://github.com/discordjs/discord.js/commit/d8efba24e09aa2a8dbf028fc57a561a56e7833fd)) + +## Typings + +- Add `ReadonlyCollection` (#7245) ([db25f52](https://github.com/discordjs/discord.js/commit/db25f529b26d7c819c1c42ad3e26c2263ea2da0e)) +- **Collection:** Union types on `intersect` and `difference` (#7196) ([1f9b922](https://github.com/discordjs/discord.js/commit/1f9b9225f2066e9cc66c3355417139fd25cc403c)) diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/LICENSE b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/LICENSE new file mode 100644 index 0000000..d21f37a --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/LICENSE @@ -0,0 +1,191 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + Copyright 2021 Noel Buechler + Copyright 2015 Amish Shah + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/README.md b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/README.md new file mode 100644 index 0000000..4ddde14 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/README.md @@ -0,0 +1,67 @@ +
+
+

+ discord.js +

+
+

+ Discord server + npm version + npm downloads + Build status + Code coverage +

+

+ Vercel + Cloudflare Workers +

+
+ +## About + +`@discordjs/collection` is a powerful utility data structure used in discord.js. + +## Installation + +**Node.js 16.11.0 or newer is required.** + +```sh +npm install @discordjs/collection +yarn add @discordjs/collection +pnpm add @discordjs/collection +``` + +## Links + +- [Website][website] ([source][website-source]) +- [Documentation][documentation] +- [Guide][guide] ([source][guide-source]) + Also see the v13 to v14 [Update Guide][guide-update], which includes updated and removed items from the library. +- [discord.js Discord server][discord] +- [Discord API Discord server][discord-api] +- [GitHub][source] +- [npm][npm] +- [Related libraries][related-libs] + +## Contributing + +Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the +[documentation][documentation]. +See [the contribution guide][contributing] if you'd like to submit a PR. + +## Help + +If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official [discord.js Server][discord]. + +[website]: https://discord.js.org +[website-source]: https://github.com/discordjs/discord.js/tree/main/apps/website +[documentation]: https://discord.js.org/docs/packages/collection/stable +[guide]: https://discordjs.guide/ +[guide-source]: https://github.com/discordjs/guide +[guide-update]: https://discordjs.guide/additional-info/changes-in-v14.html +[discord]: https://discord.gg/djs +[discord-api]: https://discord.gg/discord-api +[source]: https://github.com/discordjs/discord.js/tree/main/packages/collection +[npm]: https://www.npmjs.com/package/@discordjs/collection +[related-libs]: https://discord.com/developers/docs/topics/community-resources#libraries +[contributing]: https://github.com/discordjs/discord.js/blob/main/.github/CONTRIBUTING.md diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.mts b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.mts new file mode 100644 index 0000000..5990c61 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.mts @@ -0,0 +1,457 @@ +/** + * @internal + */ +interface CollectionConstructor { + new (): Collection; + new (entries?: readonly (readonly [K, V])[] | null): Collection; + new (iterable: Iterable): Collection; + readonly prototype: Collection; + readonly [Symbol.species]: CollectionConstructor; +} +/** + * Represents an immutable version of a collection + */ +type ReadonlyCollection = Omit, 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'> & ReadonlyMap; +/** + * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself + * + * @internal + */ +interface Collection extends Map { + constructor: CollectionConstructor; +} +/** + * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has + * an ID, for significantly improved performance and ease-of-use. + * + * @typeParam K - The key type this collection holds + * @typeParam V - The value type this collection holds + */ +declare class Collection extends Map { + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V; + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys: K[]): boolean; + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys: K[]): boolean; + /** + * Obtains the first value(s) in this collection. + * + * @param amount - Amount of values to obtain from the beginning + * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative + */ + first(): V | undefined; + first(amount: number): V[]; + /** + * Obtains the first key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the beginning + * @returns A single key if no amount is provided or an array of keys, starting from the end if + * amount is negative + */ + firstKey(): K | undefined; + firstKey(amount: number): K[]; + /** + * Obtains the last value(s) in this collection. + * + * @param amount - Amount of values to obtain from the end + * @returns A single value if no amount is provided or an array of values, starting from the start if + * amount is negative + */ + last(): V | undefined; + last(amount: number): V[]; + /** + * Obtains the last key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the end + * @returns A single key if no amount is provided or an array of keys, starting from the start if + * amount is negative + */ + lastKey(): K | undefined; + lastKey(amount: number): K[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index: number): V | undefined; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index: number): K | undefined; + /** + * Obtains unique random value(s) from this collection. + * + * @param amount - Amount of values to obtain randomly + * @returns A single value if no amount is provided or an array of values + */ + random(): V | undefined; + random(amount: number): V[]; + /** + * Obtains unique random key(s) from this collection. + * + * @param amount - Amount of keys to obtain randomly + * @returns A single key if no amount is provided or an array + */ + randomKey(): K | undefined; + randomKey(amount: number): K[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse(): this; + /** + * Searches for a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}. + * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you + * should use the `get` method. See + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.find(user => user.username === 'Bob'); + * ``` + */ + find(fn: (value: V, key: K, collection: this) => value is V2): V2 | undefined; + find(fn: (value: V, key: K, collection: this) => unknown): V | undefined; + find(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): V2 | undefined; + find(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): V | undefined; + /** + * Searches for the key of a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.findKey(user => user.username === 'Bob'); + * ``` + */ + findKey(fn: (value: V, key: K, collection: this) => key is K2): K2 | undefined; + findKey(fn: (value: V, key: K, collection: this) => unknown): K | undefined; + findKey(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): K2 | undefined; + findKey(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): K | undefined; + /** + * Removes items that satisfy the provided filter function. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @returns The number of removed entries + */ + sweep(fn: (value: V, key: K, collection: this) => unknown): number; + sweep(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): number; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()}, + * but returns a Collection instead of an Array. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.filter(user => user.username === 'Bob'); + * ``` + */ + filter(fn: (value: V, key: K, collection: this) => key is K2): Collection; + filter(fn: (value: V, key: K, collection: this) => value is V2): Collection; + filter(fn: (value: V, key: K, collection: this) => unknown): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): Collection; + /** + * Partitions the collection into two collections where the first collection + * contains the items that passed and the second contains the items that failed. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * const [big, small] = collection.partition(guild => guild.memberCount > 250); + * ``` + */ + partition(fn: (value: V, key: K, collection: this) => key is K2): [Collection, Collection, V>]; + partition(fn: (value: V, key: K, collection: this) => value is V2): [Collection, Collection>]; + partition(fn: (value: V, key: K, collection: this) => unknown): [Collection, Collection]; + partition(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): [Collection, Collection, V>]; + partition(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): [Collection, Collection>]; + partition(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): [Collection, Collection]; + /** + * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}. + * + * @param fn - Function that produces a new Collection + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.flatMap(guild => guild.members.cache); + * ``` + */ + flatMap(fn: (value: V, key: K, collection: this) => Collection): Collection; + flatMap(fn: (this: This, value: V, key: K, collection: this) => Collection, thisArg: This): Collection; + /** + * Maps each item to another value into an array. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new array, taking three arguments + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.map(user => user.tag); + * ``` + */ + map(fn: (value: V, key: K, collection: this) => T): T[]; + map(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): T[]; + /** + * Maps each item to another value into a collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new collection, taking three arguments + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.mapValues(user => user.tag); + * ``` + */ + mapValues(fn: (value: V, key: K, collection: this) => T): Collection; + mapValues(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): Collection; + /** + * Checks if there exists an item that passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.some(user => user.discriminator === '0000'); + * ``` + */ + some(fn: (value: V, key: K, collection: this) => unknown): boolean; + some(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): boolean; + /** + * Checks if all items passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.every(user => !user.bot); + * ``` + */ + every(fn: (value: V, key: K, collection: this) => key is K2): this is Collection; + every(fn: (value: V, key: K, collection: this) => value is V2): this is Collection; + every(fn: (value: V, key: K, collection: this) => unknown): boolean; + every(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): this is Collection; + every(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): this is Collection; + every(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): boolean; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue?: T): T; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()}, + * but returns the collection instead of undefined. + * + * @param fn - Function to execute for each element + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection + * .each(user => console.log(user.username)) + * .filter(user => user.bot) + * .each(user => console.log(user.username)); + * ``` + */ + each(fn: (value: V, key: K, collection: this) => void): this; + each(fn: (this: T, value: V, key: K, collection: this) => void, thisArg: T): this; + /** + * Runs a function on the collection and returns the collection. + * + * @param fn - Function to execute + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection + * .tap(coll => console.log(coll.size)) + * .filter(user => user.bot) + * .tap(coll => console.log(coll.size)) + * ``` + */ + tap(fn: (collection: this) => void): this; + tap(fn: (this: T, collection: this) => void, thisArg: T): this; + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone(): Collection; + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections: ReadonlyCollection[]): Collection; + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection: ReadonlyCollection): boolean; + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction?: Comparator): this; + /** + * The intersect method returns a new structure containing items where the keys and values are present in both original structures. + * + * @param other - The other Collection to filter against + */ + intersect(other: ReadonlyCollection): Collection; + /** + * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other. + * + * @param other - The other Collection to filter against + */ + subtract(other: ReadonlyCollection): Collection; + /** + * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other. + * + * @param other - The other Collection to filter against + */ + difference(other: ReadonlyCollection): Collection; + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other: ReadonlyCollection, whenInSelf: (value: V, key: K) => Keep, whenInOther: (valueOther: T, key: K) => Keep, whenInBoth: (value: V, valueOther: T, key: K) => Keep): Collection; + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sorted(compareFunction?: Comparator): Collection; + toJSON(): V[]; + private static defaultSort; + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries: Iterable<[K, V]>, combine: (firstValue: V, secondValue: V, key: K) => V): Collection; +} +/** + * @internal + */ +type Keep = { + keep: false; +} | { + keep: true; + value: V; +}; +/** + * @internal + */ +type Comparator = (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection/#readme | @discordjs/collection} version + * that you are currently using. + */ +declare const version: string; + +export { Collection, CollectionConstructor, Comparator, Keep, ReadonlyCollection, version }; diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.ts b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.ts new file mode 100644 index 0000000..5990c61 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.d.ts @@ -0,0 +1,457 @@ +/** + * @internal + */ +interface CollectionConstructor { + new (): Collection; + new (entries?: readonly (readonly [K, V])[] | null): Collection; + new (iterable: Iterable): Collection; + readonly prototype: Collection; + readonly [Symbol.species]: CollectionConstructor; +} +/** + * Represents an immutable version of a collection + */ +type ReadonlyCollection = Omit, 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'> & ReadonlyMap; +/** + * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself + * + * @internal + */ +interface Collection extends Map { + constructor: CollectionConstructor; +} +/** + * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has + * an ID, for significantly improved performance and ease-of-use. + * + * @typeParam K - The key type this collection holds + * @typeParam V - The value type this collection holds + */ +declare class Collection extends Map { + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V; + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys: K[]): boolean; + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys: K[]): boolean; + /** + * Obtains the first value(s) in this collection. + * + * @param amount - Amount of values to obtain from the beginning + * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative + */ + first(): V | undefined; + first(amount: number): V[]; + /** + * Obtains the first key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the beginning + * @returns A single key if no amount is provided or an array of keys, starting from the end if + * amount is negative + */ + firstKey(): K | undefined; + firstKey(amount: number): K[]; + /** + * Obtains the last value(s) in this collection. + * + * @param amount - Amount of values to obtain from the end + * @returns A single value if no amount is provided or an array of values, starting from the start if + * amount is negative + */ + last(): V | undefined; + last(amount: number): V[]; + /** + * Obtains the last key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the end + * @returns A single key if no amount is provided or an array of keys, starting from the start if + * amount is negative + */ + lastKey(): K | undefined; + lastKey(amount: number): K[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index: number): V | undefined; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index: number): K | undefined; + /** + * Obtains unique random value(s) from this collection. + * + * @param amount - Amount of values to obtain randomly + * @returns A single value if no amount is provided or an array of values + */ + random(): V | undefined; + random(amount: number): V[]; + /** + * Obtains unique random key(s) from this collection. + * + * @param amount - Amount of keys to obtain randomly + * @returns A single key if no amount is provided or an array + */ + randomKey(): K | undefined; + randomKey(amount: number): K[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse(): this; + /** + * Searches for a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}. + * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you + * should use the `get` method. See + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.find(user => user.username === 'Bob'); + * ``` + */ + find(fn: (value: V, key: K, collection: this) => value is V2): V2 | undefined; + find(fn: (value: V, key: K, collection: this) => unknown): V | undefined; + find(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): V2 | undefined; + find(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): V | undefined; + /** + * Searches for the key of a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.findKey(user => user.username === 'Bob'); + * ``` + */ + findKey(fn: (value: V, key: K, collection: this) => key is K2): K2 | undefined; + findKey(fn: (value: V, key: K, collection: this) => unknown): K | undefined; + findKey(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): K2 | undefined; + findKey(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): K | undefined; + /** + * Removes items that satisfy the provided filter function. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @returns The number of removed entries + */ + sweep(fn: (value: V, key: K, collection: this) => unknown): number; + sweep(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): number; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()}, + * but returns a Collection instead of an Array. + * + * @param fn - The function to test with (should return boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.filter(user => user.username === 'Bob'); + * ``` + */ + filter(fn: (value: V, key: K, collection: this) => key is K2): Collection; + filter(fn: (value: V, key: K, collection: this) => value is V2): Collection; + filter(fn: (value: V, key: K, collection: this) => unknown): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): Collection; + filter(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): Collection; + /** + * Partitions the collection into two collections where the first collection + * contains the items that passed and the second contains the items that failed. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * const [big, small] = collection.partition(guild => guild.memberCount > 250); + * ``` + */ + partition(fn: (value: V, key: K, collection: this) => key is K2): [Collection, Collection, V>]; + partition(fn: (value: V, key: K, collection: this) => value is V2): [Collection, Collection>]; + partition(fn: (value: V, key: K, collection: this) => unknown): [Collection, Collection]; + partition(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): [Collection, Collection, V>]; + partition(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): [Collection, Collection>]; + partition(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): [Collection, Collection]; + /** + * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}. + * + * @param fn - Function that produces a new Collection + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.flatMap(guild => guild.members.cache); + * ``` + */ + flatMap(fn: (value: V, key: K, collection: this) => Collection): Collection; + flatMap(fn: (this: This, value: V, key: K, collection: this) => Collection, thisArg: This): Collection; + /** + * Maps each item to another value into an array. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new array, taking three arguments + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.map(user => user.tag); + * ``` + */ + map(fn: (value: V, key: K, collection: this) => T): T[]; + map(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): T[]; + /** + * Maps each item to another value into a collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new collection, taking three arguments + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.mapValues(user => user.tag); + * ``` + */ + mapValues(fn: (value: V, key: K, collection: this) => T): Collection; + mapValues(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): Collection; + /** + * Checks if there exists an item that passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.some(user => user.discriminator === '0000'); + * ``` + */ + some(fn: (value: V, key: K, collection: this) => unknown): boolean; + some(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): boolean; + /** + * Checks if all items passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection.every(user => !user.bot); + * ``` + */ + every(fn: (value: V, key: K, collection: this) => key is K2): this is Collection; + every(fn: (value: V, key: K, collection: this) => value is V2): this is Collection; + every(fn: (value: V, key: K, collection: this) => unknown): boolean; + every(fn: (this: This, value: V, key: K, collection: this) => key is K2, thisArg: This): this is Collection; + every(fn: (this: This, value: V, key: K, collection: this) => value is V2, thisArg: This): this is Collection; + every(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): boolean; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue?: T): T; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()}, + * but returns the collection instead of undefined. + * + * @param fn - Function to execute for each element + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection + * .each(user => console.log(user.username)) + * .filter(user => user.bot) + * .each(user => console.log(user.username)); + * ``` + */ + each(fn: (value: V, key: K, collection: this) => void): this; + each(fn: (this: T, value: V, key: K, collection: this) => void, thisArg: T): this; + /** + * Runs a function on the collection and returns the collection. + * + * @param fn - Function to execute + * @param thisArg - Value to use as `this` when executing function + * @example + * ```ts + * collection + * .tap(coll => console.log(coll.size)) + * .filter(user => user.bot) + * .tap(coll => console.log(coll.size)) + * ``` + */ + tap(fn: (collection: this) => void): this; + tap(fn: (this: T, collection: this) => void, thisArg: T): this; + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone(): Collection; + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections: ReadonlyCollection[]): Collection; + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection: ReadonlyCollection): boolean; + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction?: Comparator): this; + /** + * The intersect method returns a new structure containing items where the keys and values are present in both original structures. + * + * @param other - The other Collection to filter against + */ + intersect(other: ReadonlyCollection): Collection; + /** + * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other. + * + * @param other - The other Collection to filter against + */ + subtract(other: ReadonlyCollection): Collection; + /** + * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other. + * + * @param other - The other Collection to filter against + */ + difference(other: ReadonlyCollection): Collection; + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other: ReadonlyCollection, whenInSelf: (value: V, key: K) => Keep, whenInOther: (valueOther: T, key: K) => Keep, whenInBoth: (value: V, valueOther: T, key: K) => Keep): Collection; + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sorted(compareFunction?: Comparator): Collection; + toJSON(): V[]; + private static defaultSort; + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries: Iterable<[K, V]>, combine: (firstValue: V, secondValue: V, key: K) => V): Collection; +} +/** + * @internal + */ +type Keep = { + keep: false; +} | { + keep: true; + value: V; +}; +/** + * @internal + */ +type Comparator = (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection/#readme | @discordjs/collection} version + * that you are currently using. + */ +declare const version: string; + +export { Collection, CollectionConstructor, Comparator, Keep, ReadonlyCollection, version }; diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js new file mode 100644 index 0000000..d9379ea --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js @@ -0,0 +1,543 @@ +"use strict"; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key) && key !== except) + __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); + } + return to; +}; +var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); + +// src/index.ts +var src_exports = {}; +__export(src_exports, { + Collection: () => Collection, + version: () => version +}); +module.exports = __toCommonJS(src_exports); + +// src/collection.ts +var Collection = class _Collection extends Map { + static { + __name(this, "Collection"); + } + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key, defaultValueGenerator) { + if (this.has(key)) + return this.get(key); + if (typeof defaultValueGenerator !== "function") + throw new TypeError(`${defaultValueGenerator} is not a function`); + const defaultValue = defaultValueGenerator(key, this); + this.set(key, defaultValue); + return defaultValue; + } + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys) { + return keys.every((key) => super.has(key)); + } + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys) { + return keys.some((key) => super.has(key)); + } + first(amount) { + if (amount === void 0) + return this.values().next().value; + if (amount < 0) + return this.last(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.values(); + return Array.from({ length: amount }, () => iter.next().value); + } + firstKey(amount) { + if (amount === void 0) + return this.keys().next().value; + if (amount < 0) + return this.lastKey(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.keys(); + return Array.from({ length: amount }, () => iter.next().value); + } + last(amount) { + const arr = [...this.values()]; + if (amount === void 0) + return arr[arr.length - 1]; + if (amount < 0) + return this.first(amount * -1); + if (!amount) + return []; + return arr.slice(-amount); + } + lastKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) + return arr[arr.length - 1]; + if (amount < 0) + return this.firstKey(amount * -1); + if (!amount) + return []; + return arr.slice(-amount); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index) { + index = Math.floor(index); + const arr = [...this.values()]; + return arr.at(index); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index) { + index = Math.floor(index); + const arr = [...this.keys()]; + return arr.at(index); + } + random(amount) { + const arr = [...this.values()]; + if (amount === void 0) + return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) + return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + randomKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) + return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) + return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse() { + const entries = [...this.entries()].reverse(); + this.clear(); + for (const [key, value] of entries) + this.set(key, value); + return this; + } + find(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return val; + } + return void 0; + } + findKey(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return key; + } + return void 0; + } + sweep(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const previousSize = this.size; + for (const [key, val] of this) { + if (fn(val, key, this)) + this.delete(key); + } + return previousSize - this.size; + } + filter(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const results = new this.constructor[Symbol.species](); + for (const [key, val] of this) { + if (fn(val, key, this)) + results.set(key, val); + } + return results; + } + partition(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const results = [ + new this.constructor[Symbol.species](), + new this.constructor[Symbol.species]() + ]; + for (const [key, val] of this) { + if (fn(val, key, this)) { + results[0].set(key, val); + } else { + results[1].set(key, val); + } + } + return results; + } + flatMap(fn, thisArg) { + const collections = this.map(fn, thisArg); + return new this.constructor[Symbol.species]().concat(...collections); + } + map(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const iter = this.entries(); + return Array.from({ length: this.size }, () => { + const [key, value] = iter.next().value; + return fn(value, key, this); + }); + } + mapValues(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const coll = new this.constructor[Symbol.species](); + for (const [key, val] of this) + coll.set(key, fn(val, key, this)); + return coll; + } + some(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return true; + } + return false; + } + every(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (!fn(val, key, this)) + return false; + } + return true; + } + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn, initialValue) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + let accumulator; + const iterator = this.entries(); + if (initialValue === void 0) { + if (this.size === 0) + throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = iterator.next().value[1]; + } else { + accumulator = initialValue; + } + for (const [key, value] of iterator) { + accumulator = fn(accumulator, value, key, this); + } + return accumulator; + } + each(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, value] of this) { + fn(value, key, this); + } + return this; + } + tap(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + fn(this); + return this; + } + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone() { + return new this.constructor[Symbol.species](this); + } + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections) { + const newColl = this.clone(); + for (const coll of collections) { + for (const [key, val] of coll) + newColl.set(key, val); + } + return newColl; + } + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection) { + if (!collection) + return false; + if (this === collection) + return true; + if (this.size !== collection.size) + return false; + for (const [key, value] of this) { + if (!collection.has(key) || value !== collection.get(key)) { + return false; + } + } + return true; + } + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction = _Collection.defaultSort) { + const entries = [...this.entries()]; + entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0])); + super.clear(); + for (const [key, value] of entries) { + super.set(key, value); + } + return this; + } + /** + * The intersect method returns a new structure containing items where the keys and values are present in both original structures. + * + * @param other - The other Collection to filter against + */ + intersect(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of other) { + if (this.has(key) && Object.is(value, this.get(key))) { + coll.set(key, value); + } + } + return coll; + } + /** + * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other. + * + * @param other - The other Collection to filter against + */ + subtract(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key) || !Object.is(value, other.get(key))) { + coll.set(key, value); + } + } + return coll; + } + /** + * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other. + * + * @param other - The other Collection to filter against + */ + difference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of other) { + if (!this.has(key)) + coll.set(key, value); + } + for (const [key, value] of this) { + if (!other.has(key)) + coll.set(key, value); + } + return coll; + } + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other, whenInSelf, whenInOther, whenInBoth) { + const coll = new this.constructor[Symbol.species](); + const keys = /* @__PURE__ */ new Set([...this.keys(), ...other.keys()]); + for (const key of keys) { + const hasInSelf = this.has(key); + const hasInOther = other.has(key); + if (hasInSelf && hasInOther) { + const result = whenInBoth(this.get(key), other.get(key), key); + if (result.keep) + coll.set(key, result.value); + } else if (hasInSelf) { + const result = whenInSelf(this.get(key), key); + if (result.keep) + coll.set(key, result.value); + } else if (hasInOther) { + const result = whenInOther(other.get(key), key); + if (result.keep) + coll.set(key, result.value); + } + } + return coll; + } + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sorted(compareFunction = _Collection.defaultSort) { + return new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk)); + } + toJSON() { + return [...this.values()]; + } + static defaultSort(firstValue, secondValue) { + return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1; + } + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries, combine) { + const coll = new _Collection(); + for (const [key, value] of entries) { + if (coll.has(key)) { + coll.set(key, combine(coll.get(key), value, key)); + } else { + coll.set(key, value); + } + } + return coll; + } +}; + +// src/index.ts +var version = "1.5.3"; +// Annotate the CommonJS export names for ESM import in node: +0 && (module.exports = { + Collection, + version +}); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js.map b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js.map new file mode 100644 index 0000000..247240c --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/index.ts","../src/collection.ts"],"sourcesContent":["export * from './collection.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection/#readme | @discordjs/collection} version\n * that you are currently using.\n */\n// This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild\nexport const version = '1.5.3' as string;\n","/* eslint-disable no-param-reassign */\n/**\n * @internal\n */\nexport interface CollectionConstructor {\n\tnew (): Collection;\n\tnew (entries?: readonly (readonly [K, V])[] | null): Collection;\n\tnew (iterable: Iterable): Collection;\n\treadonly prototype: Collection;\n\treadonly [Symbol.species]: CollectionConstructor;\n}\n\n/**\n * Represents an immutable version of a collection\n */\nexport type ReadonlyCollection = Omit<\n\tCollection,\n\t'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'\n> &\n\tReadonlyMap;\n\n/**\n * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself\n *\n * @internal\n */\nexport interface Collection extends Map {\n\tconstructor: CollectionConstructor;\n}\n\n/**\n * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has\n * an ID, for significantly improved performance and ease-of-use.\n *\n * @typeParam K - The key type this collection holds\n * @typeParam V - The value type this collection holds\n */\nexport class Collection extends Map {\n\t/**\n\t * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator.\n\t *\n\t * @param key - The key to get if it exists, or set otherwise\n\t * @param defaultValueGenerator - A function that generates the default value\n\t * @example\n\t * ```ts\n\t * collection.ensure(guildId, () => defaultGuildConfig);\n\t * ```\n\t */\n\tpublic ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\n\t\tif (this.has(key)) return this.get(key)!;\n\t\tif (typeof defaultValueGenerator !== 'function') throw new TypeError(`${defaultValueGenerator} is not a function`);\n\t\tconst defaultValue = defaultValueGenerator(key, this);\n\t\tthis.set(key, defaultValue);\n\t\treturn defaultValue;\n\t}\n\n\t/**\n\t * Checks if all of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if all of the elements exist, `false` if at least one does not exist.\n\t */\n\tpublic hasAll(...keys: K[]) {\n\t\treturn keys.every((key) => super.has(key));\n\t}\n\n\t/**\n\t * Checks if any of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if any of the elements exist, `false` if none exist.\n\t */\n\tpublic hasAny(...keys: K[]) {\n\t\treturn keys.some((key) => super.has(key));\n\t}\n\n\t/**\n\t * Obtains the first value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the beginning\n\t * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative\n\t */\n\tpublic first(): V | undefined;\n\tpublic first(amount: number): V[];\n\tpublic first(amount?: number): V | V[] | undefined {\n\t\tif (amount === undefined) return this.values().next().value;\n\t\tif (amount < 0) return this.last(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.values();\n\t\treturn Array.from({ length: amount }, (): V => iter.next().value);\n\t}\n\n\t/**\n\t * Obtains the first key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the beginning\n\t * @returns A single key if no amount is provided or an array of keys, starting from the end if\n\t * amount is negative\n\t */\n\tpublic firstKey(): K | undefined;\n\tpublic firstKey(amount: number): K[];\n\tpublic firstKey(amount?: number): K | K[] | undefined {\n\t\tif (amount === undefined) return this.keys().next().value;\n\t\tif (amount < 0) return this.lastKey(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.keys();\n\t\treturn Array.from({ length: amount }, (): K => iter.next().value);\n\t}\n\n\t/**\n\t * Obtains the last value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the end\n\t * @returns A single value if no amount is provided or an array of values, starting from the start if\n\t * amount is negative\n\t */\n\tpublic last(): V | undefined;\n\tpublic last(amount: number): V[];\n\tpublic last(amount?: number): V | V[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.first(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Obtains the last key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the end\n\t * @returns A single key if no amount is provided or an array of keys, starting from the start if\n\t * amount is negative\n\t */\n\tpublic lastKey(): K | undefined;\n\tpublic lastKey(amount: number): K[];\n\tpublic lastKey(amount?: number): K | K[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.firstKey(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the item at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the element to obtain\n\t */\n\tpublic at(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.values()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the key at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the key to obtain\n\t */\n\tpublic keyAt(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.keys()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Obtains unique random value(s) from this collection.\n\t *\n\t * @param amount - Amount of values to obtain randomly\n\t * @returns A single value if no amount is provided or an array of values\n\t */\n\tpublic random(): V | undefined;\n\tpublic random(amount: number): V[];\n\tpublic random(amount?: number): V | V[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): V => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Obtains unique random key(s) from this collection.\n\t *\n\t * @param amount - Amount of keys to obtain randomly\n\t * @returns A single key if no amount is provided or an array\n\t */\n\tpublic randomKey(): K | undefined;\n\tpublic randomKey(amount: number): K[];\n\tpublic randomKey(amount?: number): K | K[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): K => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic reverse() {\n\t\tconst entries = [...this.entries()].reverse();\n\t\tthis.clear();\n\t\tfor (const [key, value] of entries) this.set(key, value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Searches for a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}.\n\t * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you\n\t * should use the `get` method. See\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.find(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic find(fn: (value: V, key: K, collection: this) => value is V2): V2 | undefined;\n\tpublic find(fn: (value: V, key: K, collection: this) => unknown): V | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): V2 | undefined;\n\tpublic find(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): V | undefined;\n\tpublic find(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): V | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.findKey(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic findKey(fn: (value: V, key: K, collection: this) => key is K2): K2 | undefined;\n\tpublic findKey(fn: (value: V, key: K, collection: this) => unknown): K | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): K2 | undefined;\n\tpublic findKey(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): K | undefined;\n\tpublic findKey(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): K | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Removes items that satisfy the provided filter function.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @returns The number of removed entries\n\t */\n\tpublic sweep(fn: (value: V, key: K, collection: this) => unknown): number;\n\tpublic sweep(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): number;\n\tpublic sweep(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): number {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst previousSize = this.size;\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) this.delete(key);\n\t\t}\n\n\t\treturn previousSize - this.size;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()},\n\t * but returns a Collection instead of an Array.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.filter(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic filter(fn: (value: V, key: K, collection: this) => key is K2): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => value is V2): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => unknown): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) results.set(key, val);\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Partitions the collection into two collections where the first collection\n\t * contains the items that passed and the second contains the items that failed.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * const [big, small] = collection.partition(guild => guild.memberCount > 250);\n\t * ```\n\t */\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => key is K2,\n\t): [Collection, Collection, V>];\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => value is V2,\n\t): [Collection, Collection>];\n\tpublic partition(fn: (value: V, key: K, collection: this) => unknown): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): [Collection, Collection, V>];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => unknown,\n\t\tthisArg: This,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => unknown,\n\t\tthisArg?: unknown,\n\t): [Collection, Collection] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results: [Collection, Collection] = [\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t];\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) {\n\t\t\t\tresults[0].set(key, val);\n\t\t\t} else {\n\t\t\t\tresults[1].set(key, val);\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}.\n\t *\n\t * @param fn - Function that produces a new Collection\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.flatMap(guild => guild.members.cache);\n\t * ```\n\t */\n\tpublic flatMap(fn: (value: V, key: K, collection: this) => Collection): Collection;\n\tpublic flatMap(\n\t\tfn: (this: This, value: V, key: K, collection: this) => Collection,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic flatMap(fn: (value: V, key: K, collection: this) => Collection, thisArg?: unknown): Collection {\n\t\t// eslint-disable-next-line unicorn/no-array-method-this-argument\n\t\tconst collections = this.map(fn, thisArg);\n\t\treturn new this.constructor[Symbol.species]().concat(...collections);\n\t}\n\n\t/**\n\t * Maps each item to another value into an array. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new array, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.map(user => user.tag);\n\t * ```\n\t */\n\tpublic map(fn: (value: V, key: K, collection: this) => T): T[];\n\tpublic map(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): T[];\n\tpublic map(fn: (value: V, key: K, collection: this) => T, thisArg?: unknown): T[] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst iter = this.entries();\n\t\treturn Array.from({ length: this.size }, (): T => {\n\t\t\tconst [key, value] = iter.next().value;\n\t\t\treturn fn(value, key, this);\n\t\t});\n\t}\n\n\t/**\n\t * Maps each item to another value into a collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new collection, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.mapValues(user => user.tag);\n\t * ```\n\t */\n\tpublic mapValues(fn: (value: V, key: K, collection: this) => T): Collection;\n\tpublic mapValues(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): Collection;\n\tpublic mapValues(fn: (value: V, key: K, collection: this) => T, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) coll.set(key, fn(val, key, this));\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Checks if there exists an item that passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.some(user => user.discriminator === '0000');\n\t * ```\n\t */\n\tpublic some(fn: (value: V, key: K, collection: this) => unknown): boolean;\n\tpublic some(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): boolean;\n\tpublic some(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t * Checks if all items passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.every(user => !user.bot);\n\t * ```\n\t */\n\tpublic every(fn: (value: V, key: K, collection: this) => key is K2): this is Collection;\n\tpublic every(fn: (value: V, key: K, collection: this) => value is V2): this is Collection;\n\tpublic every(fn: (value: V, key: K, collection: this) => unknown): boolean;\n\tpublic every(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): boolean;\n\tpublic every(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (!fn(val, key, this)) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`,\n\t * and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t * @example\n\t * ```ts\n\t * collection.reduce((acc, guild) => acc + guild.memberCount, 0);\n\t * ```\n\t */\n\tpublic reduce(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue?: T): T {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tlet accumulator!: T;\n\n\t\tconst iterator = this.entries();\n\t\tif (initialValue === undefined) {\n\t\t\tif (this.size === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = iterator.next().value[1];\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t}\n\n\t\tfor (const [key, value] of iterator) {\n\t\t\taccumulator = fn(accumulator, value, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()},\n\t * but returns the collection instead of undefined.\n\t *\n\t * @param fn - Function to execute for each element\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .each(user => console.log(user.username))\n\t * .filter(user => user.bot)\n\t * .each(user => console.log(user.username));\n\t * ```\n\t */\n\tpublic each(fn: (value: V, key: K, collection: this) => void): this;\n\tpublic each(fn: (this: T, value: V, key: K, collection: this) => void, thisArg: T): this;\n\tpublic each(fn: (value: V, key: K, collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\n\t\tfor (const [key, value] of this) {\n\t\t\tfn(value, key, this);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Runs a function on the collection and returns the collection.\n\t *\n\t * @param fn - Function to execute\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .tap(coll => console.log(coll.size))\n\t * .filter(user => user.bot)\n\t * .tap(coll => console.log(coll.size))\n\t * ```\n\t */\n\tpublic tap(fn: (collection: this) => void): this;\n\tpublic tap(fn: (this: T, collection: this) => void, thisArg: T): this;\n\tpublic tap(fn: (collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfn(this);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Creates an identical shallow copy of this collection.\n\t *\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.clone();\n\t * ```\n\t */\n\tpublic clone(): Collection {\n\t\treturn new this.constructor[Symbol.species](this);\n\t}\n\n\t/**\n\t * Combines this collection with others into a new collection. None of the source collections are modified.\n\t *\n\t * @param collections - Collections to merge\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl);\n\t * ```\n\t */\n\tpublic concat(...collections: ReadonlyCollection[]) {\n\t\tconst newColl = this.clone();\n\t\tfor (const coll of collections) {\n\t\t\tfor (const [key, val] of coll) newColl.set(key, val);\n\t\t}\n\n\t\treturn newColl;\n\t}\n\n\t/**\n\t * Checks if this collection shares identical items with another.\n\t * This is different to checking for equality using equal-signs, because\n\t * the collections may be different objects, but contain the same data.\n\t *\n\t * @param collection - Collection to compare with\n\t * @returns Whether the collections have identical contents\n\t */\n\tpublic equals(collection: ReadonlyCollection) {\n\t\tif (!collection) return false; // runtime check\n\t\tif (this === collection) return true;\n\t\tif (this.size !== collection.size) return false;\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!collection.has(key) || value !== collection.get(key)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * The sort method sorts the items of a collection in place and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sort(compareFunction: Comparator = Collection.defaultSort) {\n\t\tconst entries = [...this.entries()];\n\t\tentries.sort((a, b): number => compareFunction(a[1], b[1], a[0], b[0]));\n\n\t\t// Perform clean-up\n\t\tsuper.clear();\n\n\t\t// Set the new entries\n\t\tfor (const [key, value] of entries) {\n\t\t\tsuper.set(key, value);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * The intersect method returns a new structure containing items where the keys and values are present in both original structures.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic intersect(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of other) {\n\t\t\tif (this.has(key) && Object.is(value, this.get(key))) {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic subtract(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key) || !Object.is(value, other.get(key))) {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic difference(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!this.has(key)) coll.set(key, value);\n\t\t}\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Merges two Collections together into a new Collection.\n\t *\n\t * @param other - The other Collection to merge with\n\t * @param whenInSelf - Function getting the result if the entry only exists in this Collection\n\t * @param whenInOther - Function getting the result if the entry only exists in the other Collection\n\t * @param whenInBoth - Function getting the result if the entry exists in both Collections\n\t * @example\n\t * ```ts\n\t * // Sums up the entries in two collections.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: true, value: x }),\n\t * y => ({ keep: true, value: y }),\n\t * (x, y) => ({ keep: true, value: x + y }),\n\t * );\n\t * ```\n\t * @example\n\t * ```ts\n\t * // Intersects two collections in a left-biased manner.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: false }),\n\t * y => ({ keep: false }),\n\t * (x, _) => ({ keep: true, value: x }),\n\t * );\n\t * ```\n\t */\n\tpublic merge(\n\t\tother: ReadonlyCollection,\n\t\twhenInSelf: (value: V, key: K) => Keep,\n\t\twhenInOther: (valueOther: T, key: K) => Keep,\n\t\twhenInBoth: (value: V, valueOther: T, key: K) => Keep,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tconst keys = new Set([...this.keys(), ...other.keys()]);\n\n\t\tfor (const key of keys) {\n\t\t\tconst hasInSelf = this.has(key);\n\t\t\tconst hasInOther = other.has(key);\n\n\t\t\tif (hasInSelf && hasInOther) {\n\t\t\t\tconst result = whenInBoth(this.get(key)!, other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInSelf) {\n\t\t\t\tconst result = whenInSelf(this.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInOther) {\n\t\t\t\tconst result = whenInOther(other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The sorted method sorts the items of a collection and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value,\n\t * according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sorted(compareFunction: Comparator = Collection.defaultSort) {\n\t\treturn new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk));\n\t}\n\n\tpublic toJSON() {\n\t\t// toJSON is called recursively by JSON.stringify.\n\t\treturn [...this.values()];\n\t}\n\n\tprivate static defaultSort(firstValue: V, secondValue: V): number {\n\t\treturn Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n\t}\n\n\t/**\n\t * Creates a Collection from a list of entries.\n\t *\n\t * @param entries - The list of entries\n\t * @param combine - Function to combine an existing entry with a new one\n\t * @example\n\t * ```ts\n\t * Collection.combineEntries([[\"a\", 1], [\"b\", 2], [\"a\", 2]], (x, y) => x + y);\n\t * // returns Collection { \"a\" => 3, \"b\" => 2 }\n\t * ```\n\t */\n\tpublic static combineEntries(\n\t\tentries: Iterable<[K, V]>,\n\t\tcombine: (firstValue: V, secondValue: V, key: K) => V,\n\t): Collection {\n\t\tconst coll = new Collection();\n\t\tfor (const [key, value] of entries) {\n\t\t\tif (coll.has(key)) {\n\t\t\t\tcoll.set(key, combine(coll.get(key)!, value, key));\n\t\t\t} else {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n}\n\n/**\n * @internal\n */\nexport type Keep = { keep: false } | { keep: true; value: V };\n\n/**\n * @internal\n */\nexport type Comparator = (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACqCO,IAAM,aAAN,MAAM,oBAAyB,IAAU;AAAA,EArChD,OAqCgD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWxC,OAAO,KAAQ,uBAA2D;AAChF,QAAI,KAAK,IAAI,GAAG;AAAG,aAAO,KAAK,IAAI,GAAG;AACtC,QAAI,OAAO,0BAA0B;AAAY,YAAM,IAAI,UAAU,GAAG,qBAAqB,oBAAoB;AACjH,UAAM,eAAe,sBAAsB,KAAK,IAAI;AACpD,SAAK,IAAI,KAAK,YAAY;AAC1B,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAU,MAAW;AAC3B,WAAO,KAAK,MAAM,CAAC,QAAQ,MAAM,IAAI,GAAG,CAAC;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAU,MAAW;AAC3B,WAAO,KAAK,KAAK,CAAC,QAAQ,MAAM,IAAI,GAAG,CAAC;AAAA,EACzC;AAAA,EAUO,MAAM,QAAsC;AAClD,QAAI,WAAW;AAAW,aAAO,KAAK,OAAO,EAAE,KAAK,EAAE;AACtD,QAAI,SAAS;AAAG,aAAO,KAAK,KAAK,SAAS,EAAE;AAC5C,aAAS,KAAK,IAAI,KAAK,MAAM,MAAM;AACnC,UAAM,OAAO,KAAK,OAAO;AACzB,WAAO,MAAM,KAAK,EAAE,QAAQ,OAAO,GAAG,MAAS,KAAK,KAAK,EAAE,KAAK;AAAA,EACjE;AAAA,EAWO,SAAS,QAAsC;AACrD,QAAI,WAAW;AAAW,aAAO,KAAK,KAAK,EAAE,KAAK,EAAE;AACpD,QAAI,SAAS;AAAG,aAAO,KAAK,QAAQ,SAAS,EAAE;AAC/C,aAAS,KAAK,IAAI,KAAK,MAAM,MAAM;AACnC,UAAM,OAAO,KAAK,KAAK;AACvB,WAAO,MAAM,KAAK,EAAE,QAAQ,OAAO,GAAG,MAAS,KAAK,KAAK,EAAE,KAAK;AAAA,EACjE;AAAA,EAWO,KAAK,QAAsC;AACjD,UAAM,MAAM,CAAC,GAAG,KAAK,OAAO,CAAC;AAC7B,QAAI,WAAW;AAAW,aAAO,IAAI,IAAI,SAAS,CAAC;AACnD,QAAI,SAAS;AAAG,aAAO,KAAK,MAAM,SAAS,EAAE;AAC7C,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,WAAO,IAAI,MAAM,CAAC,MAAM;AAAA,EACzB;AAAA,EAWO,QAAQ,QAAsC;AACpD,UAAM,MAAM,CAAC,GAAG,KAAK,KAAK,CAAC;AAC3B,QAAI,WAAW;AAAW,aAAO,IAAI,IAAI,SAAS,CAAC;AACnD,QAAI,SAAS;AAAG,aAAO,KAAK,SAAS,SAAS,EAAE;AAChD,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,WAAO,IAAI,MAAM,CAAC,MAAM;AAAA,EACzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASO,GAAG,OAAe;AACxB,YAAQ,KAAK,MAAM,KAAK;AACxB,UAAM,MAAM,CAAC,GAAG,KAAK,OAAO,CAAC;AAC7B,WAAO,IAAI,GAAG,KAAK;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASO,MAAM,OAAe;AAC3B,YAAQ,KAAK,MAAM,KAAK;AACxB,UAAM,MAAM,CAAC,GAAG,KAAK,KAAK,CAAC;AAC3B,WAAO,IAAI,GAAG,KAAK;AAAA,EACpB;AAAA,EAUO,OAAO,QAAsC;AACnD,UAAM,MAAM,CAAC,GAAG,KAAK,OAAO,CAAC;AAC7B,QAAI,WAAW;AAAW,aAAO,IAAI,KAAK,MAAM,KAAK,OAAO,IAAI,IAAI,MAAM,CAAC;AAC3E,QAAI,CAAC,IAAI,UAAU,CAAC;AAAQ,aAAO,CAAC;AACpC,WAAO,MAAM;AAAA,MACZ,EAAE,QAAQ,KAAK,IAAI,QAAQ,IAAI,MAAM,EAAE;AAAA,MACvC,MAAS,IAAI,OAAO,KAAK,MAAM,KAAK,OAAO,IAAI,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;AAAA,IACjE;AAAA,EACD;AAAA,EAUO,UAAU,QAAsC;AACtD,UAAM,MAAM,CAAC,GAAG,KAAK,KAAK,CAAC;AAC3B,QAAI,WAAW;AAAW,aAAO,IAAI,KAAK,MAAM,KAAK,OAAO,IAAI,IAAI,MAAM,CAAC;AAC3E,QAAI,CAAC,IAAI,UAAU,CAAC;AAAQ,aAAO,CAAC;AACpC,WAAO,MAAM;AAAA,MACZ,EAAE,QAAQ,KAAK,IAAI,QAAQ,IAAI,MAAM,EAAE;AAAA,MACvC,MAAS,IAAI,OAAO,KAAK,MAAM,KAAK,OAAO,IAAI,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;AAAA,IACjE;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAU;AAChB,UAAM,UAAU,CAAC,GAAG,KAAK,QAAQ,CAAC,EAAE,QAAQ;AAC5C,SAAK,MAAM;AACX,eAAW,CAAC,KAAK,KAAK,KAAK;AAAS,WAAK,IAAI,KAAK,KAAK;AACvD,WAAO;AAAA,EACR;AAAA,EAuBO,KAAK,IAAqD,SAAkC;AAClG,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI;AAAG,eAAO;AAAA,IAChC;AAEA,WAAO;AAAA,EACR;AAAA,EAqBO,QAAQ,IAAqD,SAAkC;AACrG,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI;AAAG,eAAO;AAAA,IAChC;AAEA,WAAO;AAAA,EACR;AAAA,EAWO,MAAM,IAAqD,SAA2B;AAC5F,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,UAAM,eAAe,KAAK;AAC1B,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI;AAAG,aAAK,OAAO,GAAG;AAAA,IACxC;AAEA,WAAO,eAAe,KAAK;AAAA,EAC5B;AAAA,EA0BO,OAAO,IAAqD,SAAqC;AACvG,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,UAAM,UAAU,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AAC3D,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI;AAAG,gBAAQ,IAAI,KAAK,GAAG;AAAA,IAC7C;AAEA,WAAO;AAAA,EACR;AAAA,EAgCO,UACN,IACA,SACuC;AACvC,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,UAAM,UAAgD;AAAA,MACrD,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AAAA,MAC3C,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AAAA,IAC5C;AACA,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI,GAAG;AACvB,gBAAQ,CAAC,EAAE,IAAI,KAAK,GAAG;AAAA,MACxB,OAAO;AACN,gBAAQ,CAAC,EAAE,IAAI,KAAK,GAAG;AAAA,MACxB;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA,EAkBO,QAAW,IAA8D,SAAqC;AAEpH,UAAM,cAAc,KAAK,IAAI,IAAI,OAAO;AACxC,WAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ,EAAE,OAAO,GAAG,WAAW;AAAA,EAC1E;AAAA,EAeO,IAAO,IAA+C,SAAwB;AACpF,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,UAAM,OAAO,KAAK,QAAQ;AAC1B,WAAO,MAAM,KAAK,EAAE,QAAQ,KAAK,KAAK,GAAG,MAAS;AACjD,YAAM,CAAC,KAAK,KAAK,IAAI,KAAK,KAAK,EAAE;AACjC,aAAO,GAAG,OAAO,KAAK,IAAI;AAAA,IAC3B,CAAC;AAAA,EACF;AAAA,EAeO,UAAa,IAA+C,SAAqC;AACvG,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,UAAM,OAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AACxD,eAAW,CAAC,KAAK,GAAG,KAAK;AAAM,WAAK,IAAI,KAAK,GAAG,KAAK,KAAK,IAAI,CAAC;AAC/D,WAAO;AAAA,EACR;AAAA,EAeO,KAAK,IAAqD,SAA4B;AAC5F,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,GAAG,KAAK,KAAK,IAAI;AAAG,eAAO;AAAA,IAChC;AAEA,WAAO;AAAA,EACR;AAAA,EAyBO,MAAM,IAAqD,SAA4B;AAC7F,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,eAAW,CAAC,KAAK,GAAG,KAAK,MAAM;AAC9B,UAAI,CAAC,GAAG,KAAK,KAAK,IAAI;AAAG,eAAO;AAAA,IACjC;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcO,OAAc,IAA+D,cAAqB;AACxG,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI;AAEJ,UAAM,WAAW,KAAK,QAAQ;AAC9B,QAAI,iBAAiB,QAAW;AAC/B,UAAI,KAAK,SAAS;AAAG,cAAM,IAAI,UAAU,kDAAkD;AAC3F,oBAAc,SAAS,KAAK,EAAE,MAAM,CAAC;AAAA,IACtC,OAAO;AACN,oBAAc;AAAA,IACf;AAEA,eAAW,CAAC,KAAK,KAAK,KAAK,UAAU;AACpC,oBAAc,GAAG,aAAa,OAAO,KAAK,IAAI;AAAA,IAC/C;AAEA,WAAO;AAAA,EACR;AAAA,EAmBO,KAAK,IAAkD,SAAyB;AACtF,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAE/C,eAAW,CAAC,KAAK,KAAK,KAAK,MAAM;AAChC,SAAG,OAAO,KAAK,IAAI;AAAA,IACpB;AAEA,WAAO;AAAA,EACR;AAAA,EAiBO,IAAI,IAAgC,SAAyB;AACnE,QAAI,OAAO,OAAO;AAAY,YAAM,IAAI,UAAU,GAAG,EAAE,oBAAoB;AAC3E,QAAI,YAAY;AAAW,WAAK,GAAG,KAAK,OAAO;AAC/C,OAAG,IAAI;AACP,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUO,QAA0B;AAChC,WAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAE,IAAI;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWO,UAAU,aAAyC;AACzD,UAAM,UAAU,KAAK,MAAM;AAC3B,eAAW,QAAQ,aAAa;AAC/B,iBAAW,CAAC,KAAK,GAAG,KAAK;AAAM,gBAAQ,IAAI,KAAK,GAAG;AAAA,IACpD;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUO,OAAO,YAAsC;AACnD,QAAI,CAAC;AAAY,aAAO;AACxB,QAAI,SAAS;AAAY,aAAO;AAChC,QAAI,KAAK,SAAS,WAAW;AAAM,aAAO;AAC1C,eAAW,CAAC,KAAK,KAAK,KAAK,MAAM;AAChC,UAAI,CAAC,WAAW,IAAI,GAAG,KAAK,UAAU,WAAW,IAAI,GAAG,GAAG;AAC1D,eAAO;AAAA,MACR;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcO,KAAK,kBAAoC,YAAW,aAAa;AACvE,UAAM,UAAU,CAAC,GAAG,KAAK,QAAQ,CAAC;AAClC,YAAQ,KAAK,CAAC,GAAG,MAAc,gBAAgB,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;AAGtE,UAAM,MAAM;AAGZ,eAAW,CAAC,KAAK,KAAK,KAAK,SAAS;AACnC,YAAM,IAAI,KAAK,KAAK;AAAA,IACrB;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,UAAa,OAAmD;AACtE,UAAM,OAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AACxD,eAAW,CAAC,KAAK,KAAK,KAAK,OAAO;AACjC,UAAI,KAAK,IAAI,GAAG,KAAK,OAAO,GAAG,OAAO,KAAK,IAAI,GAAG,CAAC,GAAG;AACrD,aAAK,IAAI,KAAK,KAAK;AAAA,MACpB;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,SAAY,OAAmD;AACrE,UAAM,OAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AACxD,eAAW,CAAC,KAAK,KAAK,KAAK,MAAM;AAChC,UAAI,CAAC,MAAM,IAAI,GAAG,KAAK,CAAC,OAAO,GAAG,OAAO,MAAM,IAAI,GAAG,CAAC,GAAG;AACzD,aAAK,IAAI,KAAK,KAAK;AAAA,MACpB;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,WAAc,OAAuD;AAC3E,UAAM,OAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAY;AAC5D,eAAW,CAAC,KAAK,KAAK,KAAK,OAAO;AACjC,UAAI,CAAC,KAAK,IAAI,GAAG;AAAG,aAAK,IAAI,KAAK,KAAK;AAAA,IACxC;AAEA,eAAW,CAAC,KAAK,KAAK,KAAK,MAAM;AAChC,UAAI,CAAC,MAAM,IAAI,GAAG;AAAG,aAAK,IAAI,KAAK,KAAK;AAAA,IACzC;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA8BO,MACN,OACA,YACA,aACA,YACmB;AACnB,UAAM,OAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAQ;AACxD,UAAM,OAAO,oBAAI,IAAI,CAAC,GAAG,KAAK,KAAK,GAAG,GAAG,MAAM,KAAK,CAAC,CAAC;AAEtD,eAAW,OAAO,MAAM;AACvB,YAAM,YAAY,KAAK,IAAI,GAAG;AAC9B,YAAM,aAAa,MAAM,IAAI,GAAG;AAEhC,UAAI,aAAa,YAAY;AAC5B,cAAM,SAAS,WAAW,KAAK,IAAI,GAAG,GAAI,MAAM,IAAI,GAAG,GAAI,GAAG;AAC9D,YAAI,OAAO;AAAM,eAAK,IAAI,KAAK,OAAO,KAAK;AAAA,MAC5C,WAAW,WAAW;AACrB,cAAM,SAAS,WAAW,KAAK,IAAI,GAAG,GAAI,GAAG;AAC7C,YAAI,OAAO;AAAM,eAAK,IAAI,KAAK,OAAO,KAAK;AAAA,MAC5C,WAAW,YAAY;AACtB,cAAM,SAAS,YAAY,MAAM,IAAI,GAAG,GAAI,GAAG;AAC/C,YAAI,OAAO;AAAM,eAAK,IAAI,KAAK,OAAO,KAAK;AAAA,MAC5C;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeO,OAAO,kBAAoC,YAAW,aAAa;AACzE,WAAO,IAAI,KAAK,YAAY,OAAO,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,IAAI,OAAO,gBAAgB,IAAI,IAAI,IAAI,EAAE,CAAC;AAAA,EAC3G;AAAA,EAEO,SAAS;AAEf,WAAO,CAAC,GAAG,KAAK,OAAO,CAAC;AAAA,EACzB;AAAA,EAEA,OAAe,YAAe,YAAe,aAAwB;AACpE,WAAO,OAAO,aAAa,WAAW,KAAK,OAAO,eAAe,WAAW,IAAI;AAAA,EACjF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,OAAc,eACb,SACA,SACmB;AACnB,UAAM,OAAO,IAAI,YAAiB;AAClC,eAAW,CAAC,KAAK,KAAK,KAAK,SAAS;AACnC,UAAI,KAAK,IAAI,GAAG,GAAG;AAClB,aAAK,IAAI,KAAK,QAAQ,KAAK,IAAI,GAAG,GAAI,OAAO,GAAG,CAAC;AAAA,MAClD,OAAO;AACN,aAAK,IAAI,KAAK,KAAK;AAAA,MACpB;AAAA,IACD;AAEA,WAAO;AAAA,EACR;AACD;;;AD9yBO,IAAM,UAAU;","names":[]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs new file mode 100644 index 0000000..c31c9ee --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs @@ -0,0 +1,517 @@ +var __defProp = Object.defineProperty; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); + +// src/collection.ts +var Collection = class _Collection extends Map { + static { + __name(this, "Collection"); + } + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key, defaultValueGenerator) { + if (this.has(key)) + return this.get(key); + if (typeof defaultValueGenerator !== "function") + throw new TypeError(`${defaultValueGenerator} is not a function`); + const defaultValue = defaultValueGenerator(key, this); + this.set(key, defaultValue); + return defaultValue; + } + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys) { + return keys.every((key) => super.has(key)); + } + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys) { + return keys.some((key) => super.has(key)); + } + first(amount) { + if (amount === void 0) + return this.values().next().value; + if (amount < 0) + return this.last(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.values(); + return Array.from({ length: amount }, () => iter.next().value); + } + firstKey(amount) { + if (amount === void 0) + return this.keys().next().value; + if (amount < 0) + return this.lastKey(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.keys(); + return Array.from({ length: amount }, () => iter.next().value); + } + last(amount) { + const arr = [...this.values()]; + if (amount === void 0) + return arr[arr.length - 1]; + if (amount < 0) + return this.first(amount * -1); + if (!amount) + return []; + return arr.slice(-amount); + } + lastKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) + return arr[arr.length - 1]; + if (amount < 0) + return this.firstKey(amount * -1); + if (!amount) + return []; + return arr.slice(-amount); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index) { + index = Math.floor(index); + const arr = [...this.values()]; + return arr.at(index); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index) { + index = Math.floor(index); + const arr = [...this.keys()]; + return arr.at(index); + } + random(amount) { + const arr = [...this.values()]; + if (amount === void 0) + return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) + return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + randomKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) + return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) + return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse() { + const entries = [...this.entries()].reverse(); + this.clear(); + for (const [key, value] of entries) + this.set(key, value); + return this; + } + find(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return val; + } + return void 0; + } + findKey(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return key; + } + return void 0; + } + sweep(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const previousSize = this.size; + for (const [key, val] of this) { + if (fn(val, key, this)) + this.delete(key); + } + return previousSize - this.size; + } + filter(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const results = new this.constructor[Symbol.species](); + for (const [key, val] of this) { + if (fn(val, key, this)) + results.set(key, val); + } + return results; + } + partition(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const results = [ + new this.constructor[Symbol.species](), + new this.constructor[Symbol.species]() + ]; + for (const [key, val] of this) { + if (fn(val, key, this)) { + results[0].set(key, val); + } else { + results[1].set(key, val); + } + } + return results; + } + flatMap(fn, thisArg) { + const collections = this.map(fn, thisArg); + return new this.constructor[Symbol.species]().concat(...collections); + } + map(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const iter = this.entries(); + return Array.from({ length: this.size }, () => { + const [key, value] = iter.next().value; + return fn(value, key, this); + }); + } + mapValues(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + const coll = new this.constructor[Symbol.species](); + for (const [key, val] of this) + coll.set(key, fn(val, key, this)); + return coll; + } + some(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) + return true; + } + return false; + } + every(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (!fn(val, key, this)) + return false; + } + return true; + } + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn, initialValue) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + let accumulator; + const iterator = this.entries(); + if (initialValue === void 0) { + if (this.size === 0) + throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = iterator.next().value[1]; + } else { + accumulator = initialValue; + } + for (const [key, value] of iterator) { + accumulator = fn(accumulator, value, key, this); + } + return accumulator; + } + each(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + for (const [key, value] of this) { + fn(value, key, this); + } + return this; + } + tap(fn, thisArg) { + if (typeof fn !== "function") + throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) + fn = fn.bind(thisArg); + fn(this); + return this; + } + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone() { + return new this.constructor[Symbol.species](this); + } + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections) { + const newColl = this.clone(); + for (const coll of collections) { + for (const [key, val] of coll) + newColl.set(key, val); + } + return newColl; + } + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection) { + if (!collection) + return false; + if (this === collection) + return true; + if (this.size !== collection.size) + return false; + for (const [key, value] of this) { + if (!collection.has(key) || value !== collection.get(key)) { + return false; + } + } + return true; + } + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction = _Collection.defaultSort) { + const entries = [...this.entries()]; + entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0])); + super.clear(); + for (const [key, value] of entries) { + super.set(key, value); + } + return this; + } + /** + * The intersect method returns a new structure containing items where the keys and values are present in both original structures. + * + * @param other - The other Collection to filter against + */ + intersect(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of other) { + if (this.has(key) && Object.is(value, this.get(key))) { + coll.set(key, value); + } + } + return coll; + } + /** + * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other. + * + * @param other - The other Collection to filter against + */ + subtract(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key) || !Object.is(value, other.get(key))) { + coll.set(key, value); + } + } + return coll; + } + /** + * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other. + * + * @param other - The other Collection to filter against + */ + difference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of other) { + if (!this.has(key)) + coll.set(key, value); + } + for (const [key, value] of this) { + if (!other.has(key)) + coll.set(key, value); + } + return coll; + } + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other, whenInSelf, whenInOther, whenInBoth) { + const coll = new this.constructor[Symbol.species](); + const keys = /* @__PURE__ */ new Set([...this.keys(), ...other.keys()]); + for (const key of keys) { + const hasInSelf = this.has(key); + const hasInOther = other.has(key); + if (hasInSelf && hasInOther) { + const result = whenInBoth(this.get(key), other.get(key), key); + if (result.keep) + coll.set(key, result.value); + } else if (hasInSelf) { + const result = whenInSelf(this.get(key), key); + if (result.keep) + coll.set(key, result.value); + } else if (hasInOther) { + const result = whenInOther(other.get(key), key); + if (result.keep) + coll.set(key, result.value); + } + } + return coll; + } + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sorted(compareFunction = _Collection.defaultSort) { + return new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk)); + } + toJSON() { + return [...this.values()]; + } + static defaultSort(firstValue, secondValue) { + return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1; + } + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries, combine) { + const coll = new _Collection(); + for (const [key, value] of entries) { + if (coll.has(key)) { + coll.set(key, combine(coll.get(key), value, key)); + } else { + coll.set(key, value); + } + } + return coll; + } +}; + +// src/index.ts +var version = "1.5.3"; +export { + Collection, + version +}; +//# sourceMappingURL=index.mjs.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs.map b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs.map new file mode 100644 index 0000000..fcf72ab --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/dist/index.mjs.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/collection.ts","../src/index.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\n/**\n * @internal\n */\nexport interface CollectionConstructor {\n\tnew (): Collection;\n\tnew (entries?: readonly (readonly [K, V])[] | null): Collection;\n\tnew (iterable: Iterable): Collection;\n\treadonly prototype: Collection;\n\treadonly [Symbol.species]: CollectionConstructor;\n}\n\n/**\n * Represents an immutable version of a collection\n */\nexport type ReadonlyCollection = Omit<\n\tCollection,\n\t'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'\n> &\n\tReadonlyMap;\n\n/**\n * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself\n *\n * @internal\n */\nexport interface Collection extends Map {\n\tconstructor: CollectionConstructor;\n}\n\n/**\n * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has\n * an ID, for significantly improved performance and ease-of-use.\n *\n * @typeParam K - The key type this collection holds\n * @typeParam V - The value type this collection holds\n */\nexport class Collection extends Map {\n\t/**\n\t * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator.\n\t *\n\t * @param key - The key to get if it exists, or set otherwise\n\t * @param defaultValueGenerator - A function that generates the default value\n\t * @example\n\t * ```ts\n\t * collection.ensure(guildId, () => defaultGuildConfig);\n\t * ```\n\t */\n\tpublic ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\n\t\tif (this.has(key)) return this.get(key)!;\n\t\tif (typeof defaultValueGenerator !== 'function') throw new TypeError(`${defaultValueGenerator} is not a function`);\n\t\tconst defaultValue = defaultValueGenerator(key, this);\n\t\tthis.set(key, defaultValue);\n\t\treturn defaultValue;\n\t}\n\n\t/**\n\t * Checks if all of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if all of the elements exist, `false` if at least one does not exist.\n\t */\n\tpublic hasAll(...keys: K[]) {\n\t\treturn keys.every((key) => super.has(key));\n\t}\n\n\t/**\n\t * Checks if any of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if any of the elements exist, `false` if none exist.\n\t */\n\tpublic hasAny(...keys: K[]) {\n\t\treturn keys.some((key) => super.has(key));\n\t}\n\n\t/**\n\t * Obtains the first value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the beginning\n\t * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative\n\t */\n\tpublic first(): V | undefined;\n\tpublic first(amount: number): V[];\n\tpublic first(amount?: number): V | V[] | undefined {\n\t\tif (amount === undefined) return this.values().next().value;\n\t\tif (amount < 0) return this.last(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.values();\n\t\treturn Array.from({ length: amount }, (): V => iter.next().value);\n\t}\n\n\t/**\n\t * Obtains the first key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the beginning\n\t * @returns A single key if no amount is provided or an array of keys, starting from the end if\n\t * amount is negative\n\t */\n\tpublic firstKey(): K | undefined;\n\tpublic firstKey(amount: number): K[];\n\tpublic firstKey(amount?: number): K | K[] | undefined {\n\t\tif (amount === undefined) return this.keys().next().value;\n\t\tif (amount < 0) return this.lastKey(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.keys();\n\t\treturn Array.from({ length: amount }, (): K => iter.next().value);\n\t}\n\n\t/**\n\t * Obtains the last value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the end\n\t * @returns A single value if no amount is provided or an array of values, starting from the start if\n\t * amount is negative\n\t */\n\tpublic last(): V | undefined;\n\tpublic last(amount: number): V[];\n\tpublic last(amount?: number): V | V[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.first(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Obtains the last key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the end\n\t * @returns A single key if no amount is provided or an array of keys, starting from the start if\n\t * amount is negative\n\t */\n\tpublic lastKey(): K | undefined;\n\tpublic lastKey(amount: number): K[];\n\tpublic lastKey(amount?: number): K | K[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.firstKey(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the item at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the element to obtain\n\t */\n\tpublic at(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.values()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the key at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the key to obtain\n\t */\n\tpublic keyAt(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.keys()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Obtains unique random value(s) from this collection.\n\t *\n\t * @param amount - Amount of values to obtain randomly\n\t * @returns A single value if no amount is provided or an array of values\n\t */\n\tpublic random(): V | undefined;\n\tpublic random(amount: number): V[];\n\tpublic random(amount?: number): V | V[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): V => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Obtains unique random key(s) from this collection.\n\t *\n\t * @param amount - Amount of keys to obtain randomly\n\t * @returns A single key if no amount is provided or an array\n\t */\n\tpublic randomKey(): K | undefined;\n\tpublic randomKey(amount: number): K[];\n\tpublic randomKey(amount?: number): K | K[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): K => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic reverse() {\n\t\tconst entries = [...this.entries()].reverse();\n\t\tthis.clear();\n\t\tfor (const [key, value] of entries) this.set(key, value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Searches for a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}.\n\t * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you\n\t * should use the `get` method. See\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.find(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic find(fn: (value: V, key: K, collection: this) => value is V2): V2 | undefined;\n\tpublic find(fn: (value: V, key: K, collection: this) => unknown): V | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): V2 | undefined;\n\tpublic find(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): V | undefined;\n\tpublic find(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): V | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.findKey(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic findKey(fn: (value: V, key: K, collection: this) => key is K2): K2 | undefined;\n\tpublic findKey(fn: (value: V, key: K, collection: this) => unknown): K | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): K2 | undefined;\n\tpublic findKey(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): K | undefined;\n\tpublic findKey(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): K | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Removes items that satisfy the provided filter function.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @returns The number of removed entries\n\t */\n\tpublic sweep(fn: (value: V, key: K, collection: this) => unknown): number;\n\tpublic sweep(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): number;\n\tpublic sweep(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): number {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst previousSize = this.size;\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) this.delete(key);\n\t\t}\n\n\t\treturn previousSize - this.size;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()},\n\t * but returns a Collection instead of an Array.\n\t *\n\t * @param fn - The function to test with (should return boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.filter(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic filter(fn: (value: V, key: K, collection: this) => key is K2): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => value is V2): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => unknown): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): Collection;\n\tpublic filter(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) results.set(key, val);\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Partitions the collection into two collections where the first collection\n\t * contains the items that passed and the second contains the items that failed.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * const [big, small] = collection.partition(guild => guild.memberCount > 250);\n\t * ```\n\t */\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => key is K2,\n\t): [Collection, Collection, V>];\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => value is V2,\n\t): [Collection, Collection>];\n\tpublic partition(fn: (value: V, key: K, collection: this) => unknown): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): [Collection, Collection, V>];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (this: This, value: V, key: K, collection: this) => unknown,\n\t\tthisArg: This,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (value: V, key: K, collection: this) => unknown,\n\t\tthisArg?: unknown,\n\t): [Collection, Collection] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results: [Collection, Collection] = [\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t];\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) {\n\t\t\t\tresults[0].set(key, val);\n\t\t\t} else {\n\t\t\t\tresults[1].set(key, val);\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}.\n\t *\n\t * @param fn - Function that produces a new Collection\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.flatMap(guild => guild.members.cache);\n\t * ```\n\t */\n\tpublic flatMap(fn: (value: V, key: K, collection: this) => Collection): Collection;\n\tpublic flatMap(\n\t\tfn: (this: This, value: V, key: K, collection: this) => Collection,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic flatMap(fn: (value: V, key: K, collection: this) => Collection, thisArg?: unknown): Collection {\n\t\t// eslint-disable-next-line unicorn/no-array-method-this-argument\n\t\tconst collections = this.map(fn, thisArg);\n\t\treturn new this.constructor[Symbol.species]().concat(...collections);\n\t}\n\n\t/**\n\t * Maps each item to another value into an array. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new array, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.map(user => user.tag);\n\t * ```\n\t */\n\tpublic map(fn: (value: V, key: K, collection: this) => T): T[];\n\tpublic map(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): T[];\n\tpublic map(fn: (value: V, key: K, collection: this) => T, thisArg?: unknown): T[] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst iter = this.entries();\n\t\treturn Array.from({ length: this.size }, (): T => {\n\t\t\tconst [key, value] = iter.next().value;\n\t\t\treturn fn(value, key, this);\n\t\t});\n\t}\n\n\t/**\n\t * Maps each item to another value into a collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new collection, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.mapValues(user => user.tag);\n\t * ```\n\t */\n\tpublic mapValues(fn: (value: V, key: K, collection: this) => T): Collection;\n\tpublic mapValues(fn: (this: This, value: V, key: K, collection: this) => T, thisArg: This): Collection;\n\tpublic mapValues(fn: (value: V, key: K, collection: this) => T, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) coll.set(key, fn(val, key, this));\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Checks if there exists an item that passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.some(user => user.discriminator === '0000');\n\t * ```\n\t */\n\tpublic some(fn: (value: V, key: K, collection: this) => unknown): boolean;\n\tpublic some(fn: (this: T, value: V, key: K, collection: this) => unknown, thisArg: T): boolean;\n\tpublic some(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t * Checks if all items passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection.every(user => !user.bot);\n\t * ```\n\t */\n\tpublic every(fn: (value: V, key: K, collection: this) => key is K2): this is Collection;\n\tpublic every(fn: (value: V, key: K, collection: this) => value is V2): this is Collection;\n\tpublic every(fn: (value: V, key: K, collection: this) => unknown): boolean;\n\tpublic every(\n\t\tfn: (this: This, value: V, key: K, collection: this) => key is K2,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (this: This, value: V, key: K, collection: this) => value is V2,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(fn: (this: This, value: V, key: K, collection: this) => unknown, thisArg: This): boolean;\n\tpublic every(fn: (value: V, key: K, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (!fn(val, key, this)) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`,\n\t * and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t * @example\n\t * ```ts\n\t * collection.reduce((acc, guild) => acc + guild.memberCount, 0);\n\t * ```\n\t */\n\tpublic reduce(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue?: T): T {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tlet accumulator!: T;\n\n\t\tconst iterator = this.entries();\n\t\tif (initialValue === undefined) {\n\t\t\tif (this.size === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = iterator.next().value[1];\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t}\n\n\t\tfor (const [key, value] of iterator) {\n\t\t\taccumulator = fn(accumulator, value, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()},\n\t * but returns the collection instead of undefined.\n\t *\n\t * @param fn - Function to execute for each element\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .each(user => console.log(user.username))\n\t * .filter(user => user.bot)\n\t * .each(user => console.log(user.username));\n\t * ```\n\t */\n\tpublic each(fn: (value: V, key: K, collection: this) => void): this;\n\tpublic each(fn: (this: T, value: V, key: K, collection: this) => void, thisArg: T): this;\n\tpublic each(fn: (value: V, key: K, collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\n\t\tfor (const [key, value] of this) {\n\t\t\tfn(value, key, this);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Runs a function on the collection and returns the collection.\n\t *\n\t * @param fn - Function to execute\n\t * @param thisArg - Value to use as `this` when executing function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .tap(coll => console.log(coll.size))\n\t * .filter(user => user.bot)\n\t * .tap(coll => console.log(coll.size))\n\t * ```\n\t */\n\tpublic tap(fn: (collection: this) => void): this;\n\tpublic tap(fn: (this: T, collection: this) => void, thisArg: T): this;\n\tpublic tap(fn: (collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfn(this);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Creates an identical shallow copy of this collection.\n\t *\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.clone();\n\t * ```\n\t */\n\tpublic clone(): Collection {\n\t\treturn new this.constructor[Symbol.species](this);\n\t}\n\n\t/**\n\t * Combines this collection with others into a new collection. None of the source collections are modified.\n\t *\n\t * @param collections - Collections to merge\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl);\n\t * ```\n\t */\n\tpublic concat(...collections: ReadonlyCollection[]) {\n\t\tconst newColl = this.clone();\n\t\tfor (const coll of collections) {\n\t\t\tfor (const [key, val] of coll) newColl.set(key, val);\n\t\t}\n\n\t\treturn newColl;\n\t}\n\n\t/**\n\t * Checks if this collection shares identical items with another.\n\t * This is different to checking for equality using equal-signs, because\n\t * the collections may be different objects, but contain the same data.\n\t *\n\t * @param collection - Collection to compare with\n\t * @returns Whether the collections have identical contents\n\t */\n\tpublic equals(collection: ReadonlyCollection) {\n\t\tif (!collection) return false; // runtime check\n\t\tif (this === collection) return true;\n\t\tif (this.size !== collection.size) return false;\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!collection.has(key) || value !== collection.get(key)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * The sort method sorts the items of a collection in place and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sort(compareFunction: Comparator = Collection.defaultSort) {\n\t\tconst entries = [...this.entries()];\n\t\tentries.sort((a, b): number => compareFunction(a[1], b[1], a[0], b[0]));\n\n\t\t// Perform clean-up\n\t\tsuper.clear();\n\n\t\t// Set the new entries\n\t\tfor (const [key, value] of entries) {\n\t\t\tsuper.set(key, value);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * The intersect method returns a new structure containing items where the keys and values are present in both original structures.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic intersect(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of other) {\n\t\t\tif (this.has(key) && Object.is(value, this.get(key))) {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The subtract method returns a new structure containing items where the keys and values of the original structure are not present in the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic subtract(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key) || !Object.is(value, other.get(key))) {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The difference method returns a new structure containing items where the key is present in one of the original structures but not the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t */\n\tpublic difference(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!this.has(key)) coll.set(key, value);\n\t\t}\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Merges two Collections together into a new Collection.\n\t *\n\t * @param other - The other Collection to merge with\n\t * @param whenInSelf - Function getting the result if the entry only exists in this Collection\n\t * @param whenInOther - Function getting the result if the entry only exists in the other Collection\n\t * @param whenInBoth - Function getting the result if the entry exists in both Collections\n\t * @example\n\t * ```ts\n\t * // Sums up the entries in two collections.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: true, value: x }),\n\t * y => ({ keep: true, value: y }),\n\t * (x, y) => ({ keep: true, value: x + y }),\n\t * );\n\t * ```\n\t * @example\n\t * ```ts\n\t * // Intersects two collections in a left-biased manner.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: false }),\n\t * y => ({ keep: false }),\n\t * (x, _) => ({ keep: true, value: x }),\n\t * );\n\t * ```\n\t */\n\tpublic merge(\n\t\tother: ReadonlyCollection,\n\t\twhenInSelf: (value: V, key: K) => Keep,\n\t\twhenInOther: (valueOther: T, key: K) => Keep,\n\t\twhenInBoth: (value: V, valueOther: T, key: K) => Keep,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tconst keys = new Set([...this.keys(), ...other.keys()]);\n\n\t\tfor (const key of keys) {\n\t\t\tconst hasInSelf = this.has(key);\n\t\t\tconst hasInOther = other.has(key);\n\n\t\t\tif (hasInSelf && hasInOther) {\n\t\t\t\tconst result = whenInBoth(this.get(key)!, other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInSelf) {\n\t\t\t\tconst result = whenInSelf(this.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInOther) {\n\t\t\t\tconst result = whenInOther(other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * The sorted method sorts the items of a collection and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value,\n\t * according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sorted(compareFunction: Comparator = Collection.defaultSort) {\n\t\treturn new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk));\n\t}\n\n\tpublic toJSON() {\n\t\t// toJSON is called recursively by JSON.stringify.\n\t\treturn [...this.values()];\n\t}\n\n\tprivate static defaultSort(firstValue: V, secondValue: V): number {\n\t\treturn Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n\t}\n\n\t/**\n\t * Creates a Collection from a list of entries.\n\t *\n\t * @param entries - The list of entries\n\t * @param combine - Function to combine an existing entry with a new one\n\t * @example\n\t * ```ts\n\t * Collection.combineEntries([[\"a\", 1], [\"b\", 2], [\"a\", 2]], (x, y) => x + y);\n\t * // returns Collection { \"a\" => 3, \"b\" => 2 }\n\t * ```\n\t */\n\tpublic static combineEntries(\n\t\tentries: Iterable<[K, V]>,\n\t\tcombine: (firstValue: V, secondValue: V, key: K) => V,\n\t): Collection {\n\t\tconst coll = new Collection();\n\t\tfor (const [key, value] of entries) {\n\t\t\tif (coll.has(key)) {\n\t\t\t\tcoll.set(key, combine(coll.get(key)!, value, key));\n\t\t\t} else {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n}\n\n/**\n * @internal\n */\nexport type Keep = { keep: false } | { keep: true; value: V };\n\n/**\n * @internal\n */\nexport type Comparator = (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number;\n","export * from './collection.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection/#readme | @discordjs/collection} version\n * that you are currently using.\n */\n// This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild\nexport const version = '1.5.3' as string;\n"],"mappings":"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","names":[]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/package.json b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/package.json new file mode 100644 index 0000000..81e2418 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@1.5.3/node_modules/@discordjs/collection/package.json @@ -0,0 +1,76 @@ +{ + "name": "@discordjs/collection", + "version": "1.5.3", + "description": "Utility data structure used in discord.js", + "scripts": { + "test": "vitest run", + "build": "tsup", + "build:docs": "tsc -p tsconfig.docs.json", + "lint": "prettier --check . && cross-env TIMING=1 eslint src __tests__ --ext .mjs,.js,.ts --format=pretty", + "format": "prettier --write . && cross-env TIMING=1 eslint src __tests__ --ext .mjs,.js,.ts --fix --format=pretty", + "fmt": "yarn format", + "docs": "yarn build:docs && api-extractor run --local && api-extractor run --local --config ./api-extractor-docs.json", + "prepack": "yarn lint && yarn test && yarn build", + "changelog": "git cliff --prepend ./CHANGELOG.md -u -c ./cliff.toml -r ../../ --include-path 'packages/collection/*'", + "release": "cliff-jumper" + }, + "main": "./dist/index.js", + "module": "./dist/index.mjs", + "types": "./dist/index.d.ts", + "exports": { + "types": "./dist/index.d.ts", + "import": "./dist/index.mjs", + "require": "./dist/index.js" + }, + "directories": { + "lib": "src", + "test": "__tests__" + }, + "files": [ + "dist" + ], + "contributors": [ + "Crawl ", + "Amish Shah ", + "SpaceEEC ", + "Vlad Frangu ", + "Aura Román " + ], + "license": "Apache-2.0", + "keywords": [ + "map", + "collection", + "utility" + ], + "repository": { + "type": "git", + "url": "https://github.com/discordjs/discord.js.git", + "directory": "packages/collection" + }, + "bugs": { + "url": "https://github.com/discordjs/discord.js/issues" + }, + "homepage": "https://discord.js.org", + "devDependencies": { + "@favware/cliff-jumper": "^2.1.1", + "@microsoft/api-extractor": "^7.36.4", + "@types/node": "16.18.40", + "@vitest/coverage-v8": "^0.34.2", + "cross-env": "^7.0.3", + "esbuild-plugin-version-injector": "^1.2.0", + "eslint": "^8.47.0", + "eslint-config-neon": "^0.1.47", + "eslint-formatter-pretty": "^5.0.0", + "prettier": "^2.8.8", + "tsup": "^7.2.0", + "turbo": "^1.10.12", + "typescript": "^5.1.6", + "vitest": "^0.34.2" + }, + "engines": { + "node": ">=16.11.0" + }, + "publishConfig": { + "access": "public" + } +} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/LICENSE b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/LICENSE new file mode 100644 index 0000000..d21f37a --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/LICENSE @@ -0,0 +1,191 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + Copyright 2021 Noel Buechler + Copyright 2015 Amish Shah + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/README.md b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/README.md new file mode 100644 index 0000000..21d1dcc --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/README.md @@ -0,0 +1,67 @@ +
+
+

+ discord.js +

+
+

+ Discord server + npm version + npm downloads + Build status + Code coverage +

+

+ Vercel + Cloudflare Workers +

+
+ +## About + +`@discordjs/collection` is a powerful utility data structure used in discord.js. + +## Installation + +**Node.js 18 or newer is required.** + +```sh +npm install @discordjs/collection +yarn add @discordjs/collection +pnpm add @discordjs/collection +``` + +## Links + +- [Website][website] ([source][website-source]) +- [Documentation][documentation] +- [Guide][guide] ([source][guide-source]) + Also see the v13 to v14 [Update Guide][guide-update], which includes updated and removed items from the library. +- [discord.js Discord server][discord] +- [Discord API Discord server][discord-api] +- [GitHub][source] +- [npm][npm] +- [Related libraries][related-libs] + +## Contributing + +Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the +[documentation][documentation]. +See [the contribution guide][contributing] if you'd like to submit a PR. + +## Help + +If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official [discord.js Server][discord]. + +[website]: https://discord.js.org +[website-source]: https://github.com/discordjs/discord.js/tree/main/apps/website +[documentation]: https://discord.js.org/docs/packages/collection/stable +[guide]: https://discordjs.guide/ +[guide-source]: https://github.com/discordjs/guide +[guide-update]: https://discordjs.guide/additional-info/changes-in-v14.html +[discord]: https://discord.gg/djs +[discord-api]: https://discord.gg/discord-api +[source]: https://github.com/discordjs/discord.js/tree/main/packages/collection +[npm]: https://www.npmjs.com/package/@discordjs/collection +[related-libs]: https://discord.com/developers/docs/topics/community-resources#libraries +[contributing]: https://github.com/discordjs/discord.js/blob/main/.github/CONTRIBUTING.md diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.mts b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.mts new file mode 100644 index 0000000..859730c --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.mts @@ -0,0 +1,537 @@ +/** + * @internal + */ +interface CollectionConstructor { + new (): Collection; + new (entries?: readonly (readonly [Key, Value])[] | null): Collection; + new (iterable: Iterable): Collection; + readonly prototype: Collection; + readonly [Symbol.species]: CollectionConstructor; +} +/** + * Represents an immutable version of a collection + */ +type ReadonlyCollection = Omit, 'clear' | 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'> & ReadonlyMap; +/** + * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself + * + * @internal + */ +interface Collection extends Map { + constructor: CollectionConstructor; +} +/** + * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has + * an ID, for significantly improved performance and ease-of-use. + * + * @typeParam Key - The key type this collection holds + * @typeParam Value - The value type this collection holds + */ +declare class Collection extends Map { + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key: Key, defaultValueGenerator: (key: Key, collection: this) => Value): Value; + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys: Key[]): boolean; + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys: Key[]): boolean; + /** + * Obtains the first value(s) in this collection. + * + * @param amount - Amount of values to obtain from the beginning + * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative + */ + first(): Value | undefined; + first(amount: number): Value[]; + /** + * Obtains the first key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the beginning + * @returns A single key if no amount is provided or an array of keys, starting from the end if + * amount is negative + */ + firstKey(): Key | undefined; + firstKey(amount: number): Key[]; + /** + * Obtains the last value(s) in this collection. + * + * @param amount - Amount of values to obtain from the end + * @returns A single value if no amount is provided or an array of values, starting from the start if + * amount is negative + */ + last(): Value | undefined; + last(amount: number): Value[]; + /** + * Obtains the last key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the end + * @returns A single key if no amount is provided or an array of keys, starting from the start if + * amount is negative + */ + lastKey(): Key | undefined; + lastKey(amount: number): Key[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index: number): Value | undefined; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index: number): Key | undefined; + /** + * Obtains unique random value(s) from this collection. + * + * @param amount - Amount of values to obtain randomly + * @returns A single value if no amount is provided or an array of values + */ + random(): Value | undefined; + random(amount: number): Value[]; + /** + * Obtains unique random key(s) from this collection. + * + * @param amount - Amount of keys to obtain randomly + * @returns A single key if no amount is provided or an array + */ + randomKey(): Key | undefined; + randomKey(amount: number): Key[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse(): this; + /** + * Searches for a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}. + * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you + * should use the `get` method. See + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.find(user => user.username === 'Bob'); + * ``` + */ + find(fn: (value: Value, key: Key, collection: this) => value is NewValue): NewValue | undefined; + find(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined; + find(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): NewValue | undefined; + find(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Value | undefined; + /** + * Searches for the key of a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.findKey(user => user.username === 'Bob'); + * ``` + */ + findKey(fn: (value: Value, key: Key, collection: this) => key is NewKey): NewKey | undefined; + findKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined; + findKey(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): NewKey | undefined; + findKey(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Key | undefined; + /** + * Searches for a last item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLast | Array.findLast()}. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + */ + findLast(fn: (value: Value, key: Key, collection: this) => value is NewValue): NewValue | undefined; + findLast(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined; + findLast(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): NewValue | undefined; + findLast(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Value | undefined; + /** + * Searches for the key of a last item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLastIndex | Array.findLastIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + */ + findLastKey(fn: (value: Value, key: Key, collection: this) => key is NewKey): NewKey | undefined; + findLastKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined; + findLastKey(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): NewKey | undefined; + findLastKey(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Key | undefined; + /** + * Removes items that satisfy the provided filter function. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @returns The number of removed entries + */ + sweep(fn: (value: Value, key: Key, collection: this) => unknown): number; + sweep(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): number; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()}, + * but returns a Collection instead of an Array. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.filter(user => user.username === 'Bob'); + * ``` + */ + filter(fn: (value: Value, key: Key, collection: this) => key is NewKey): Collection; + filter(fn: (value: Value, key: Key, collection: this) => value is NewValue): Collection; + filter(fn: (value: Value, key: Key, collection: this) => unknown): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Collection; + /** + * Partitions the collection into two collections where the first collection + * contains the items that passed and the second contains the items that failed. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * const [big, small] = collection.partition(guild => guild.memberCount > 250); + * ``` + */ + partition(fn: (value: Value, key: Key, collection: this) => key is NewKey): [Collection, Collection, Value>]; + partition(fn: (value: Value, key: Key, collection: this) => value is NewValue): [Collection, Collection>]; + partition(fn: (value: Value, key: Key, collection: this) => unknown): [Collection, Collection]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): [Collection, Collection, Value>]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): [Collection, Collection>]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): [Collection, Collection]; + /** + * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}. + * + * @param fn - Function that produces a new Collection + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.flatMap(guild => guild.members.cache); + * ``` + */ + flatMap(fn: (value: Value, key: Key, collection: this) => Collection): Collection; + flatMap(fn: (this: This, value: Value, key: Key, collection: this) => Collection, thisArg: This): Collection; + /** + * Maps each item to another value into an array. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new array, taking three arguments + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.map(user => user.tag); + * ``` + */ + map(fn: (value: Value, key: Key, collection: this) => NewValue): NewValue[]; + map(fn: (this: This, value: Value, key: Key, collection: this) => NewValue, thisArg: This): NewValue[]; + /** + * Maps each item to another value into a collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new collection, taking three arguments + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.mapValues(user => user.tag); + * ``` + */ + mapValues(fn: (value: Value, key: Key, collection: this) => NewValue): Collection; + mapValues(fn: (this: This, value: Value, key: Key, collection: this) => NewValue, thisArg: This): Collection; + /** + * Checks if there exists an item that passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.some(user => user.discriminator === '0000'); + * ``` + */ + some(fn: (value: Value, key: Key, collection: this) => unknown): boolean; + some(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean; + /** + * Checks if all items passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.every(user => !user.bot); + * ``` + */ + every(fn: (value: Value, key: Key, collection: this) => key is NewKey): this is Collection; + every(fn: (value: Value, key: Key, collection: this) => value is NewValue): this is Collection; + every(fn: (value: Value, key: Key, collection: this) => unknown): boolean; + every(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): this is Collection; + every(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): this is Collection; + every(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn: (accumulator: Value, value: Value, key: Key, collection: this) => Value, initialValue?: Value): Value; + reduce(fn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue, initialValue: InitialValue): InitialValue; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight | Array.reduceRight()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `value`, `key`, and `collection` + * @param initialValue - Starting value for the accumulator + */ + reduceRight(fn: (accumulator: Value, value: Value, key: Key, collection: this) => Value, initialValue?: Value): Value; + reduceRight(fn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue, initialValue: InitialValue): InitialValue; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()}, + * but returns the collection instead of undefined. + * + * @param fn - Function to execute for each element + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection + * .each(user => console.log(user.username)) + * .filter(user => user.bot) + * .each(user => console.log(user.username)); + * ``` + */ + each(fn: (value: Value, key: Key, collection: this) => void): this; + each(fn: (this: This, value: Value, key: Key, collection: this) => void, thisArg: This): this; + /** + * Runs a function on the collection and returns the collection. + * + * @param fn - Function to execute + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection + * .tap(coll => console.log(coll.size)) + * .filter(user => user.bot) + * .tap(coll => console.log(coll.size)) + * ``` + */ + tap(fn: (collection: this) => void): this; + tap(fn: (this: This, collection: this) => void, thisArg: This): this; + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone(): Collection; + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections: ReadonlyCollection[]): Collection; + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection: ReadonlyCollection): boolean; + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction?: Comparator): this; + /** + * The intersection method returns a new collection containing the items where the key is present in both collections. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const intersection = col1.intersection(col2); + * console.log(col1.intersection(col2)); + * // => Collection { 'a' => 1 } + * ``` + */ + intersection(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing the items where the key is present in either of the collections. + * + * @remarks + * + * If the collections have any items with the same key, the value from the first collection will be used. + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]); + * const union = col1.union(col2); + * console.log(union); + * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 } + * ``` + */ + union(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing the items where the key is present in this collection but not the other. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * console.log(col1.difference(col2)); + * // => Collection { 'b' => 2 } + * console.log(col2.difference(col1)); + * // => Collection { 'c' => 3 } + * ``` + */ + difference(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing only the items where the keys are present in either collection, but not both. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const symmetricDifference = col1.symmetricDifference(col2); + * console.log(col1.symmetricDifference(col2)); + * // => Collection { 'b' => 2, 'c' => 3 } + * ``` + */ + symmetricDifference(other: ReadonlyCollection): Collection; + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other: ReadonlyCollection, whenInSelf: (value: Value, key: Key) => Keep, whenInOther: (valueOther: OtherValue, key: Key) => Keep, whenInBoth: (value: Value, valueOther: OtherValue, key: Key) => Keep): Collection; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()} + * but returns a Collection instead of an Array. + */ + toReversed(): Collection; + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + toSorted(compareFunction?: Comparator): Collection; + toJSON(): [Key, Value][]; + private static defaultSort; + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries: Iterable<[Key, Value]>, combine: (firstValue: Value, secondValue: Value, key: Key) => Value): Collection; +} +/** + * @internal + */ +type Keep = { + keep: false; +} | { + keep: true; + value: Value; +}; +/** + * @internal + */ +type Comparator = (firstValue: Value, secondValue: Value, firstKey: Key, secondKey: Key) => number; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection#readme | @discordjs/collection} version + * that you are currently using. + */ +declare const version: string; + +export { Collection, type CollectionConstructor, type Comparator, type Keep, type ReadonlyCollection, version }; diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.ts b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.ts new file mode 100644 index 0000000..859730c --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.d.ts @@ -0,0 +1,537 @@ +/** + * @internal + */ +interface CollectionConstructor { + new (): Collection; + new (entries?: readonly (readonly [Key, Value])[] | null): Collection; + new (iterable: Iterable): Collection; + readonly prototype: Collection; + readonly [Symbol.species]: CollectionConstructor; +} +/** + * Represents an immutable version of a collection + */ +type ReadonlyCollection = Omit, 'clear' | 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'> & ReadonlyMap; +/** + * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself + * + * @internal + */ +interface Collection extends Map { + constructor: CollectionConstructor; +} +/** + * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has + * an ID, for significantly improved performance and ease-of-use. + * + * @typeParam Key - The key type this collection holds + * @typeParam Value - The value type this collection holds + */ +declare class Collection extends Map { + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key: Key, defaultValueGenerator: (key: Key, collection: this) => Value): Value; + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys: Key[]): boolean; + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys: Key[]): boolean; + /** + * Obtains the first value(s) in this collection. + * + * @param amount - Amount of values to obtain from the beginning + * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative + */ + first(): Value | undefined; + first(amount: number): Value[]; + /** + * Obtains the first key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the beginning + * @returns A single key if no amount is provided or an array of keys, starting from the end if + * amount is negative + */ + firstKey(): Key | undefined; + firstKey(amount: number): Key[]; + /** + * Obtains the last value(s) in this collection. + * + * @param amount - Amount of values to obtain from the end + * @returns A single value if no amount is provided or an array of values, starting from the start if + * amount is negative + */ + last(): Value | undefined; + last(amount: number): Value[]; + /** + * Obtains the last key(s) in this collection. + * + * @param amount - Amount of keys to obtain from the end + * @returns A single key if no amount is provided or an array of keys, starting from the start if + * amount is negative + */ + lastKey(): Key | undefined; + lastKey(amount: number): Key[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index: number): Value | undefined; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index: number): Key | undefined; + /** + * Obtains unique random value(s) from this collection. + * + * @param amount - Amount of values to obtain randomly + * @returns A single value if no amount is provided or an array of values + */ + random(): Value | undefined; + random(amount: number): Value[]; + /** + * Obtains unique random key(s) from this collection. + * + * @param amount - Amount of keys to obtain randomly + * @returns A single key if no amount is provided or an array + */ + randomKey(): Key | undefined; + randomKey(amount: number): Key[]; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse(): this; + /** + * Searches for a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}. + * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you + * should use the `get` method. See + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.find(user => user.username === 'Bob'); + * ``` + */ + find(fn: (value: Value, key: Key, collection: this) => value is NewValue): NewValue | undefined; + find(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined; + find(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): NewValue | undefined; + find(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Value | undefined; + /** + * Searches for the key of a single item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.findKey(user => user.username === 'Bob'); + * ``` + */ + findKey(fn: (value: Value, key: Key, collection: this) => key is NewKey): NewKey | undefined; + findKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined; + findKey(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): NewKey | undefined; + findKey(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Key | undefined; + /** + * Searches for a last item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLast | Array.findLast()}. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + */ + findLast(fn: (value: Value, key: Key, collection: this) => value is NewValue): NewValue | undefined; + findLast(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined; + findLast(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): NewValue | undefined; + findLast(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Value | undefined; + /** + * Searches for the key of a last item where the given function returns a truthy value. This behaves like + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLastIndex | Array.findLastIndex()}, + * but returns the key rather than the positional index. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + */ + findLastKey(fn: (value: Value, key: Key, collection: this) => key is NewKey): NewKey | undefined; + findLastKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined; + findLastKey(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): NewKey | undefined; + findLastKey(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Key | undefined; + /** + * Removes items that satisfy the provided filter function. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @returns The number of removed entries + */ + sweep(fn: (value: Value, key: Key, collection: this) => unknown): number; + sweep(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): number; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()}, + * but returns a Collection instead of an Array. + * + * @param fn - The function to test with (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.filter(user => user.username === 'Bob'); + * ``` + */ + filter(fn: (value: Value, key: Key, collection: this) => key is NewKey): Collection; + filter(fn: (value: Value, key: Key, collection: this) => value is NewValue): Collection; + filter(fn: (value: Value, key: Key, collection: this) => unknown): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): Collection; + filter(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): Collection; + /** + * Partitions the collection into two collections where the first collection + * contains the items that passed and the second contains the items that failed. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * const [big, small] = collection.partition(guild => guild.memberCount > 250); + * ``` + */ + partition(fn: (value: Value, key: Key, collection: this) => key is NewKey): [Collection, Collection, Value>]; + partition(fn: (value: Value, key: Key, collection: this) => value is NewValue): [Collection, Collection>]; + partition(fn: (value: Value, key: Key, collection: this) => unknown): [Collection, Collection]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): [Collection, Collection, Value>]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): [Collection, Collection>]; + partition(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): [Collection, Collection]; + /** + * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}. + * + * @param fn - Function that produces a new Collection + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.flatMap(guild => guild.members.cache); + * ``` + */ + flatMap(fn: (value: Value, key: Key, collection: this) => Collection): Collection; + flatMap(fn: (this: This, value: Value, key: Key, collection: this) => Collection, thisArg: This): Collection; + /** + * Maps each item to another value into an array. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new array, taking three arguments + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.map(user => user.tag); + * ``` + */ + map(fn: (value: Value, key: Key, collection: this) => NewValue): NewValue[]; + map(fn: (this: This, value: Value, key: Key, collection: this) => NewValue, thisArg: This): NewValue[]; + /** + * Maps each item to another value into a collection. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}. + * + * @param fn - Function that produces an element of the new collection, taking three arguments + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.mapValues(user => user.tag); + * ``` + */ + mapValues(fn: (value: Value, key: Key, collection: this) => NewValue): Collection; + mapValues(fn: (this: This, value: Value, key: Key, collection: this) => NewValue, thisArg: This): Collection; + /** + * Checks if there exists an item that passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.some(user => user.discriminator === '0000'); + * ``` + */ + some(fn: (value: Value, key: Key, collection: this) => unknown): boolean; + some(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean; + /** + * Checks if all items passes a test. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}. + * + * @param fn - Function used to test (should return a boolean) + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection.every(user => !user.bot); + * ``` + */ + every(fn: (value: Value, key: Key, collection: this) => key is NewKey): this is Collection; + every(fn: (value: Value, key: Key, collection: this) => value is NewValue): this is Collection; + every(fn: (value: Value, key: Key, collection: this) => unknown): boolean; + every(fn: (this: This, value: Value, key: Key, collection: this) => key is NewKey, thisArg: This): this is Collection; + every(fn: (this: This, value: Value, key: Key, collection: this) => value is NewValue, thisArg: This): this is Collection; + every(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`, + * and `collection` + * @param initialValue - Starting value for the accumulator + * @example + * ```ts + * collection.reduce((acc, guild) => acc + guild.memberCount, 0); + * ``` + */ + reduce(fn: (accumulator: Value, value: Value, key: Key, collection: this) => Value, initialValue?: Value): Value; + reduce(fn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue, initialValue: InitialValue): InitialValue; + /** + * Applies a function to produce a single value. Identical in behavior to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight | Array.reduceRight()}. + * + * @param fn - Function used to reduce, taking four arguments; `accumulator`, `value`, `key`, and `collection` + * @param initialValue - Starting value for the accumulator + */ + reduceRight(fn: (accumulator: Value, value: Value, key: Key, collection: this) => Value, initialValue?: Value): Value; + reduceRight(fn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue, initialValue: InitialValue): InitialValue; + /** + * Identical to + * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()}, + * but returns the collection instead of undefined. + * + * @param fn - Function to execute for each element + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection + * .each(user => console.log(user.username)) + * .filter(user => user.bot) + * .each(user => console.log(user.username)); + * ``` + */ + each(fn: (value: Value, key: Key, collection: this) => void): this; + each(fn: (this: This, value: Value, key: Key, collection: this) => void, thisArg: This): this; + /** + * Runs a function on the collection and returns the collection. + * + * @param fn - Function to execute + * @param thisArg - Value to use as `this` when executing the function + * @example + * ```ts + * collection + * .tap(coll => console.log(coll.size)) + * .filter(user => user.bot) + * .tap(coll => console.log(coll.size)) + * ``` + */ + tap(fn: (collection: this) => void): this; + tap(fn: (this: This, collection: this) => void, thisArg: This): this; + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone(): Collection; + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections: ReadonlyCollection[]): Collection; + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection: ReadonlyCollection): boolean; + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction?: Comparator): this; + /** + * The intersection method returns a new collection containing the items where the key is present in both collections. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const intersection = col1.intersection(col2); + * console.log(col1.intersection(col2)); + * // => Collection { 'a' => 1 } + * ``` + */ + intersection(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing the items where the key is present in either of the collections. + * + * @remarks + * + * If the collections have any items with the same key, the value from the first collection will be used. + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]); + * const union = col1.union(col2); + * console.log(union); + * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 } + * ``` + */ + union(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing the items where the key is present in this collection but not the other. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * console.log(col1.difference(col2)); + * // => Collection { 'b' => 2 } + * console.log(col2.difference(col1)); + * // => Collection { 'c' => 3 } + * ``` + */ + difference(other: ReadonlyCollection): Collection; + /** + * Returns a new collection containing only the items where the keys are present in either collection, but not both. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const symmetricDifference = col1.symmetricDifference(col2); + * console.log(col1.symmetricDifference(col2)); + * // => Collection { 'b' => 2, 'c' => 3 } + * ``` + */ + symmetricDifference(other: ReadonlyCollection): Collection; + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other: ReadonlyCollection, whenInSelf: (value: Value, key: Key) => Keep, whenInOther: (valueOther: OtherValue, key: Key) => Keep, whenInBoth: (value: Value, valueOther: OtherValue, key: Key) => Keep): Collection; + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()} + * but returns a Collection instead of an Array. + */ + toReversed(): Collection; + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + toSorted(compareFunction?: Comparator): Collection; + toJSON(): [Key, Value][]; + private static defaultSort; + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries: Iterable<[Key, Value]>, combine: (firstValue: Value, secondValue: Value, key: Key) => Value): Collection; +} +/** + * @internal + */ +type Keep = { + keep: false; +} | { + keep: true; + value: Value; +}; +/** + * @internal + */ +type Comparator = (firstValue: Value, secondValue: Value, firstKey: Key, secondKey: Key) => number; + +/** + * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection#readme | @discordjs/collection} version + * that you are currently using. + */ +declare const version: string; + +export { Collection, type CollectionConstructor, type Comparator, type Keep, type ReadonlyCollection, version }; diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js new file mode 100644 index 0000000..67cc603 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js @@ -0,0 +1,567 @@ +"use strict"; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key) && key !== except) + __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); + } + return to; +}; +var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); + +// src/index.ts +var src_exports = {}; +__export(src_exports, { + Collection: () => Collection, + version: () => version +}); +module.exports = __toCommonJS(src_exports); + +// src/collection.ts +var Collection = class _Collection extends Map { + static { + __name(this, "Collection"); + } + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key, defaultValueGenerator) { + if (this.has(key)) return this.get(key); + if (typeof defaultValueGenerator !== "function") throw new TypeError(`${defaultValueGenerator} is not a function`); + const defaultValue = defaultValueGenerator(key, this); + this.set(key, defaultValue); + return defaultValue; + } + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys) { + return keys.every((key) => super.has(key)); + } + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys) { + return keys.some((key) => super.has(key)); + } + first(amount) { + if (amount === void 0) return this.values().next().value; + if (amount < 0) return this.last(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.values(); + return Array.from({ length: amount }, () => iter.next().value); + } + firstKey(amount) { + if (amount === void 0) return this.keys().next().value; + if (amount < 0) return this.lastKey(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.keys(); + return Array.from({ length: amount }, () => iter.next().value); + } + last(amount) { + const arr = [...this.values()]; + if (amount === void 0) return arr[arr.length - 1]; + if (amount < 0) return this.first(amount * -1); + if (!amount) return []; + return arr.slice(-amount); + } + lastKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) return arr[arr.length - 1]; + if (amount < 0) return this.firstKey(amount * -1); + if (!amount) return []; + return arr.slice(-amount); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index) { + index = Math.floor(index); + const arr = [...this.values()]; + return arr.at(index); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index) { + index = Math.floor(index); + const arr = [...this.keys()]; + return arr.at(index); + } + random(amount) { + const arr = [...this.values()]; + if (amount === void 0) return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + randomKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse() { + const entries = [...this.entries()].reverse(); + this.clear(); + for (const [key, value] of entries) this.set(key, value); + return this; + } + find(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return val; + } + return void 0; + } + findKey(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return key; + } + return void 0; + } + findLast(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const entries = [...this.entries()]; + for (let index = entries.length - 1; index >= 0; index--) { + const val = entries[index][1]; + const key = entries[index][0]; + if (fn(val, key, this)) return val; + } + return void 0; + } + findLastKey(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const entries = [...this.entries()]; + for (let index = entries.length - 1; index >= 0; index--) { + const key = entries[index][0]; + const val = entries[index][1]; + if (fn(val, key, this)) return key; + } + return void 0; + } + sweep(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const previousSize = this.size; + for (const [key, val] of this) { + if (fn(val, key, this)) this.delete(key); + } + return previousSize - this.size; + } + filter(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const results = new this.constructor[Symbol.species](); + for (const [key, val] of this) { + if (fn(val, key, this)) results.set(key, val); + } + return results; + } + partition(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const results = [ + new this.constructor[Symbol.species](), + new this.constructor[Symbol.species]() + ]; + for (const [key, val] of this) { + if (fn(val, key, this)) { + results[0].set(key, val); + } else { + results[1].set(key, val); + } + } + return results; + } + flatMap(fn, thisArg) { + const collections = this.map(fn, thisArg); + return new this.constructor[Symbol.species]().concat(...collections); + } + map(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const iter = this.entries(); + return Array.from({ length: this.size }, () => { + const [key, value] = iter.next().value; + return fn(value, key, this); + }); + } + mapValues(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const coll = new this.constructor[Symbol.species](); + for (const [key, val] of this) coll.set(key, fn(val, key, this)); + return coll; + } + some(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return true; + } + return false; + } + every(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (!fn(val, key, this)) return false; + } + return true; + } + reduce(fn, initialValue) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + let accumulator; + const iterator = this.entries(); + if (initialValue === void 0) { + if (this.size === 0) throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = iterator.next().value[1]; + } else { + accumulator = initialValue; + } + for (const [key, value] of iterator) { + accumulator = fn(accumulator, value, key, this); + } + return accumulator; + } + reduceRight(fn, initialValue) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + const entries = [...this.entries()]; + let accumulator; + let index; + if (initialValue === void 0) { + if (entries.length === 0) throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = entries[entries.length - 1][1]; + index = entries.length - 1; + } else { + accumulator = initialValue; + index = entries.length; + } + while (--index >= 0) { + const key = entries[index][0]; + const val = entries[index][1]; + accumulator = fn(accumulator, val, key, this); + } + return accumulator; + } + each(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, value] of this) { + fn(value, key, this); + } + return this; + } + tap(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + fn(this); + return this; + } + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone() { + return new this.constructor[Symbol.species](this); + } + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections) { + const newColl = this.clone(); + for (const coll of collections) { + for (const [key, val] of coll) newColl.set(key, val); + } + return newColl; + } + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection) { + if (!collection) return false; + if (this === collection) return true; + if (this.size !== collection.size) return false; + for (const [key, value] of this) { + if (!collection.has(key) || value !== collection.get(key)) { + return false; + } + } + return true; + } + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction = _Collection.defaultSort) { + const entries = [...this.entries()]; + entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0])); + super.clear(); + for (const [key, value] of entries) { + super.set(key, value); + } + return this; + } + /** + * The intersection method returns a new collection containing the items where the key is present in both collections. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const intersection = col1.intersection(col2); + * console.log(col1.intersection(col2)); + * // => Collection { 'a' => 1 } + * ``` + */ + intersection(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (other.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing the items where the key is present in either of the collections. + * + * @remarks + * + * If the collections have any items with the same key, the value from the first collection will be used. + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]); + * const union = col1.union(col2); + * console.log(union); + * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 } + * ``` + */ + union(other) { + const coll = new this.constructor[Symbol.species](this); + for (const [key, value] of other) { + if (!coll.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing the items where the key is present in this collection but not the other. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * console.log(col1.difference(col2)); + * // => Collection { 'b' => 2 } + * console.log(col2.difference(col1)); + * // => Collection { 'c' => 3 } + * ``` + */ + difference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing only the items where the keys are present in either collection, but not both. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const symmetricDifference = col1.symmetricDifference(col2); + * console.log(col1.symmetricDifference(col2)); + * // => Collection { 'b' => 2, 'c' => 3 } + * ``` + */ + symmetricDifference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key)) coll.set(key, value); + } + for (const [key, value] of other) { + if (!this.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other, whenInSelf, whenInOther, whenInBoth) { + const coll = new this.constructor[Symbol.species](); + const keys = /* @__PURE__ */ new Set([...this.keys(), ...other.keys()]); + for (const key of keys) { + const hasInSelf = this.has(key); + const hasInOther = other.has(key); + if (hasInSelf && hasInOther) { + const result = whenInBoth(this.get(key), other.get(key), key); + if (result.keep) coll.set(key, result.value); + } else if (hasInSelf) { + const result = whenInSelf(this.get(key), key); + if (result.keep) coll.set(key, result.value); + } else if (hasInOther) { + const result = whenInOther(other.get(key), key); + if (result.keep) coll.set(key, result.value); + } + } + return coll; + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()} + * but returns a Collection instead of an Array. + */ + toReversed() { + return new this.constructor[Symbol.species](this).reverse(); + } + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + toSorted(compareFunction = _Collection.defaultSort) { + return new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk)); + } + toJSON() { + return [...this.entries()]; + } + static defaultSort(firstValue, secondValue) { + return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1; + } + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries, combine) { + const coll = new _Collection(); + for (const [key, value] of entries) { + if (coll.has(key)) { + coll.set(key, combine(coll.get(key), value, key)); + } else { + coll.set(key, value); + } + } + return coll; + } +}; + +// src/index.ts +var version = "2.1.1"; +// Annotate the CommonJS export names for ESM import in node: +0 && (module.exports = { + Collection, + version +}); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js.map b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js.map new file mode 100644 index 0000000..375b8f2 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/index.ts","../src/collection.ts"],"sourcesContent":["export * from './collection.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection#readme | @discordjs/collection} version\n * that you are currently using.\n */\n// This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild\nexport const version = '2.1.1' as string;\n","/* eslint-disable no-param-reassign */\n/**\n * @internal\n */\nexport interface CollectionConstructor {\n\tnew (): Collection;\n\tnew (entries?: readonly (readonly [Key, Value])[] | null): Collection;\n\tnew (iterable: Iterable): Collection;\n\treadonly prototype: Collection;\n\treadonly [Symbol.species]: CollectionConstructor;\n}\n\n/**\n * Represents an immutable version of a collection\n */\nexport type ReadonlyCollection = Omit<\n\tCollection,\n\t'clear' | 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'\n> &\n\tReadonlyMap;\n\n/**\n * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself\n *\n * @internal\n */\nexport interface Collection extends Map {\n\tconstructor: CollectionConstructor;\n}\n\n/**\n * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has\n * an ID, for significantly improved performance and ease-of-use.\n *\n * @typeParam Key - The key type this collection holds\n * @typeParam Value - The value type this collection holds\n */\nexport class Collection extends Map {\n\t/**\n\t * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator.\n\t *\n\t * @param key - The key to get if it exists, or set otherwise\n\t * @param defaultValueGenerator - A function that generates the default value\n\t * @example\n\t * ```ts\n\t * collection.ensure(guildId, () => defaultGuildConfig);\n\t * ```\n\t */\n\tpublic ensure(key: Key, defaultValueGenerator: (key: Key, collection: this) => Value): Value {\n\t\tif (this.has(key)) return this.get(key)!;\n\t\tif (typeof defaultValueGenerator !== 'function') throw new TypeError(`${defaultValueGenerator} is not a function`);\n\t\tconst defaultValue = defaultValueGenerator(key, this);\n\t\tthis.set(key, defaultValue);\n\t\treturn defaultValue;\n\t}\n\n\t/**\n\t * Checks if all of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if all of the elements exist, `false` if at least one does not exist.\n\t */\n\tpublic hasAll(...keys: Key[]) {\n\t\treturn keys.every((key) => super.has(key));\n\t}\n\n\t/**\n\t * Checks if any of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if any of the elements exist, `false` if none exist.\n\t */\n\tpublic hasAny(...keys: Key[]) {\n\t\treturn keys.some((key) => super.has(key));\n\t}\n\n\t/**\n\t * Obtains the first value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the beginning\n\t * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative\n\t */\n\tpublic first(): Value | undefined;\n\tpublic first(amount: number): Value[];\n\tpublic first(amount?: number): Value | Value[] | undefined {\n\t\tif (amount === undefined) return this.values().next().value;\n\t\tif (amount < 0) return this.last(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.values();\n\t\treturn Array.from({ length: amount }, (): Value => iter.next().value!);\n\t}\n\n\t/**\n\t * Obtains the first key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the beginning\n\t * @returns A single key if no amount is provided or an array of keys, starting from the end if\n\t * amount is negative\n\t */\n\tpublic firstKey(): Key | undefined;\n\tpublic firstKey(amount: number): Key[];\n\tpublic firstKey(amount?: number): Key | Key[] | undefined {\n\t\tif (amount === undefined) return this.keys().next().value;\n\t\tif (amount < 0) return this.lastKey(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.keys();\n\t\treturn Array.from({ length: amount }, (): Key => iter.next().value!);\n\t}\n\n\t/**\n\t * Obtains the last value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the end\n\t * @returns A single value if no amount is provided or an array of values, starting from the start if\n\t * amount is negative\n\t */\n\tpublic last(): Value | undefined;\n\tpublic last(amount: number): Value[];\n\tpublic last(amount?: number): Value | Value[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.first(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Obtains the last key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the end\n\t * @returns A single key if no amount is provided or an array of keys, starting from the start if\n\t * amount is negative\n\t */\n\tpublic lastKey(): Key | undefined;\n\tpublic lastKey(amount: number): Key[];\n\tpublic lastKey(amount?: number): Key | Key[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.firstKey(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the item at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the element to obtain\n\t */\n\tpublic at(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.values()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the key at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the key to obtain\n\t */\n\tpublic keyAt(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.keys()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Obtains unique random value(s) from this collection.\n\t *\n\t * @param amount - Amount of values to obtain randomly\n\t * @returns A single value if no amount is provided or an array of values\n\t */\n\tpublic random(): Value | undefined;\n\tpublic random(amount: number): Value[];\n\tpublic random(amount?: number): Value | Value[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): Value => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Obtains unique random key(s) from this collection.\n\t *\n\t * @param amount - Amount of keys to obtain randomly\n\t * @returns A single key if no amount is provided or an array\n\t */\n\tpublic randomKey(): Key | undefined;\n\tpublic randomKey(amount: number): Key[];\n\tpublic randomKey(amount?: number): Key | Key[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): Key => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic reverse() {\n\t\tconst entries = [...this.entries()].reverse();\n\t\tthis.clear();\n\t\tfor (const [key, value] of entries) this.set(key, value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Searches for a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}.\n\t * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you\n\t * should use the `get` method. See\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.find(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic find(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): NewValue | undefined;\n\tpublic find(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): NewValue | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Value | undefined;\n\tpublic find(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Value | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.findKey(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic findKey(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): NewKey | undefined;\n\tpublic findKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): NewKey | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Key | undefined;\n\tpublic findKey(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Key | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for a last item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLast | Array.findLast()}.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t */\n\tpublic findLast(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): NewValue | undefined;\n\tpublic findLast(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined;\n\tpublic findLast(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): NewValue | undefined;\n\tpublic findLast(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Value | undefined;\n\tpublic findLast(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Value | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst entries = [...this.entries()];\n\t\tfor (let index = entries.length - 1; index >= 0; index--) {\n\t\t\tconst val = entries[index]![1];\n\t\t\tconst key = entries[index]![0];\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a last item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLastIndex | Array.findLastIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t */\n\tpublic findLastKey(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): NewKey | undefined;\n\tpublic findLastKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined;\n\tpublic findLastKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): NewKey | undefined;\n\tpublic findLastKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Key | undefined;\n\tpublic findLastKey(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Key | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst entries = [...this.entries()];\n\t\tfor (let index = entries.length - 1; index >= 0; index--) {\n\t\t\tconst key = entries[index]![0];\n\t\t\tconst val = entries[index]![1];\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Removes items that satisfy the provided filter function.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @returns The number of removed entries\n\t */\n\tpublic sweep(fn: (value: Value, key: Key, collection: this) => unknown): number;\n\tpublic sweep(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): number;\n\tpublic sweep(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): number {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst previousSize = this.size;\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) this.delete(key);\n\t\t}\n\n\t\treturn previousSize - this.size;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()},\n\t * but returns a Collection instead of an Array.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.filter(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic filter(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): Collection;\n\tpublic filter(fn: (value: Value, key: Key, collection: this) => unknown): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) results.set(key, val);\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Partitions the collection into two collections where the first collection\n\t * contains the items that passed and the second contains the items that failed.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * const [big, small] = collection.partition(guild => guild.memberCount > 250);\n\t * ```\n\t */\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): [Collection, Collection, Value>];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => unknown,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): [Collection, Collection, Value>];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg?: unknown,\n\t): [Collection, Collection] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results: [Collection, Collection] = [\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t];\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) {\n\t\t\t\tresults[0].set(key, val);\n\t\t\t} else {\n\t\t\t\tresults[1].set(key, val);\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}.\n\t *\n\t * @param fn - Function that produces a new Collection\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.flatMap(guild => guild.members.cache);\n\t * ```\n\t */\n\tpublic flatMap(\n\t\tfn: (value: Value, key: Key, collection: this) => Collection,\n\t): Collection;\n\tpublic flatMap(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => Collection,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic flatMap(\n\t\tfn: (value: Value, key: Key, collection: this) => Collection,\n\t\tthisArg?: unknown,\n\t): Collection {\n\t\t// eslint-disable-next-line unicorn/no-array-method-this-argument\n\t\tconst collections = this.map(fn, thisArg);\n\t\treturn new this.constructor[Symbol.species]().concat(...collections);\n\t}\n\n\t/**\n\t * Maps each item to another value into an array. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new array, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.map(user => user.tag);\n\t * ```\n\t */\n\tpublic map(fn: (value: Value, key: Key, collection: this) => NewValue): NewValue[];\n\tpublic map(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg: This,\n\t): NewValue[];\n\tpublic map(fn: (value: Value, key: Key, collection: this) => NewValue, thisArg?: unknown): NewValue[] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst iter = this.entries();\n\t\treturn Array.from({ length: this.size }, (): NewValue => {\n\t\t\tconst [key, value] = iter.next().value!;\n\t\t\treturn fn(value, key, this);\n\t\t});\n\t}\n\n\t/**\n\t * Maps each item to another value into a collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new collection, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.mapValues(user => user.tag);\n\t * ```\n\t */\n\tpublic mapValues(fn: (value: Value, key: Key, collection: this) => NewValue): Collection;\n\tpublic mapValues(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic mapValues(\n\t\tfn: (value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg?: unknown,\n\t): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) coll.set(key, fn(val, key, this));\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Checks if there exists an item that passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.some(user => user.discriminator === '0000');\n\t * ```\n\t */\n\tpublic some(fn: (value: Value, key: Key, collection: this) => unknown): boolean;\n\tpublic some(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean;\n\tpublic some(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t * Checks if all items passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.every(user => !user.bot);\n\t * ```\n\t */\n\tpublic every(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): this is Collection;\n\tpublic every(fn: (value: Value, key: Key, collection: this) => unknown): boolean;\n\tpublic every(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean;\n\tpublic every(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (!fn(val, key, this)) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`,\n\t * and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t * @example\n\t * ```ts\n\t * collection.reduce((acc, guild) => acc + guild.memberCount, 0);\n\t * ```\n\t */\n\tpublic reduce(\n\t\tfn: (accumulator: Value, value: Value, key: Key, collection: this) => Value,\n\t\tinitialValue?: Value,\n\t): Value;\n\tpublic reduce(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue: InitialValue,\n\t): InitialValue;\n\tpublic reduce(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue?: InitialValue,\n\t): InitialValue {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tlet accumulator!: InitialValue;\n\n\t\tconst iterator = this.entries();\n\t\tif (initialValue === undefined) {\n\t\t\tif (this.size === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = iterator.next().value![1] as unknown as InitialValue;\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t}\n\n\t\tfor (const [key, value] of iterator) {\n\t\t\taccumulator = fn(accumulator, value, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight | Array.reduceRight()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `value`, `key`, and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t */\n\tpublic reduceRight(\n\t\tfn: (accumulator: Value, value: Value, key: Key, collection: this) => Value,\n\t\tinitialValue?: Value,\n\t): Value;\n\tpublic reduceRight(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue: InitialValue,\n\t): InitialValue;\n\tpublic reduceRight(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue?: InitialValue,\n\t): InitialValue {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tconst entries = [...this.entries()];\n\t\tlet accumulator!: InitialValue;\n\n\t\tlet index: number;\n\t\tif (initialValue === undefined) {\n\t\t\tif (entries.length === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = entries[entries.length - 1]![1] as unknown as InitialValue;\n\t\t\tindex = entries.length - 1;\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t\tindex = entries.length;\n\t\t}\n\n\t\twhile (--index >= 0) {\n\t\t\tconst key = entries[index]![0];\n\t\t\tconst val = entries[index]![1];\n\t\t\taccumulator = fn(accumulator, val, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()},\n\t * but returns the collection instead of undefined.\n\t *\n\t * @param fn - Function to execute for each element\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .each(user => console.log(user.username))\n\t * .filter(user => user.bot)\n\t * .each(user => console.log(user.username));\n\t * ```\n\t */\n\tpublic each(fn: (value: Value, key: Key, collection: this) => void): this;\n\tpublic each(fn: (this: This, value: Value, key: Key, collection: this) => void, thisArg: This): this;\n\tpublic each(fn: (value: Value, key: Key, collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\n\t\tfor (const [key, value] of this) {\n\t\t\tfn(value, key, this);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Runs a function on the collection and returns the collection.\n\t *\n\t * @param fn - Function to execute\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .tap(coll => console.log(coll.size))\n\t * .filter(user => user.bot)\n\t * .tap(coll => console.log(coll.size))\n\t * ```\n\t */\n\tpublic tap(fn: (collection: this) => void): this;\n\tpublic tap(fn: (this: This, collection: this) => void, thisArg: This): this;\n\tpublic tap(fn: (collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfn(this);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Creates an identical shallow copy of this collection.\n\t *\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.clone();\n\t * ```\n\t */\n\tpublic clone(): Collection {\n\t\treturn new this.constructor[Symbol.species](this);\n\t}\n\n\t/**\n\t * Combines this collection with others into a new collection. None of the source collections are modified.\n\t *\n\t * @param collections - Collections to merge\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl);\n\t * ```\n\t */\n\tpublic concat(...collections: ReadonlyCollection[]) {\n\t\tconst newColl = this.clone();\n\t\tfor (const coll of collections) {\n\t\t\tfor (const [key, val] of coll) newColl.set(key, val);\n\t\t}\n\n\t\treturn newColl;\n\t}\n\n\t/**\n\t * Checks if this collection shares identical items with another.\n\t * This is different to checking for equality using equal-signs, because\n\t * the collections may be different objects, but contain the same data.\n\t *\n\t * @param collection - Collection to compare with\n\t * @returns Whether the collections have identical contents\n\t */\n\tpublic equals(collection: ReadonlyCollection) {\n\t\tif (!collection) return false; // runtime check\n\t\tif (this === collection) return true;\n\t\tif (this.size !== collection.size) return false;\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!collection.has(key) || value !== collection.get(key)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * The sort method sorts the items of a collection in place and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sort(compareFunction: Comparator = Collection.defaultSort) {\n\t\tconst entries = [...this.entries()];\n\t\tentries.sort((a, b): number => compareFunction(a[1], b[1], a[0], b[0]));\n\n\t\t// Perform clean-up\n\t\tsuper.clear();\n\n\t\t// Set the new entries\n\t\tfor (const [key, value] of entries) {\n\t\t\tsuper.set(key, value);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * The intersection method returns a new collection containing the items where the key is present in both collections.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * const intersection = col1.intersection(col2);\n\t * console.log(col1.intersection(col2));\n\t * // => Collection { 'a' => 1 }\n\t * ```\n\t */\n\tpublic intersection(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing the items where the key is present in either of the collections.\n\t *\n\t * @remarks\n\t *\n\t * If the collections have any items with the same key, the value from the first collection will be used.\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]);\n\t * const union = col1.union(col2);\n\t * console.log(union);\n\t * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 }\n\t * ```\n\t */\n\tpublic union(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species](this);\n\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!coll.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing the items where the key is present in this collection but not the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * console.log(col1.difference(col2));\n\t * // => Collection { 'b' => 2 }\n\t * console.log(col2.difference(col1));\n\t * // => Collection { 'c' => 3 }\n\t * ```\n\t */\n\tpublic difference(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing only the items where the keys are present in either collection, but not both.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * const symmetricDifference = col1.symmetricDifference(col2);\n\t * console.log(col1.symmetricDifference(col2));\n\t * // => Collection { 'b' => 2, 'c' => 3 }\n\t * ```\n\t */\n\tpublic symmetricDifference(\n\t\tother: ReadonlyCollection,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!this.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Merges two Collections together into a new Collection.\n\t *\n\t * @param other - The other Collection to merge with\n\t * @param whenInSelf - Function getting the result if the entry only exists in this Collection\n\t * @param whenInOther - Function getting the result if the entry only exists in the other Collection\n\t * @param whenInBoth - Function getting the result if the entry exists in both Collections\n\t * @example\n\t * ```ts\n\t * // Sums up the entries in two collections.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: true, value: x }),\n\t * y => ({ keep: true, value: y }),\n\t * (x, y) => ({ keep: true, value: x + y }),\n\t * );\n\t * ```\n\t * @example\n\t * ```ts\n\t * // Intersects two collections in a left-biased manner.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: false }),\n\t * y => ({ keep: false }),\n\t * (x, _) => ({ keep: true, value: x }),\n\t * );\n\t * ```\n\t */\n\tpublic merge(\n\t\tother: ReadonlyCollection,\n\t\twhenInSelf: (value: Value, key: Key) => Keep,\n\t\twhenInOther: (valueOther: OtherValue, key: Key) => Keep,\n\t\twhenInBoth: (value: Value, valueOther: OtherValue, key: Key) => Keep,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tconst keys = new Set([...this.keys(), ...other.keys()]);\n\n\t\tfor (const key of keys) {\n\t\t\tconst hasInSelf = this.has(key);\n\t\t\tconst hasInOther = other.has(key);\n\n\t\t\tif (hasInSelf && hasInOther) {\n\t\t\t\tconst result = whenInBoth(this.get(key)!, other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInSelf) {\n\t\t\t\tconst result = whenInSelf(this.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInOther) {\n\t\t\t\tconst result = whenInOther(other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic toReversed() {\n\t\treturn new this.constructor[Symbol.species](this).reverse();\n\t}\n\n\t/**\n\t * The sorted method sorts the items of a collection and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value,\n\t * according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic toSorted(compareFunction: Comparator = Collection.defaultSort) {\n\t\treturn new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk));\n\t}\n\n\tpublic toJSON() {\n\t\t// toJSON is called recursively by JSON.stringify.\n\t\treturn [...this.entries()];\n\t}\n\n\tprivate static defaultSort(firstValue: Value, secondValue: Value): number {\n\t\treturn Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n\t}\n\n\t/**\n\t * Creates a Collection from a list of entries.\n\t *\n\t * @param entries - The list of entries\n\t * @param combine - Function to combine an existing entry with a new one\n\t * @example\n\t * ```ts\n\t * Collection.combineEntries([[\"a\", 1], [\"b\", 2], [\"a\", 2]], (x, y) => x + y);\n\t * // returns Collection { \"a\" => 3, \"b\" => 2 }\n\t * ```\n\t */\n\tpublic static combineEntries(\n\t\tentries: Iterable<[Key, Value]>,\n\t\tcombine: (firstValue: Value, secondValue: Value, key: Key) => Value,\n\t): Collection {\n\t\tconst coll = new Collection();\n\t\tfor (const [key, value] of entries) {\n\t\t\tif (coll.has(key)) {\n\t\t\t\tcoll.set(key, combine(coll.get(key)!, value, key));\n\t\t\t} else {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n}\n\n/**\n * @internal\n */\nexport type Keep = { keep: false } | { keep: true; value: Value };\n\n/**\n * @internal\n */\nexport type Comparator = (firstValue: Value, secondValue: Value, firstKey: Key, secondKey: Key) => number;\n"],"mappings":"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","names":[]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs new file mode 100644 index 0000000..4bb95c3 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs @@ -0,0 +1,541 @@ +var __defProp = Object.defineProperty; +var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); + +// src/collection.ts +var Collection = class _Collection extends Map { + static { + __name(this, "Collection"); + } + /** + * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator. + * + * @param key - The key to get if it exists, or set otherwise + * @param defaultValueGenerator - A function that generates the default value + * @example + * ```ts + * collection.ensure(guildId, () => defaultGuildConfig); + * ``` + */ + ensure(key, defaultValueGenerator) { + if (this.has(key)) return this.get(key); + if (typeof defaultValueGenerator !== "function") throw new TypeError(`${defaultValueGenerator} is not a function`); + const defaultValue = defaultValueGenerator(key, this); + this.set(key, defaultValue); + return defaultValue; + } + /** + * Checks if all of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if all of the elements exist, `false` if at least one does not exist. + */ + hasAll(...keys) { + return keys.every((key) => super.has(key)); + } + /** + * Checks if any of the elements exist in the collection. + * + * @param keys - The keys of the elements to check for + * @returns `true` if any of the elements exist, `false` if none exist. + */ + hasAny(...keys) { + return keys.some((key) => super.has(key)); + } + first(amount) { + if (amount === void 0) return this.values().next().value; + if (amount < 0) return this.last(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.values(); + return Array.from({ length: amount }, () => iter.next().value); + } + firstKey(amount) { + if (amount === void 0) return this.keys().next().value; + if (amount < 0) return this.lastKey(amount * -1); + amount = Math.min(this.size, amount); + const iter = this.keys(); + return Array.from({ length: amount }, () => iter.next().value); + } + last(amount) { + const arr = [...this.values()]; + if (amount === void 0) return arr[arr.length - 1]; + if (amount < 0) return this.first(amount * -1); + if (!amount) return []; + return arr.slice(-amount); + } + lastKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) return arr[arr.length - 1]; + if (amount < 0) return this.firstKey(amount * -1); + if (!amount) return []; + return arr.slice(-amount); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the item at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the element to obtain + */ + at(index) { + index = Math.floor(index); + const arr = [...this.values()]; + return arr.at(index); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}. + * Returns the key at a given index, allowing for positive and negative integers. + * Negative integers count back from the last item in the collection. + * + * @param index - The index of the key to obtain + */ + keyAt(index) { + index = Math.floor(index); + const arr = [...this.keys()]; + return arr.at(index); + } + random(amount) { + const arr = [...this.values()]; + if (amount === void 0) return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + randomKey(amount) { + const arr = [...this.keys()]; + if (amount === void 0) return arr[Math.floor(Math.random() * arr.length)]; + if (!arr.length || !amount) return []; + return Array.from( + { length: Math.min(amount, arr.length) }, + () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0] + ); + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()} + * but returns a Collection instead of an Array. + */ + reverse() { + const entries = [...this.entries()].reverse(); + this.clear(); + for (const [key, value] of entries) this.set(key, value); + return this; + } + find(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return val; + } + return void 0; + } + findKey(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return key; + } + return void 0; + } + findLast(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const entries = [...this.entries()]; + for (let index = entries.length - 1; index >= 0; index--) { + const val = entries[index][1]; + const key = entries[index][0]; + if (fn(val, key, this)) return val; + } + return void 0; + } + findLastKey(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const entries = [...this.entries()]; + for (let index = entries.length - 1; index >= 0; index--) { + const key = entries[index][0]; + const val = entries[index][1]; + if (fn(val, key, this)) return key; + } + return void 0; + } + sweep(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const previousSize = this.size; + for (const [key, val] of this) { + if (fn(val, key, this)) this.delete(key); + } + return previousSize - this.size; + } + filter(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const results = new this.constructor[Symbol.species](); + for (const [key, val] of this) { + if (fn(val, key, this)) results.set(key, val); + } + return results; + } + partition(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const results = [ + new this.constructor[Symbol.species](), + new this.constructor[Symbol.species]() + ]; + for (const [key, val] of this) { + if (fn(val, key, this)) { + results[0].set(key, val); + } else { + results[1].set(key, val); + } + } + return results; + } + flatMap(fn, thisArg) { + const collections = this.map(fn, thisArg); + return new this.constructor[Symbol.species]().concat(...collections); + } + map(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const iter = this.entries(); + return Array.from({ length: this.size }, () => { + const [key, value] = iter.next().value; + return fn(value, key, this); + }); + } + mapValues(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + const coll = new this.constructor[Symbol.species](); + for (const [key, val] of this) coll.set(key, fn(val, key, this)); + return coll; + } + some(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (fn(val, key, this)) return true; + } + return false; + } + every(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, val] of this) { + if (!fn(val, key, this)) return false; + } + return true; + } + reduce(fn, initialValue) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + let accumulator; + const iterator = this.entries(); + if (initialValue === void 0) { + if (this.size === 0) throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = iterator.next().value[1]; + } else { + accumulator = initialValue; + } + for (const [key, value] of iterator) { + accumulator = fn(accumulator, value, key, this); + } + return accumulator; + } + reduceRight(fn, initialValue) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + const entries = [...this.entries()]; + let accumulator; + let index; + if (initialValue === void 0) { + if (entries.length === 0) throw new TypeError("Reduce of empty collection with no initial value"); + accumulator = entries[entries.length - 1][1]; + index = entries.length - 1; + } else { + accumulator = initialValue; + index = entries.length; + } + while (--index >= 0) { + const key = entries[index][0]; + const val = entries[index][1]; + accumulator = fn(accumulator, val, key, this); + } + return accumulator; + } + each(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + for (const [key, value] of this) { + fn(value, key, this); + } + return this; + } + tap(fn, thisArg) { + if (typeof fn !== "function") throw new TypeError(`${fn} is not a function`); + if (thisArg !== void 0) fn = fn.bind(thisArg); + fn(this); + return this; + } + /** + * Creates an identical shallow copy of this collection. + * + * @example + * ```ts + * const newColl = someColl.clone(); + * ``` + */ + clone() { + return new this.constructor[Symbol.species](this); + } + /** + * Combines this collection with others into a new collection. None of the source collections are modified. + * + * @param collections - Collections to merge + * @example + * ```ts + * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl); + * ``` + */ + concat(...collections) { + const newColl = this.clone(); + for (const coll of collections) { + for (const [key, val] of coll) newColl.set(key, val); + } + return newColl; + } + /** + * Checks if this collection shares identical items with another. + * This is different to checking for equality using equal-signs, because + * the collections may be different objects, but contain the same data. + * + * @param collection - Collection to compare with + * @returns Whether the collections have identical contents + */ + equals(collection) { + if (!collection) return false; + if (this === collection) return true; + if (this.size !== collection.size) return false; + for (const [key, value] of this) { + if (!collection.has(key) || value !== collection.get(key)) { + return false; + } + } + return true; + } + /** + * The sort method sorts the items of a collection in place and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element. + * @example + * ```ts + * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + sort(compareFunction = _Collection.defaultSort) { + const entries = [...this.entries()]; + entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0])); + super.clear(); + for (const [key, value] of entries) { + super.set(key, value); + } + return this; + } + /** + * The intersection method returns a new collection containing the items where the key is present in both collections. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const intersection = col1.intersection(col2); + * console.log(col1.intersection(col2)); + * // => Collection { 'a' => 1 } + * ``` + */ + intersection(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (other.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing the items where the key is present in either of the collections. + * + * @remarks + * + * If the collections have any items with the same key, the value from the first collection will be used. + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]); + * const union = col1.union(col2); + * console.log(union); + * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 } + * ``` + */ + union(other) { + const coll = new this.constructor[Symbol.species](this); + for (const [key, value] of other) { + if (!coll.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing the items where the key is present in this collection but not the other. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * console.log(col1.difference(col2)); + * // => Collection { 'b' => 2 } + * console.log(col2.difference(col1)); + * // => Collection { 'c' => 3 } + * ``` + */ + difference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Returns a new collection containing only the items where the keys are present in either collection, but not both. + * + * @param other - The other Collection to filter against + * @example + * ```ts + * const col1 = new Collection([['a', 1], ['b', 2]]); + * const col2 = new Collection([['a', 1], ['c', 3]]); + * const symmetricDifference = col1.symmetricDifference(col2); + * console.log(col1.symmetricDifference(col2)); + * // => Collection { 'b' => 2, 'c' => 3 } + * ``` + */ + symmetricDifference(other) { + const coll = new this.constructor[Symbol.species](); + for (const [key, value] of this) { + if (!other.has(key)) coll.set(key, value); + } + for (const [key, value] of other) { + if (!this.has(key)) coll.set(key, value); + } + return coll; + } + /** + * Merges two Collections together into a new Collection. + * + * @param other - The other Collection to merge with + * @param whenInSelf - Function getting the result if the entry only exists in this Collection + * @param whenInOther - Function getting the result if the entry only exists in the other Collection + * @param whenInBoth - Function getting the result if the entry exists in both Collections + * @example + * ```ts + * // Sums up the entries in two collections. + * coll.merge( + * other, + * x => ({ keep: true, value: x }), + * y => ({ keep: true, value: y }), + * (x, y) => ({ keep: true, value: x + y }), + * ); + * ``` + * @example + * ```ts + * // Intersects two collections in a left-biased manner. + * coll.merge( + * other, + * x => ({ keep: false }), + * y => ({ keep: false }), + * (x, _) => ({ keep: true, value: x }), + * ); + * ``` + */ + merge(other, whenInSelf, whenInOther, whenInBoth) { + const coll = new this.constructor[Symbol.species](); + const keys = /* @__PURE__ */ new Set([...this.keys(), ...other.keys()]); + for (const key of keys) { + const hasInSelf = this.has(key); + const hasInOther = other.has(key); + if (hasInSelf && hasInOther) { + const result = whenInBoth(this.get(key), other.get(key), key); + if (result.keep) coll.set(key, result.value); + } else if (hasInSelf) { + const result = whenInSelf(this.get(key), key); + if (result.keep) coll.set(key, result.value); + } else if (hasInOther) { + const result = whenInOther(other.get(key), key); + if (result.keep) coll.set(key, result.value); + } + } + return coll; + } + /** + * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()} + * but returns a Collection instead of an Array. + */ + toReversed() { + return new this.constructor[Symbol.species](this).reverse(); + } + /** + * The sorted method sorts the items of a collection and returns it. + * The sort is not necessarily stable in Node 10 or older. + * The default sort order is according to string Unicode code points. + * + * @param compareFunction - Specifies a function that defines the sort order. + * If omitted, the collection is sorted according to each character's Unicode code point value, + * according to the string conversion of each element. + * @example + * ```ts + * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp); + * ``` + */ + toSorted(compareFunction = _Collection.defaultSort) { + return new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk)); + } + toJSON() { + return [...this.entries()]; + } + static defaultSort(firstValue, secondValue) { + return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1; + } + /** + * Creates a Collection from a list of entries. + * + * @param entries - The list of entries + * @param combine - Function to combine an existing entry with a new one + * @example + * ```ts + * Collection.combineEntries([["a", 1], ["b", 2], ["a", 2]], (x, y) => x + y); + * // returns Collection { "a" => 3, "b" => 2 } + * ``` + */ + static combineEntries(entries, combine) { + const coll = new _Collection(); + for (const [key, value] of entries) { + if (coll.has(key)) { + coll.set(key, combine(coll.get(key), value, key)); + } else { + coll.set(key, value); + } + } + return coll; + } +}; + +// src/index.ts +var version = "2.1.1"; +export { + Collection, + version +}; +//# sourceMappingURL=index.mjs.map \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs.map b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs.map new file mode 100644 index 0000000..4ae6ce5 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/dist/index.mjs.map @@ -0,0 +1 @@ +{"version":3,"sources":["../src/collection.ts","../src/index.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\n/**\n * @internal\n */\nexport interface CollectionConstructor {\n\tnew (): Collection;\n\tnew (entries?: readonly (readonly [Key, Value])[] | null): Collection;\n\tnew (iterable: Iterable): Collection;\n\treadonly prototype: Collection;\n\treadonly [Symbol.species]: CollectionConstructor;\n}\n\n/**\n * Represents an immutable version of a collection\n */\nexport type ReadonlyCollection = Omit<\n\tCollection,\n\t'clear' | 'delete' | 'ensure' | 'forEach' | 'get' | 'reverse' | 'set' | 'sort' | 'sweep'\n> &\n\tReadonlyMap;\n\n/**\n * Separate interface for the constructor so that emitted js does not have a constructor that overwrites itself\n *\n * @internal\n */\nexport interface Collection extends Map {\n\tconstructor: CollectionConstructor;\n}\n\n/**\n * A Map with additional utility methods. This is used throughout discord.js rather than Arrays for anything that has\n * an ID, for significantly improved performance and ease-of-use.\n *\n * @typeParam Key - The key type this collection holds\n * @typeParam Value - The value type this collection holds\n */\nexport class Collection extends Map {\n\t/**\n\t * Obtains the value of the given key if it exists, otherwise sets and returns the value provided by the default value generator.\n\t *\n\t * @param key - The key to get if it exists, or set otherwise\n\t * @param defaultValueGenerator - A function that generates the default value\n\t * @example\n\t * ```ts\n\t * collection.ensure(guildId, () => defaultGuildConfig);\n\t * ```\n\t */\n\tpublic ensure(key: Key, defaultValueGenerator: (key: Key, collection: this) => Value): Value {\n\t\tif (this.has(key)) return this.get(key)!;\n\t\tif (typeof defaultValueGenerator !== 'function') throw new TypeError(`${defaultValueGenerator} is not a function`);\n\t\tconst defaultValue = defaultValueGenerator(key, this);\n\t\tthis.set(key, defaultValue);\n\t\treturn defaultValue;\n\t}\n\n\t/**\n\t * Checks if all of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if all of the elements exist, `false` if at least one does not exist.\n\t */\n\tpublic hasAll(...keys: Key[]) {\n\t\treturn keys.every((key) => super.has(key));\n\t}\n\n\t/**\n\t * Checks if any of the elements exist in the collection.\n\t *\n\t * @param keys - The keys of the elements to check for\n\t * @returns `true` if any of the elements exist, `false` if none exist.\n\t */\n\tpublic hasAny(...keys: Key[]) {\n\t\treturn keys.some((key) => super.has(key));\n\t}\n\n\t/**\n\t * Obtains the first value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the beginning\n\t * @returns A single value if no amount is provided or an array of values, starting from the end if amount is negative\n\t */\n\tpublic first(): Value | undefined;\n\tpublic first(amount: number): Value[];\n\tpublic first(amount?: number): Value | Value[] | undefined {\n\t\tif (amount === undefined) return this.values().next().value;\n\t\tif (amount < 0) return this.last(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.values();\n\t\treturn Array.from({ length: amount }, (): Value => iter.next().value!);\n\t}\n\n\t/**\n\t * Obtains the first key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the beginning\n\t * @returns A single key if no amount is provided or an array of keys, starting from the end if\n\t * amount is negative\n\t */\n\tpublic firstKey(): Key | undefined;\n\tpublic firstKey(amount: number): Key[];\n\tpublic firstKey(amount?: number): Key | Key[] | undefined {\n\t\tif (amount === undefined) return this.keys().next().value;\n\t\tif (amount < 0) return this.lastKey(amount * -1);\n\t\tamount = Math.min(this.size, amount);\n\t\tconst iter = this.keys();\n\t\treturn Array.from({ length: amount }, (): Key => iter.next().value!);\n\t}\n\n\t/**\n\t * Obtains the last value(s) in this collection.\n\t *\n\t * @param amount - Amount of values to obtain from the end\n\t * @returns A single value if no amount is provided or an array of values, starting from the start if\n\t * amount is negative\n\t */\n\tpublic last(): Value | undefined;\n\tpublic last(amount: number): Value[];\n\tpublic last(amount?: number): Value | Value[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.first(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Obtains the last key(s) in this collection.\n\t *\n\t * @param amount - Amount of keys to obtain from the end\n\t * @returns A single key if no amount is provided or an array of keys, starting from the start if\n\t * amount is negative\n\t */\n\tpublic lastKey(): Key | undefined;\n\tpublic lastKey(amount: number): Key[];\n\tpublic lastKey(amount?: number): Key | Key[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[arr.length - 1];\n\t\tif (amount < 0) return this.firstKey(amount * -1);\n\t\tif (!amount) return [];\n\t\treturn arr.slice(-amount);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the item at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the element to obtain\n\t */\n\tpublic at(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.values()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/at | Array.at()}.\n\t * Returns the key at a given index, allowing for positive and negative integers.\n\t * Negative integers count back from the last item in the collection.\n\t *\n\t * @param index - The index of the key to obtain\n\t */\n\tpublic keyAt(index: number) {\n\t\tindex = Math.floor(index);\n\t\tconst arr = [...this.keys()];\n\t\treturn arr.at(index);\n\t}\n\n\t/**\n\t * Obtains unique random value(s) from this collection.\n\t *\n\t * @param amount - Amount of values to obtain randomly\n\t * @returns A single value if no amount is provided or an array of values\n\t */\n\tpublic random(): Value | undefined;\n\tpublic random(amount: number): Value[];\n\tpublic random(amount?: number): Value | Value[] | undefined {\n\t\tconst arr = [...this.values()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): Value => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Obtains unique random key(s) from this collection.\n\t *\n\t * @param amount - Amount of keys to obtain randomly\n\t * @returns A single key if no amount is provided or an array\n\t */\n\tpublic randomKey(): Key | undefined;\n\tpublic randomKey(amount: number): Key[];\n\tpublic randomKey(amount?: number): Key | Key[] | undefined {\n\t\tconst arr = [...this.keys()];\n\t\tif (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n\t\tif (!arr.length || !amount) return [];\n\t\treturn Array.from(\n\t\t\t{ length: Math.min(amount, arr.length) },\n\t\t\t(): Key => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]!,\n\t\t);\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse | Array.reverse()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic reverse() {\n\t\tconst entries = [...this.entries()].reverse();\n\t\tthis.clear();\n\t\tfor (const [key, value] of entries) this.set(key, value);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Searches for a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find | Array.find()}.\n\t * All collections used in Discord.js are mapped using their `id` property, and if you want to find by id you\n\t * should use the `get` method. See\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/get | MDN} for details.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.find(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic find(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): NewValue | undefined;\n\tpublic find(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): NewValue | undefined;\n\tpublic find(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Value | undefined;\n\tpublic find(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Value | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a single item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex | Array.findIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.findKey(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic findKey(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): NewKey | undefined;\n\tpublic findKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): NewKey | undefined;\n\tpublic findKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Key | undefined;\n\tpublic findKey(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Key | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for a last item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLast | Array.findLast()}.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t */\n\tpublic findLast(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): NewValue | undefined;\n\tpublic findLast(fn: (value: Value, key: Key, collection: this) => unknown): Value | undefined;\n\tpublic findLast(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): NewValue | undefined;\n\tpublic findLast(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Value | undefined;\n\tpublic findLast(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Value | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst entries = [...this.entries()];\n\t\tfor (let index = entries.length - 1; index >= 0; index--) {\n\t\t\tconst val = entries[index]![1];\n\t\t\tconst key = entries[index]![0];\n\t\t\tif (fn(val, key, this)) return val;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Searches for the key of a last item where the given function returns a truthy value. This behaves like\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findLastIndex | Array.findLastIndex()},\n\t * but returns the key rather than the positional index.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t */\n\tpublic findLastKey(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): NewKey | undefined;\n\tpublic findLastKey(fn: (value: Value, key: Key, collection: this) => unknown): Key | undefined;\n\tpublic findLastKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): NewKey | undefined;\n\tpublic findLastKey(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Key | undefined;\n\tpublic findLastKey(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Key | undefined {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst entries = [...this.entries()];\n\t\tfor (let index = entries.length - 1; index >= 0; index--) {\n\t\t\tconst key = entries[index]![0];\n\t\t\tconst val = entries[index]![1];\n\t\t\tif (fn(val, key, this)) return key;\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\t/**\n\t * Removes items that satisfy the provided filter function.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @returns The number of removed entries\n\t */\n\tpublic sweep(fn: (value: Value, key: Key, collection: this) => unknown): number;\n\tpublic sweep(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): number;\n\tpublic sweep(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): number {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst previousSize = this.size;\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) this.delete(key);\n\t\t}\n\n\t\treturn previousSize - this.size;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter | Array.filter()},\n\t * but returns a Collection instead of an Array.\n\t *\n\t * @param fn - The function to test with (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.filter(user => user.username === 'Bob');\n\t * ```\n\t */\n\tpublic filter(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): Collection;\n\tpublic filter(fn: (value: Value, key: Key, collection: this) => unknown): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic filter(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) results.set(key, val);\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Partitions the collection into two collections where the first collection\n\t * contains the items that passed and the second contains the items that failed.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * const [big, small] = collection.partition(guild => guild.memberCount > 250);\n\t * ```\n\t */\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): [Collection, Collection, Value>];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => unknown,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): [Collection, Collection, Value>];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): [Collection, Collection>];\n\tpublic partition(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg: This,\n\t): [Collection, Collection];\n\tpublic partition(\n\t\tfn: (value: Value, key: Key, collection: this) => unknown,\n\t\tthisArg?: unknown,\n\t): [Collection, Collection] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst results: [Collection, Collection] = [\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t\tnew this.constructor[Symbol.species](),\n\t\t];\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) {\n\t\t\t\tresults[0].set(key, val);\n\t\t\t} else {\n\t\t\t\tresults[1].set(key, val);\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\t/**\n\t * Maps each item into a Collection, then joins the results into a single Collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flatMap | Array.flatMap()}.\n\t *\n\t * @param fn - Function that produces a new Collection\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.flatMap(guild => guild.members.cache);\n\t * ```\n\t */\n\tpublic flatMap(\n\t\tfn: (value: Value, key: Key, collection: this) => Collection,\n\t): Collection;\n\tpublic flatMap(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => Collection,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic flatMap(\n\t\tfn: (value: Value, key: Key, collection: this) => Collection,\n\t\tthisArg?: unknown,\n\t): Collection {\n\t\t// eslint-disable-next-line unicorn/no-array-method-this-argument\n\t\tconst collections = this.map(fn, thisArg);\n\t\treturn new this.constructor[Symbol.species]().concat(...collections);\n\t}\n\n\t/**\n\t * Maps each item to another value into an array. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new array, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.map(user => user.tag);\n\t * ```\n\t */\n\tpublic map(fn: (value: Value, key: Key, collection: this) => NewValue): NewValue[];\n\tpublic map(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg: This,\n\t): NewValue[];\n\tpublic map(fn: (value: Value, key: Key, collection: this) => NewValue, thisArg?: unknown): NewValue[] {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst iter = this.entries();\n\t\treturn Array.from({ length: this.size }, (): NewValue => {\n\t\t\tconst [key, value] = iter.next().value!;\n\t\t\treturn fn(value, key, this);\n\t\t});\n\t}\n\n\t/**\n\t * Maps each item to another value into a collection. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map | Array.map()}.\n\t *\n\t * @param fn - Function that produces an element of the new collection, taking three arguments\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.mapValues(user => user.tag);\n\t * ```\n\t */\n\tpublic mapValues(fn: (value: Value, key: Key, collection: this) => NewValue): Collection;\n\tpublic mapValues(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg: This,\n\t): Collection;\n\tpublic mapValues(\n\t\tfn: (value: Value, key: Key, collection: this) => NewValue,\n\t\tthisArg?: unknown,\n\t): Collection {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tfor (const [key, val] of this) coll.set(key, fn(val, key, this));\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Checks if there exists an item that passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some | Array.some()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.some(user => user.discriminator === '0000');\n\t * ```\n\t */\n\tpublic some(fn: (value: Value, key: Key, collection: this) => unknown): boolean;\n\tpublic some(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean;\n\tpublic some(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (fn(val, key, this)) return true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t * Checks if all items passes a test. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every | Array.every()}.\n\t *\n\t * @param fn - Function used to test (should return a boolean)\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection.every(user => !user.bot);\n\t * ```\n\t */\n\tpublic every(\n\t\tfn: (value: Value, key: Key, collection: this) => key is NewKey,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (value: Value, key: Key, collection: this) => value is NewValue,\n\t): this is Collection;\n\tpublic every(fn: (value: Value, key: Key, collection: this) => unknown): boolean;\n\tpublic every(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => key is NewKey,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(\n\t\tfn: (this: This, value: Value, key: Key, collection: this) => value is NewValue,\n\t\tthisArg: This,\n\t): this is Collection;\n\tpublic every(fn: (this: This, value: Value, key: Key, collection: this) => unknown, thisArg: This): boolean;\n\tpublic every(fn: (value: Value, key: Key, collection: this) => unknown, thisArg?: unknown): boolean {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfor (const [key, val] of this) {\n\t\t\tif (!fn(val, key, this)) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce | Array.reduce()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `currentValue`, `currentKey`,\n\t * and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t * @example\n\t * ```ts\n\t * collection.reduce((acc, guild) => acc + guild.memberCount, 0);\n\t * ```\n\t */\n\tpublic reduce(\n\t\tfn: (accumulator: Value, value: Value, key: Key, collection: this) => Value,\n\t\tinitialValue?: Value,\n\t): Value;\n\tpublic reduce(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue: InitialValue,\n\t): InitialValue;\n\tpublic reduce(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue?: InitialValue,\n\t): InitialValue {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tlet accumulator!: InitialValue;\n\n\t\tconst iterator = this.entries();\n\t\tif (initialValue === undefined) {\n\t\t\tif (this.size === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = iterator.next().value![1] as unknown as InitialValue;\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t}\n\n\t\tfor (const [key, value] of iterator) {\n\t\t\taccumulator = fn(accumulator, value, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Applies a function to produce a single value. Identical in behavior to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight | Array.reduceRight()}.\n\t *\n\t * @param fn - Function used to reduce, taking four arguments; `accumulator`, `value`, `key`, and `collection`\n\t * @param initialValue - Starting value for the accumulator\n\t */\n\tpublic reduceRight(\n\t\tfn: (accumulator: Value, value: Value, key: Key, collection: this) => Value,\n\t\tinitialValue?: Value,\n\t): Value;\n\tpublic reduceRight(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue: InitialValue,\n\t): InitialValue;\n\tpublic reduceRight(\n\t\tfn: (accumulator: InitialValue, value: Value, key: Key, collection: this) => InitialValue,\n\t\tinitialValue?: InitialValue,\n\t): InitialValue {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tconst entries = [...this.entries()];\n\t\tlet accumulator!: InitialValue;\n\n\t\tlet index: number;\n\t\tif (initialValue === undefined) {\n\t\t\tif (entries.length === 0) throw new TypeError('Reduce of empty collection with no initial value');\n\t\t\taccumulator = entries[entries.length - 1]![1] as unknown as InitialValue;\n\t\t\tindex = entries.length - 1;\n\t\t} else {\n\t\t\taccumulator = initialValue;\n\t\t\tindex = entries.length;\n\t\t}\n\n\t\twhile (--index >= 0) {\n\t\t\tconst key = entries[index]![0];\n\t\t\tconst val = entries[index]![1];\n\t\t\taccumulator = fn(accumulator, val, key, this);\n\t\t}\n\n\t\treturn accumulator;\n\t}\n\n\t/**\n\t * Identical to\n\t * {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach | Map.forEach()},\n\t * but returns the collection instead of undefined.\n\t *\n\t * @param fn - Function to execute for each element\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .each(user => console.log(user.username))\n\t * .filter(user => user.bot)\n\t * .each(user => console.log(user.username));\n\t * ```\n\t */\n\tpublic each(fn: (value: Value, key: Key, collection: this) => void): this;\n\tpublic each(fn: (this: This, value: Value, key: Key, collection: this) => void, thisArg: This): this;\n\tpublic each(fn: (value: Value, key: Key, collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\n\t\tfor (const [key, value] of this) {\n\t\t\tfn(value, key, this);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Runs a function on the collection and returns the collection.\n\t *\n\t * @param fn - Function to execute\n\t * @param thisArg - Value to use as `this` when executing the function\n\t * @example\n\t * ```ts\n\t * collection\n\t * .tap(coll => console.log(coll.size))\n\t * .filter(user => user.bot)\n\t * .tap(coll => console.log(coll.size))\n\t * ```\n\t */\n\tpublic tap(fn: (collection: this) => void): this;\n\tpublic tap(fn: (this: This, collection: this) => void, thisArg: This): this;\n\tpublic tap(fn: (collection: this) => void, thisArg?: unknown): this {\n\t\tif (typeof fn !== 'function') throw new TypeError(`${fn} is not a function`);\n\t\tif (thisArg !== undefined) fn = fn.bind(thisArg);\n\t\tfn(this);\n\t\treturn this;\n\t}\n\n\t/**\n\t * Creates an identical shallow copy of this collection.\n\t *\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.clone();\n\t * ```\n\t */\n\tpublic clone(): Collection {\n\t\treturn new this.constructor[Symbol.species](this);\n\t}\n\n\t/**\n\t * Combines this collection with others into a new collection. None of the source collections are modified.\n\t *\n\t * @param collections - Collections to merge\n\t * @example\n\t * ```ts\n\t * const newColl = someColl.concat(someOtherColl, anotherColl, ohBoyAColl);\n\t * ```\n\t */\n\tpublic concat(...collections: ReadonlyCollection[]) {\n\t\tconst newColl = this.clone();\n\t\tfor (const coll of collections) {\n\t\t\tfor (const [key, val] of coll) newColl.set(key, val);\n\t\t}\n\n\t\treturn newColl;\n\t}\n\n\t/**\n\t * Checks if this collection shares identical items with another.\n\t * This is different to checking for equality using equal-signs, because\n\t * the collections may be different objects, but contain the same data.\n\t *\n\t * @param collection - Collection to compare with\n\t * @returns Whether the collections have identical contents\n\t */\n\tpublic equals(collection: ReadonlyCollection) {\n\t\tif (!collection) return false; // runtime check\n\t\tif (this === collection) return true;\n\t\tif (this.size !== collection.size) return false;\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!collection.has(key) || value !== collection.get(key)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\t/**\n\t * The sort method sorts the items of a collection in place and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value, according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sort((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic sort(compareFunction: Comparator = Collection.defaultSort) {\n\t\tconst entries = [...this.entries()];\n\t\tentries.sort((a, b): number => compareFunction(a[1], b[1], a[0], b[0]));\n\n\t\t// Perform clean-up\n\t\tsuper.clear();\n\n\t\t// Set the new entries\n\t\tfor (const [key, value] of entries) {\n\t\t\tsuper.set(key, value);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * The intersection method returns a new collection containing the items where the key is present in both collections.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * const intersection = col1.intersection(col2);\n\t * console.log(col1.intersection(col2));\n\t * // => Collection { 'a' => 1 }\n\t * ```\n\t */\n\tpublic intersection(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing the items where the key is present in either of the collections.\n\t *\n\t * @remarks\n\t *\n\t * If the collections have any items with the same key, the value from the first collection will be used.\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['b', 3], ['c', 3]]);\n\t * const union = col1.union(col2);\n\t * console.log(union);\n\t * // => Collection { 'a' => 1, 'b' => 2, 'c' => 3 }\n\t * ```\n\t */\n\tpublic union(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species](this);\n\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!coll.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing the items where the key is present in this collection but not the other.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * console.log(col1.difference(col2));\n\t * // => Collection { 'b' => 2 }\n\t * console.log(col2.difference(col1));\n\t * // => Collection { 'c' => 3 }\n\t * ```\n\t */\n\tpublic difference(other: ReadonlyCollection): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Returns a new collection containing only the items where the keys are present in either collection, but not both.\n\t *\n\t * @param other - The other Collection to filter against\n\t * @example\n\t * ```ts\n\t * const col1 = new Collection([['a', 1], ['b', 2]]);\n\t * const col2 = new Collection([['a', 1], ['c', 3]]);\n\t * const symmetricDifference = col1.symmetricDifference(col2);\n\t * console.log(col1.symmetricDifference(col2));\n\t * // => Collection { 'b' => 2, 'c' => 3 }\n\t * ```\n\t */\n\tpublic symmetricDifference(\n\t\tother: ReadonlyCollection,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\n\t\tfor (const [key, value] of this) {\n\t\t\tif (!other.has(key)) coll.set(key, value);\n\t\t}\n\n\t\tfor (const [key, value] of other) {\n\t\t\tif (!this.has(key)) coll.set(key, value);\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Merges two Collections together into a new Collection.\n\t *\n\t * @param other - The other Collection to merge with\n\t * @param whenInSelf - Function getting the result if the entry only exists in this Collection\n\t * @param whenInOther - Function getting the result if the entry only exists in the other Collection\n\t * @param whenInBoth - Function getting the result if the entry exists in both Collections\n\t * @example\n\t * ```ts\n\t * // Sums up the entries in two collections.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: true, value: x }),\n\t * y => ({ keep: true, value: y }),\n\t * (x, y) => ({ keep: true, value: x + y }),\n\t * );\n\t * ```\n\t * @example\n\t * ```ts\n\t * // Intersects two collections in a left-biased manner.\n\t * coll.merge(\n\t * other,\n\t * x => ({ keep: false }),\n\t * y => ({ keep: false }),\n\t * (x, _) => ({ keep: true, value: x }),\n\t * );\n\t * ```\n\t */\n\tpublic merge(\n\t\tother: ReadonlyCollection,\n\t\twhenInSelf: (value: Value, key: Key) => Keep,\n\t\twhenInOther: (valueOther: OtherValue, key: Key) => Keep,\n\t\twhenInBoth: (value: Value, valueOther: OtherValue, key: Key) => Keep,\n\t): Collection {\n\t\tconst coll = new this.constructor[Symbol.species]();\n\t\tconst keys = new Set([...this.keys(), ...other.keys()]);\n\n\t\tfor (const key of keys) {\n\t\t\tconst hasInSelf = this.has(key);\n\t\t\tconst hasInOther = other.has(key);\n\n\t\t\tif (hasInSelf && hasInOther) {\n\t\t\t\tconst result = whenInBoth(this.get(key)!, other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInSelf) {\n\t\t\t\tconst result = whenInSelf(this.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t} else if (hasInOther) {\n\t\t\t\tconst result = whenInOther(other.get(key)!, key);\n\t\t\t\tif (result.keep) coll.set(key, result.value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n\n\t/**\n\t * Identical to {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/toReversed | Array.toReversed()}\n\t * but returns a Collection instead of an Array.\n\t */\n\tpublic toReversed() {\n\t\treturn new this.constructor[Symbol.species](this).reverse();\n\t}\n\n\t/**\n\t * The sorted method sorts the items of a collection and returns it.\n\t * The sort is not necessarily stable in Node 10 or older.\n\t * The default sort order is according to string Unicode code points.\n\t *\n\t * @param compareFunction - Specifies a function that defines the sort order.\n\t * If omitted, the collection is sorted according to each character's Unicode code point value,\n\t * according to the string conversion of each element.\n\t * @example\n\t * ```ts\n\t * collection.sorted((userA, userB) => userA.createdTimestamp - userB.createdTimestamp);\n\t * ```\n\t */\n\tpublic toSorted(compareFunction: Comparator = Collection.defaultSort) {\n\t\treturn new this.constructor[Symbol.species](this).sort((av, bv, ak, bk) => compareFunction(av, bv, ak, bk));\n\t}\n\n\tpublic toJSON() {\n\t\t// toJSON is called recursively by JSON.stringify.\n\t\treturn [...this.entries()];\n\t}\n\n\tprivate static defaultSort(firstValue: Value, secondValue: Value): number {\n\t\treturn Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n\t}\n\n\t/**\n\t * Creates a Collection from a list of entries.\n\t *\n\t * @param entries - The list of entries\n\t * @param combine - Function to combine an existing entry with a new one\n\t * @example\n\t * ```ts\n\t * Collection.combineEntries([[\"a\", 1], [\"b\", 2], [\"a\", 2]], (x, y) => x + y);\n\t * // returns Collection { \"a\" => 3, \"b\" => 2 }\n\t * ```\n\t */\n\tpublic static combineEntries(\n\t\tentries: Iterable<[Key, Value]>,\n\t\tcombine: (firstValue: Value, secondValue: Value, key: Key) => Value,\n\t): Collection {\n\t\tconst coll = new Collection();\n\t\tfor (const [key, value] of entries) {\n\t\t\tif (coll.has(key)) {\n\t\t\t\tcoll.set(key, combine(coll.get(key)!, value, key));\n\t\t\t} else {\n\t\t\t\tcoll.set(key, value);\n\t\t\t}\n\t\t}\n\n\t\treturn coll;\n\t}\n}\n\n/**\n * @internal\n */\nexport type Keep = { keep: false } | { keep: true; value: Value };\n\n/**\n * @internal\n */\nexport type Comparator = (firstValue: Value, secondValue: Value, firstKey: Key, secondKey: Key) => number;\n","export * from './collection.js';\n\n/**\n * The {@link https://github.com/discordjs/discord.js/blob/main/packages/collection#readme | @discordjs/collection} version\n * that you are currently using.\n */\n// This needs to explicitly be `string` so it is not typed as a \"const string\" that gets injected by esbuild\nexport const version = '2.1.1' as string;\n"],"mappings":"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","names":[]} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/package.json b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/package.json new file mode 100644 index 0000000..ca7a22b --- /dev/null +++ b/node_modules/.pnpm/@discordjs+collection@2.1.1/node_modules/@discordjs/collection/package.json @@ -0,0 +1,86 @@ +{ + "$schema": "https://json.schemastore.org/package.json", + "name": "@discordjs/collection", + "version": "2.1.1", + "description": "Utility data structure used in discord.js", + "exports": { + ".": { + "require": { + "types": "./dist/index.d.ts", + "default": "./dist/index.js" + }, + "import": { + "types": "./dist/index.d.mts", + "default": "./dist/index.mjs" + } + } + }, + "main": "./dist/index.js", + "module": "./dist/index.mjs", + "types": "./dist/index.d.ts", + "directories": { + "lib": "src", + "test": "__tests__" + }, + "files": [ + "dist" + ], + "contributors": [ + "Crawl ", + "Amish Shah ", + "SpaceEEC ", + "Vlad Frangu ", + "Aura Román " + ], + "license": "Apache-2.0", + "keywords": [ + "map", + "collection", + "utility" + ], + "repository": { + "type": "git", + "url": "https://github.com/discordjs/discord.js.git", + "directory": "packages/collection" + }, + "bugs": { + "url": "https://github.com/discordjs/discord.js/issues" + }, + "homepage": "https://discord.js.org", + "funding": "https://github.com/discordjs/discord.js?sponsor", + "devDependencies": { + "@favware/cliff-jumper": "^4.1.0", + "@types/node": "^18.19.45", + "@vitest/coverage-v8": "^2.0.5", + "cross-env": "^7.0.3", + "esbuild-plugin-version-injector": "^1.2.1", + "eslint": "^8.57.0", + "eslint-config-neon": "^0.1.62", + "eslint-formatter-pretty": "^6.0.1", + "prettier": "^3.3.3", + "tsup": "^8.2.4", + "turbo": "^2.0.14", + "typescript": "~5.5.4", + "vitest": "^2.0.5", + "@discordjs/scripts": "^0.1.0", + "@discordjs/api-extractor": "^7.38.1" + }, + "engines": { + "node": ">=18" + }, + "publishConfig": { + "access": "public", + "provenance": true + }, + "scripts": { + "test": "vitest run", + "build": "tsc --noEmit && tsup", + "build:docs": "tsc -p tsconfig.docs.json", + "lint": "prettier --check . && cross-env TIMING=1 eslint --format=pretty src __tests__", + "format": "prettier --write . && cross-env TIMING=1 eslint --fix --format=pretty src __tests__", + "fmt": "pnpm run format", + "docs": "pnpm run build:docs && api-extractor run --local --minify && generate-split-documentation", + "changelog": "git cliff --prepend ./CHANGELOG.md -u -c ./cliff.toml -r ../../ --include-path 'packages/collection/*'", + "release": "cliff-jumper" + } +} \ No newline at end of file diff --git a/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/LICENSE b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/LICENSE new file mode 100644 index 0000000..e2baac1 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/LICENSE @@ -0,0 +1,191 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + Copyright 2021 Noel Buechler + Copyright 2021 Vlad Frangu + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/README.md b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/README.md new file mode 100644 index 0000000..65ad4b0 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/README.md @@ -0,0 +1,82 @@ +
+
+

+ discord.js +

+
+

+ Discord server + npm version + npm downloads + Build status + Code coverage +

+

+ Vercel + Cloudflare Workers +

+
+ +## About + +`@discordjs/formatters` is a collection of functions for formatting strings to be used on Discord. + +## Installation + +**Node.js 16.11.0 or newer is required.** + +```sh +npm install @discordjs/formatters +yarn add @discordjs/formatters +pnpm add @discordjs/formatters +bun add @discordjs/formatters +``` + +## Example usage + +````ts +import { codeBlock } from '@discordjs/formatters'; + +const formattedCode = codeBlock('hello world!'); +console.log(formattedCode); + +// Prints: +// ``` +// hello world! +// ``` +```` + +## Links + +- [Website][website] ([source][website-source]) +- [Documentation][documentation] +- [Guide][guide] ([source][guide-source]) + Also see the v13 to v14 [Update Guide][guide-update], which includes updated and removed items from the library. +- [discord.js Discord server][discord] +- [Discord API Discord server][discord-api] +- [GitHub][source] +- [npm][npm] +- [Related libraries][related-libs] + +## Contributing + +Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the +[documentation][documentation]. +See [the contribution guide][contributing] if you'd like to submit a PR. + +## Help + +If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official [discord.js Server][discord]. + +[website]: https://discord.js.org +[website-source]: https://github.com/discordjs/discord.js/tree/main/apps/website +[documentation]: https://discord.js.org/docs/packages/formatters/stable +[guide]: https://discordjs.guide/ +[guide-source]: https://github.com/discordjs/guide +[guide-update]: https://discordjs.guide/additional-info/changes-in-v14.html +[discord]: https://discord.gg/djs +[discord-api]: https://discord.gg/discord-api +[source]: https://github.com/discordjs/discord.js/tree/main/packages/formatters +[npm]: https://www.npmjs.com/package/@discordjs/formatters +[related-libs]: https://discord.com/developers/docs/topics/community-resources#libraries +[contributing]: https://github.com/discordjs/discord.js/blob/main/.github/CONTRIBUTING.md diff --git a/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.d.mts b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.d.mts new file mode 100644 index 0000000..b792965 --- /dev/null +++ b/node_modules/.pnpm/@discordjs+formatters@0.6.0/node_modules/@discordjs/formatters/dist/index.d.mts @@ -0,0 +1,673 @@ +import { URL } from 'node:url'; +import { Snowflake } from 'discord-api-types/globals'; + +/** + * The options that affect what will be escaped. + */ +interface EscapeMarkdownOptions { + /** + * Whether to escape bold text. + * + * @defaultValue `true` + */ + bold?: boolean; + /** + * Whether to escape bulleted lists. + * + * @defaultValue `false` + */ + bulletedList?: boolean; + /** + * Whether to escape code blocks. + * + * @defaultValue `true` + */ + codeBlock?: boolean; + /** + * Whether to escape text inside code blocks. + * + * @defaultValue `true` + */ + codeBlockContent?: boolean; + /** + * Whether to escape `\`. + * + * @defaultValue `true` + */ + escape?: boolean; + /** + * Whether to escape headings. + * + * @defaultValue `false` + */ + heading?: boolean; + /** + * Whether to escape inline code. + * + * @defaultValue `true` + */ + inlineCode?: boolean; + /** + * Whether to escape text inside inline code. + * + * @defaultValue `true` + */ + inlineCodeContent?: boolean; + /** + * Whether to escape italics. + * + * @defaultValue `true` + */ + italic?: boolean; + /** + * Whether to escape masked links. + * + * @defaultValue `false` + */ + maskedLink?: boolean; + /** + * Whether to escape numbered lists. + * + * @defaultValue `false` + */ + numberedList?: boolean; + /** + * Whether to escape spoilers. + * + * @defaultValue `true` + */ + spoiler?: boolean; + /** + * Whether to escape strikethroughs. + * + * @defaultValue `true` + */ + strikethrough?: boolean; + /** + * Whether to escape underlines. + * + * @defaultValue `true` + */ + underline?: boolean; +} +/** + * Escapes any Discord-flavored markdown in a string. + * + * @param text - Content to escape + * @param options - Options for escaping the markdown + */ +declare function escapeMarkdown(text: string, options?: EscapeMarkdownOptions): string; +/** + * Escapes code block markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeCodeBlock(text: string): string; +/** + * Escapes inline code markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeInlineCode(text: string): string; +/** + * Escapes italic markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeItalic(text: string): string; +/** + * Escapes bold markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeBold(text: string): string; +/** + * Escapes underline markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeUnderline(text: string): string; +/** + * Escapes strikethrough markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeStrikethrough(text: string): string; +/** + * Escapes spoiler markdown in a string. + * + * @param text - Content to escape + */ +declare function escapeSpoiler(text: string): string; +/** + * Escapes escape characters in a string. + * + * @param text - Content to escape + */ +declare function escapeEscape(text: string): string; +/** + * Escapes heading characters in a string. + * + * @param text - Content to escape + */ +declare function escapeHeading(text: string): string; +/** + * Escapes bulleted list characters in a string. + * + * @param text - Content to escape + */ +declare function escapeBulletedList(text: string): string; +/** + * Escapes numbered list characters in a string. + * + * @param text - Content to escape + */ +declare function escapeNumberedList(text: string): string; +/** + * Escapes masked link characters in a string. + * + * @param text - Content to escape + */ +declare function escapeMaskedLink(text: string): string; + +/** + * Wraps the content inside a code block with no language. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function codeBlock(content: Content): `\`\`\`\n${Content}\n\`\`\``; +/** + * Wraps the content inside a code block with the specified language. + * + * @typeParam Language - This is inferred by the supplied language + * @typeParam Content - This is inferred by the supplied content + * @param language - The language for the code block + * @param content - The content to wrap + */ +declare function codeBlock(language: Language, content: Content): `\`\`\`${Language}\n${Content}\n\`\`\``; +/** + * Wraps the content inside \`backticks\` which formats it as inline code. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function inlineCode(content: Content): `\`${Content}\``; +/** + * Formats the content into italic text. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function italic(content: Content): `_${Content}_`; +/** + * Formats the content into bold text. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function bold(content: Content): `**${Content}**`; +/** + * Formats the content into underscored text. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + * @deprecated Use {@link underline} instead. + */ +declare function underscore(content: Content): `__${Content}__`; +/** + * Formats the content into underlined text. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function underline(content: Content): `__${Content}__`; +/** + * Formats the content into strike-through text. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function strikethrough(content: Content): `~~${Content}~~`; +/** + * Formats the content into a quote. + * + * @remarks This needs to be at the start of the line for Discord to format it. + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function quote(content: Content): `> ${Content}`; +/** + * Formats the content into a block quote. + * + * @remarks This needs to be at the start of the line for Discord to format it. + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function blockQuote(content: Content): `>>> ${Content}`; +/** + * Wraps the URL into `<>` which stops it from embedding. + * + * @typeParam Content - This is inferred by the supplied content + * @param url - The URL to wrap + */ +declare function hideLinkEmbed(url: Content): `<${Content}>`; +/** + * Wraps the URL into `<>` which stops it from embedding. + * + * @param url - The URL to wrap + */ +declare function hideLinkEmbed(url: URL): `<${string}>`; +/** + * Formats the content and the URL into a masked URL. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to display + * @param url - The URL the content links to + */ +declare function hyperlink(content: Content, url: URL): `[${Content}](${string})`; +/** + * Formats the content and the URL into a masked URL. + * + * @typeParam Content - This is inferred by the supplied content + * @typeParam Url - This is inferred by the supplied URL + * @param content - The content to display + * @param url - The URL the content links to + */ +declare function hyperlink(content: Content, url: Url): `[${Content}](${Url})`; +/** + * Formats the content and the URL into a masked URL with a custom tooltip. + * + * @typeParam Content - This is inferred by the supplied content + * @typeParam Title - This is inferred by the supplied title + * @param content - The content to display + * @param url - The URL the content links to + * @param title - The title shown when hovering on the masked link + */ +declare function hyperlink(content: Content, url: URL, title: Title): `[${Content}](${string} "${Title}")`; +/** + * Formats the content and the URL into a masked URL with a custom tooltip. + * + * @typeParam Content - This is inferred by the supplied content + * @typeParam Url - This is inferred by the supplied URL + * @typeParam Title - This is inferred by the supplied title + * @param content - The content to display + * @param url - The URL the content links to + * @param title - The title shown when hovering on the masked link + */ +declare function hyperlink(content: Content, url: Url, title: Title): `[${Content}](${Url} "${Title}")`; +/** + * Formats the content into a spoiler. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function spoiler(content: Content): `||${Content}||`; +/** + * Formats a user id into a user mention. + * + * @typeParam UserId - This is inferred by the supplied user id + * @param userId - The user id to format + */ +declare function userMention(userId: UserId): `<@${UserId}>`; +/** + * Formats a channel id into a channel mention. + * + * @typeParam ChannelId - This is inferred by the supplied channel id + * @param channelId - The channel id to format + */ +declare function channelMention(channelId: ChannelId): `<#${ChannelId}>`; +/** + * Formats a role id into a role mention. + * + * @typeParam RoleId - This is inferred by the supplied role id + * @param roleId - The role id to format + */ +declare function roleMention(roleId: RoleId): `<@&${RoleId}>`; +/** + * Formats an application command name, subcommand group name, subcommand name, and id into an application command mention. + * + * @typeParam CommandName - This is inferred by the supplied command name + * @typeParam SubcommandGroupName - This is inferred by the supplied subcommand group name + * @typeParam SubcommandName - This is inferred by the supplied subcommand name + * @typeParam CommandId - This is inferred by the supplied command id + * @param commandName - The application command name to format + * @param subcommandGroupName - The subcommand group name to format + * @param subcommandName - The subcommand name to format + * @param commandId - The application command id to format + */ +declare function chatInputApplicationCommandMention(commandName: CommandName, subcommandGroupName: SubcommandGroupName, subcommandName: SubcommandName, commandId: CommandId): ``; +/** + * Formats an application command name, subcommand name, and id into an application command mention. + * + * @typeParam CommandName - This is inferred by the supplied command name + * @typeParam SubcommandName - This is inferred by the supplied subcommand name + * @typeParam CommandId - This is inferred by the supplied command id + * @param commandName - The application command name to format + * @param subcommandName - The subcommand name to format + * @param commandId - The application command id to format + */ +declare function chatInputApplicationCommandMention(commandName: CommandName, subcommandName: SubcommandName, commandId: CommandId): ``; +/** + * Formats an application command name and id into an application command mention. + * + * @typeParam CommandName - This is inferred by the supplied command name + * @typeParam CommandId - This is inferred by the supplied command id + * @param commandName - The application command name to format + * @param commandId - The application command id to format + */ +declare function chatInputApplicationCommandMention(commandName: CommandName, commandId: CommandId): ``; +/** + * Formats a non-animated emoji id into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @param emojiId - The emoji id to format + */ +declare function formatEmoji(emojiId: EmojiId, animated?: false): `<:_:${EmojiId}>`; +/** + * Formats an animated emoji id into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @param emojiId - The emoji id to format + * @param animated - Whether the emoji is animated + */ +declare function formatEmoji(emojiId: EmojiId, animated?: true): ``; +/** + * Formats an emoji id into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @param emojiId - The emoji id to format + * @param animated - Whether the emoji is animated + */ +declare function formatEmoji(emojiId: EmojiId, animated?: boolean): `<:_:${EmojiId}>` | ``; +/** + * Formats a non-animated emoji id and name into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @typeParam EmojiName - This is inferred by the supplied name + * @param options - The options for formatting an emoji + */ +declare function formatEmoji(options: FormatEmojiOptions & { + animated: true; +}): ``; +/** + * Formats an animated emoji id and name into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @typeParam EmojiName - This is inferred by the supplied name + * @param options - The options for formatting an emoji + */ +declare function formatEmoji(options: FormatEmojiOptions & { + animated?: false; +}): `<:${EmojiName}:${EmojiId}>`; +/** + * Formats an emoji id and name into a fully qualified emoji identifier. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @typeParam EmojiName - This is inferred by the supplied emoji name + * @param options - The options for formatting an emoji + */ +declare function formatEmoji(options: FormatEmojiOptions): `<:${EmojiName}:${EmojiId}>` | ``; +/** + * The options for formatting an emoji. + * + * @typeParam EmojiId - This is inferred by the supplied emoji id + * @typeParam EmojiName - This is inferred by the supplied emoji name + */ +interface FormatEmojiOptions { + /** + * Whether the emoji is animated + */ + animated?: boolean; + /** + * The emoji id to format + */ + id: EmojiId; + /** + * The name of the emoji + */ + name?: EmojiName; +} +/** + * Formats a channel link for a direct message channel. + * + * @typeParam ChannelId - This is inferred by the supplied channel id + * @param channelId - The channel's id + */ +declare function channelLink(channelId: ChannelId): `https://discord.com/channels/@me/${ChannelId}`; +/** + * Formats a channel link for a guild channel. + * + * @typeParam ChannelId - This is inferred by the supplied channel id + * @typeParam GuildId - This is inferred by the supplied guild id + * @param channelId - The channel's id + * @param guildId - The guild's id + */ +declare function channelLink(channelId: ChannelId, guildId: GuildId): `https://discord.com/channels/${GuildId}/${ChannelId}`; +/** + * Formats a message link for a direct message channel. + * + * @typeParam ChannelId - This is inferred by the supplied channel id + * @typeParam MessageId - This is inferred by the supplied message id + * @param channelId - The channel's id + * @param messageId - The message's id + */ +declare function messageLink(channelId: ChannelId, messageId: MessageId): `https://discord.com/channels/@me/${ChannelId}/${MessageId}`; +/** + * Formats a message link for a guild channel. + * + * @typeParam ChannelId - This is inferred by the supplied channel id + * @typeParam MessageId - This is inferred by the supplied message id + * @typeParam GuildId - This is inferred by the supplied guild id + * @param channelId - The channel's id + * @param messageId - The message's id + * @param guildId - The guild's id + */ +declare function messageLink(channelId: ChannelId, messageId: MessageId, guildId: GuildId): `https://discord.com/channels/${GuildId}/${ChannelId}/${MessageId}`; +/** + * The heading levels for expanded markdown. + */ +declare enum HeadingLevel { + /** + * The first heading level. + */ + One = 1, + /** + * The second heading level. + */ + Two = 2, + /** + * The third heading level. + */ + Three = 3 +} +/** + * Formats the content into a heading level. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + * @param level - The heading level + */ +declare function heading(content: Content, level?: HeadingLevel.One): `# ${Content}`; +/** + * Formats the content into a heading level. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + * @param level - The heading level + */ +declare function heading(content: Content, level: HeadingLevel.Two): `## ${Content}`; +/** + * Formats the content into a heading level. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + * @param level - The heading level + */ +declare function heading(content: Content, level: HeadingLevel.Three): `### ${Content}`; +/** + * A type that recursively traverses into arrays. + */ +type RecursiveArray = readonly (ItemType | RecursiveArray)[]; +/** + * Formats the elements in the array to an ordered list. + * + * @param list - The array of elements to list + * @param startNumber - The starting number for the list + */ +declare function orderedList(list: RecursiveArray, startNumber?: number): string; +/** + * Formats the elements in the array to an unordered list. + * + * @param list - The array of elements to list + */ +declare function unorderedList(list: RecursiveArray): string; +/** + * Formats the content into a subtext. + * + * @typeParam Content - This is inferred by the supplied content + * @param content - The content to wrap + */ +declare function subtext(content: Content): `-# ${Content}`; +/** + * Formats a date into a short date-time string. + * + * @param date - The date to format. Defaults to the current time + */ +declare function time(date?: Date): ``; +/** + * Formats a date given a format style. + * + * @typeParam Style - This is inferred by the supplied {@link TimestampStylesString} + * @param date - The date to format + * @param style - The style to use + */ +declare function time