From 79335ea096bf28b8ec12161bf4cd421e2c9a6f22 Mon Sep 17 00:00:00 2001 From: Laurens van der Drift Date: Mon, 27 May 2024 21:46:01 +0200 Subject: [PATCH] added code for bot --- Bot/config.json | 7 + Bot/index.js | 134 + Bot/index_with_comments.js | 158 + Bot/node_modules/.package-lock.json | 399 + .../Release/register-protocol-handler.node | Bin 0 -> 133632 bytes Bot/node_modules/@discordjs/builders/LICENSE | 191 + .../@discordjs/builders/README.md | 72 + .../@discordjs/builders/dist/index.d.mts | 1971 ++ .../@discordjs/builders/dist/index.d.ts | 1971 ++ .../@discordjs/builders/dist/index.js | 2811 +++ .../@discordjs/builders/dist/index.js.map | 1 + .../@discordjs/builders/dist/index.mjs | 2748 +++ .../@discordjs/builders/dist/index.mjs.map | 1 + .../@discordjs/builders/package.json | 99 + .../@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/formatters/LICENSE | 191 + .../@discordjs/formatters/README.md | 82 + .../@discordjs/formatters/dist/index.d.mts | 650 + .../@discordjs/formatters/dist/index.d.ts | 650 + .../@discordjs/formatters/dist/index.js | 457 + .../@discordjs/formatters/dist/index.js.map | 1 + .../@discordjs/formatters/dist/index.mjs | 392 + .../@discordjs/formatters/dist/index.mjs.map | 1 + .../@discordjs/formatters/package.json | 83 + Bot/node_modules/@discordjs/rest/LICENSE | 192 + Bot/node_modules/@discordjs/rest/README.md | 139 + .../@discordjs/rest/dist/index.d.mts | 904 + .../@discordjs/rest/dist/index.d.ts | 904 + .../@discordjs/rest/dist/index.js | 1486 ++ .../@discordjs/rest/dist/index.js.map | 1 + .../@discordjs/rest/dist/index.mjs | 1444 ++ .../@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 | 904 + .../@discordjs/rest/dist/web.d.ts | 904 + Bot/node_modules/@discordjs/rest/dist/web.js | 1418 ++ .../@discordjs/rest/dist/web.js.map | 1 + Bot/node_modules/@discordjs/rest/dist/web.mjs | 1374 ++ .../@discordjs/rest/dist/web.mjs.map | 1 + .../@discordjs/collection/LICENSE | 191 + .../@discordjs/collection/README.md | 67 + .../@discordjs/collection/dist/index.d.mts | 535 + .../@discordjs/collection/dist/index.d.ts | 535 + .../@discordjs/collection/dist/index.js | 654 + .../@discordjs/collection/dist/index.js.map | 1 + .../@discordjs/collection/dist/index.mjs | 628 + .../@discordjs/collection/dist/index.mjs.map | 1 + .../@discordjs/collection/package.json | 86 + Bot/node_modules/@discordjs/rest/package.json | 119 + Bot/node_modules/@discordjs/util/LICENSE | 190 + Bot/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 + Bot/node_modules/@discordjs/util/package.json | 91 + Bot/node_modules/@discordjs/ws/LICENSE | 191 + Bot/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 | 1058 + .../@discordjs/ws/dist/defaultWorker.js.map | 1 + .../@discordjs/ws/dist/defaultWorker.mjs | 1040 + .../@discordjs/ws/dist/defaultWorker.mjs.map | 1 + .../@discordjs/ws/dist/index.d.mts | 704 + .../@discordjs/ws/dist/index.d.ts | 704 + Bot/node_modules/@discordjs/ws/dist/index.js | 1505 ++ .../@discordjs/ws/dist/index.js.map | 1 + Bot/node_modules/@discordjs/ws/dist/index.mjs | 1469 ++ .../@discordjs/ws/dist/index.mjs.map | 1 + .../@discordjs/collection/LICENSE | 191 + .../@discordjs/collection/README.md | 67 + .../@discordjs/collection/dist/index.d.mts | 535 + .../@discordjs/collection/dist/index.d.ts | 535 + .../@discordjs/collection/dist/index.js | 654 + .../@discordjs/collection/dist/index.js.map | 1 + .../@discordjs/collection/dist/index.mjs | 628 + .../@discordjs/collection/dist/index.mjs.map | 1 + .../@discordjs/collection/package.json | 86 + Bot/node_modules/@discordjs/ws/package.json | 113 + .../@sapphire/async-queue/CHANGELOG.md | 190 + .../@sapphire/async-queue/README.md | 60 + .../@sapphire/async-queue/dist/cjs/index.cjs | 145 + .../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 | 143 + .../async-queue/dist/esm/index.mjs.map | 1 + .../async-queue/dist/iife/index.global.js | 150 + .../async-queue/dist/iife/index.global.js.map | 1 + .../@sapphire/async-queue/package.json | 72 + .../@sapphire/shapeshift/CHANGELOG.md | 326 + .../@sapphire/shapeshift/LICENSE.md | 24 + .../@sapphire/shapeshift/README.md | 934 + .../@sapphire/shapeshift/dist/cjs/index.cjs | 3013 +++ .../shapeshift/dist/cjs/index.cjs.map | 1 + .../@sapphire/shapeshift/dist/cjs/index.d.cts | 715 + .../@sapphire/shapeshift/dist/esm/index.d.mts | 715 + .../@sapphire/shapeshift/dist/esm/index.mjs | 2990 +++ .../shapeshift/dist/esm/index.mjs.map | 1 + .../shapeshift/dist/iife/index.global.js | 4220 ++++ .../shapeshift/dist/iife/index.global.js.map | 1 + .../@sapphire/shapeshift/package.json | 124 + .../@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 + Bot/node_modules/@types/node/LICENSE | 21 + Bot/node_modules/@types/node/README.md | 15 + Bot/node_modules/@types/node/assert.d.ts | 1040 + .../@types/node/assert/strict.d.ts | 8 + Bot/node_modules/@types/node/async_hooks.d.ts | 541 + Bot/node_modules/@types/node/buffer.d.ts | 2363 +++ .../@types/node/child_process.d.ts | 1542 ++ Bot/node_modules/@types/node/cluster.d.ts | 578 + Bot/node_modules/@types/node/console.d.ts | 452 + Bot/node_modules/@types/node/constants.d.ts | 19 + Bot/node_modules/@types/node/crypto.d.ts | 4522 ++++ Bot/node_modules/@types/node/dgram.d.ts | 596 + .../@types/node/diagnostics_channel.d.ts | 545 + Bot/node_modules/@types/node/dns.d.ts | 853 + .../@types/node/dns/promises.d.ts | 473 + Bot/node_modules/@types/node/dom-events.d.ts | 124 + Bot/node_modules/@types/node/domain.d.ts | 170 + Bot/node_modules/@types/node/events.d.ts | 884 + Bot/node_modules/@types/node/fs.d.ts | 4317 ++++ Bot/node_modules/@types/node/fs/promises.d.ts | 1245 ++ Bot/node_modules/@types/node/globals.d.ts | 411 + .../@types/node/globals.global.d.ts | 1 + Bot/node_modules/@types/node/http.d.ts | 1889 ++ Bot/node_modules/@types/node/http2.d.ts | 2418 +++ Bot/node_modules/@types/node/https.d.ts | 550 + Bot/node_modules/@types/node/index.d.ts | 89 + Bot/node_modules/@types/node/inspector.d.ts | 2746 +++ Bot/node_modules/@types/node/module.d.ts | 315 + Bot/node_modules/@types/node/net.d.ts | 996 + Bot/node_modules/@types/node/os.d.ts | 495 + Bot/node_modules/@types/node/package.json | 217 + Bot/node_modules/@types/node/path.d.ts | 191 + Bot/node_modules/@types/node/perf_hooks.d.ts | 645 + Bot/node_modules/@types/node/process.d.ts | 1747 ++ Bot/node_modules/@types/node/punycode.d.ts | 117 + Bot/node_modules/@types/node/querystring.d.ts | 153 + Bot/node_modules/@types/node/readline.d.ts | 540 + .../@types/node/readline/promises.d.ts | 150 + Bot/node_modules/@types/node/repl.d.ts | 430 + Bot/node_modules/@types/node/sea.d.ts | 153 + Bot/node_modules/@types/node/stream.d.ts | 1707 ++ .../@types/node/stream/consumers.d.ts | 12 + .../@types/node/stream/promises.d.ts | 83 + Bot/node_modules/@types/node/stream/web.d.ts | 367 + .../@types/node/string_decoder.d.ts | 67 + Bot/node_modules/@types/node/test.d.ts | 1470 ++ Bot/node_modules/@types/node/timers.d.ts | 240 + .../@types/node/timers/promises.d.ts | 97 + Bot/node_modules/@types/node/tls.d.ts | 1217 ++ .../@types/node/trace_events.d.ts | 197 + Bot/node_modules/@types/node/tty.d.ts | 208 + Bot/node_modules/@types/node/url.d.ts | 944 + Bot/node_modules/@types/node/util.d.ts | 2276 ++ Bot/node_modules/@types/node/v8.d.ts | 764 + Bot/node_modules/@types/node/vm.d.ts | 921 + Bot/node_modules/@types/node/wasi.d.ts | 181 + .../@types/node/worker_threads.d.ts | 691 + Bot/node_modules/@types/node/zlib.d.ts | 530 + Bot/node_modules/@types/ws/LICENSE | 21 + Bot/node_modules/@types/ws/README.md | 15 + Bot/node_modules/@types/ws/index.d.mts | 21 + Bot/node_modules/@types/ws/index.d.ts | 410 + Bot/node_modules/@types/ws/package.json | 71 + .../async_event_emitter/CHANGELOG.md | 69 + .../async_event_emitter/LICENSE.md | 24 + .../@vladfrangu/async_event_emitter/README.md | 51 + .../THIRD_PARTY_LICENSE.md | 23 + .../async_event_emitter/dist/index.cjs | 568 + .../async_event_emitter/dist/index.cjs.map | 1 + .../async_event_emitter/dist/index.d.mts | 58 + .../async_event_emitter/dist/index.d.ts | 58 + .../async_event_emitter/dist/index.global.js | 570 + .../dist/index.global.js.map | 1 + .../async_event_emitter/dist/index.mjs | 549 + .../async_event_emitter/dist/index.mjs.map | 1 + .../async_event_emitter/package.json | 111 + Bot/node_modules/asynckit/LICENSE | 21 + Bot/node_modules/asynckit/README.md | 233 + Bot/node_modules/asynckit/bench.js | 76 + Bot/node_modules/asynckit/index.js | 6 + Bot/node_modules/asynckit/lib/abort.js | 29 + Bot/node_modules/asynckit/lib/async.js | 34 + Bot/node_modules/asynckit/lib/defer.js | 26 + Bot/node_modules/asynckit/lib/iterate.js | 75 + .../asynckit/lib/readable_asynckit.js | 91 + .../asynckit/lib/readable_parallel.js | 25 + .../asynckit/lib/readable_serial.js | 25 + .../asynckit/lib/readable_serial_ordered.js | 29 + Bot/node_modules/asynckit/lib/state.js | 37 + Bot/node_modules/asynckit/lib/streamify.js | 141 + Bot/node_modules/asynckit/lib/terminator.js | 29 + Bot/node_modules/asynckit/package.json | 63 + Bot/node_modules/asynckit/parallel.js | 43 + Bot/node_modules/asynckit/serial.js | 17 + Bot/node_modules/asynckit/serialOrdered.js | 75 + Bot/node_modules/asynckit/stream.js | 21 + Bot/node_modules/axios/CHANGELOG.md | 941 + Bot/node_modules/axios/LICENSE | 7 + Bot/node_modules/axios/MIGRATION_GUIDE.md | 3 + Bot/node_modules/axios/README.md | 1695 ++ Bot/node_modules/axios/SECURITY.md | 6 + Bot/node_modules/axios/dist/axios.js | 4172 ++++ Bot/node_modules/axios/dist/axios.js.map | 1 + Bot/node_modules/axios/dist/axios.min.js | 2 + Bot/node_modules/axios/dist/axios.min.js.map | 1 + Bot/node_modules/axios/dist/browser/axios.cjs | 3638 ++++ .../axios/dist/browser/axios.cjs.map | 1 + Bot/node_modules/axios/dist/esm/axios.js | 3661 ++++ Bot/node_modules/axios/dist/esm/axios.js.map | 1 + Bot/node_modules/axios/dist/esm/axios.min.js | 2 + .../axios/dist/esm/axios.min.js.map | 1 + Bot/node_modules/axios/dist/node/axios.cjs | 4705 +++++ .../axios/dist/node/axios.cjs.map | 1 + Bot/node_modules/axios/index.d.cts | 545 + Bot/node_modules/axios/index.d.ts | 562 + Bot/node_modules/axios/index.js | 43 + Bot/node_modules/axios/lib/adapters/README.md | 37 + .../axios/lib/adapters/adapters.js | 79 + Bot/node_modules/axios/lib/adapters/fetch.js | 227 + Bot/node_modules/axios/lib/adapters/http.js | 685 + Bot/node_modules/axios/lib/adapters/xhr.js | 190 + Bot/node_modules/axios/lib/axios.js | 89 + .../axios/lib/cancel/CancelToken.js | 121 + .../axios/lib/cancel/CanceledError.js | 25 + Bot/node_modules/axios/lib/cancel/isCancel.js | 5 + Bot/node_modules/axios/lib/core/Axios.js | 228 + Bot/node_modules/axios/lib/core/AxiosError.js | 100 + .../axios/lib/core/AxiosHeaders.js | 302 + .../axios/lib/core/InterceptorManager.js | 71 + Bot/node_modules/axios/lib/core/README.md | 8 + .../axios/lib/core/buildFullPath.js | 21 + .../axios/lib/core/dispatchRequest.js | 81 + .../axios/lib/core/mergeConfig.js | 106 + Bot/node_modules/axios/lib/core/settle.js | 27 + .../axios/lib/core/transformData.js | 28 + Bot/node_modules/axios/lib/defaults/index.js | 161 + .../axios/lib/defaults/transitional.js | 7 + Bot/node_modules/axios/lib/env/README.md | 3 + .../axios/lib/env/classes/FormData.js | 2 + Bot/node_modules/axios/lib/env/data.js | 1 + .../axios/lib/helpers/AxiosTransformStream.js | 192 + .../axios/lib/helpers/AxiosURLSearchParams.js | 58 + .../axios/lib/helpers/HttpStatusCode.js | 71 + Bot/node_modules/axios/lib/helpers/README.md | 7 + .../lib/helpers/ZlibHeaderTransformStream.js | 28 + Bot/node_modules/axios/lib/helpers/bind.js | 7 + .../axios/lib/helpers/buildURL.js | 63 + .../axios/lib/helpers/callbackify.js | 16 + .../axios/lib/helpers/combineURLs.js | 15 + .../axios/lib/helpers/composeSignals.js | 46 + Bot/node_modules/axios/lib/helpers/cookies.js | 42 + .../axios/lib/helpers/deprecatedMethod.js | 26 + .../axios/lib/helpers/formDataToJSON.js | 95 + .../axios/lib/helpers/formDataToStream.js | 111 + .../axios/lib/helpers/fromDataURI.js | 53 + .../axios/lib/helpers/isAbsoluteURL.js | 15 + .../axios/lib/helpers/isAxiosError.js | 14 + .../axios/lib/helpers/isURLSameOrigin.js | 67 + Bot/node_modules/axios/lib/helpers/null.js | 2 + .../axios/lib/helpers/parseHeaders.js | 55 + .../axios/lib/helpers/parseProtocol.js | 6 + .../axios/lib/helpers/progressEventReducer.js | 32 + .../axios/lib/helpers/readBlob.js | 15 + .../axios/lib/helpers/resolveConfig.js | 57 + .../axios/lib/helpers/speedometer.js | 55 + Bot/node_modules/axios/lib/helpers/spread.js | 28 + .../axios/lib/helpers/throttle.js | 35 + .../axios/lib/helpers/toFormData.js | 219 + .../axios/lib/helpers/toURLEncodedForm.js | 18 + .../axios/lib/helpers/trackStream.js | 55 + .../axios/lib/helpers/validator.js | 91 + .../lib/platform/browser/classes/Blob.js | 3 + .../lib/platform/browser/classes/FormData.js | 3 + .../browser/classes/URLSearchParams.js | 4 + .../axios/lib/platform/browser/index.js | 13 + .../axios/lib/platform/common/utils.js | 50 + Bot/node_modules/axios/lib/platform/index.js | 7 + .../lib/platform/node/classes/FormData.js | 3 + .../platform/node/classes/URLSearchParams.js | 4 + .../axios/lib/platform/node/index.js | 12 + Bot/node_modules/axios/lib/utils.js | 728 + Bot/node_modules/axios/package.json | 219 + Bot/node_modules/combined-stream/License | 19 + Bot/node_modules/combined-stream/Readme.md | 138 + .../combined-stream/lib/combined_stream.js | 208 + Bot/node_modules/combined-stream/package.json | 25 + Bot/node_modules/combined-stream/yarn.lock | 17 + Bot/node_modules/delayed-stream/.npmignore | 1 + Bot/node_modules/delayed-stream/License | 19 + Bot/node_modules/delayed-stream/Makefile | 7 + Bot/node_modules/delayed-stream/Readme.md | 141 + .../delayed-stream/lib/delayed_stream.js | 107 + Bot/node_modules/delayed-stream/package.json | 27 + Bot/node_modules/discord-api-types/LICENSE | 21 + Bot/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 | 8 + .../discord-api-types/gateway/v10.d.ts | 1730 ++ .../discord-api-types/gateway/v10.d.ts.map | 1 + .../discord-api-types/gateway/v10.js | 261 + .../discord-api-types/gateway/v10.js.map | 1 + .../discord-api-types/gateway/v10.mjs | 8 + .../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 | 1730 ++ .../discord-api-types/gateway/v9.d.ts.map | 1 + .../discord-api-types/gateway/v9.js | 260 + .../discord-api-types/gateway/v9.js.map | 1 + .../discord-api-types/gateway/v9.mjs | 8 + .../discord-api-types/globals.d.ts | 92 + .../discord-api-types/globals.d.ts.map | 1 + Bot/node_modules/discord-api-types/globals.js | 94 + .../discord-api-types/globals.js.map | 1 + .../discord-api-types/globals.mjs | 4 + .../discord-api-types/package.json | 204 + .../discord-api-types/payloads/common.d.ts | 326 + .../payloads/common.d.ts.map | 1 + .../discord-api-types/payloads/common.js | 293 + .../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 | 76 + .../_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 | 18 + .../_chatInput/string.d.ts.map | 1 + .../_applicationCommands/_chatInput/string.js | 3 + .../_chatInput/string.js.map | 1 + .../_chatInput/subcommand.d.ts | 12 + .../_chatInput/subcommand.d.ts.map | 1 + .../_chatInput/subcommand.js | 3 + .../_chatInput/subcommand.js.map | 1 + .../_chatInput/subcommandGroup.d.ts | 12 + .../_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 | 61 + .../_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/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 | 111 + .../applicationCommands.d.ts.map | 1 + .../v10/_interactions/applicationCommands.js | 30 + .../_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 | 152 + .../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 | 111 + .../v10/_interactions/responses.d.ts.map | 1 + .../payloads/v10/_interactions/responses.js | 53 + .../v10/_interactions/responses.js.map | 1 + .../payloads/v10/application.d.ts | 276 + .../payloads/v10/application.d.ts.map | 1 + .../payloads/v10/application.js | 118 + .../payloads/v10/application.js.map | 1 + .../payloads/v10/auditLog.d.ts | 643 + .../payloads/v10/auditLog.d.ts.map | 1 + .../payloads/v10/auditLog.js | 79 + .../payloads/v10/auditLog.js.map | 1 + .../payloads/v10/autoModeration.d.ts | 208 + .../payloads/v10/autoModeration.d.ts.map | 1 + .../payloads/v10/autoModeration.js | 76 + .../payloads/v10/autoModeration.js.map | 1 + .../payloads/v10/channel.d.ts | 1739 ++ .../payloads/v10/channel.d.ts.map | 1 + .../discord-api-types/payloads/v10/channel.js | 464 + .../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 | 374 + .../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 | 1086 + .../payloads/v10/guild.d.ts.map | 1 + .../discord-api-types/payloads/v10/guild.js | 363 + .../payloads/v10/guild.js.map | 1 + .../payloads/v10/guildScheduledEvent.d.ts | 139 + .../payloads/v10/guildScheduledEvent.d.ts.map | 1 + .../payloads/v10/guildScheduledEvent.js | 33 + .../payloads/v10/guildScheduledEvent.js.map | 1 + .../discord-api-types/payloads/v10/index.d.ts | 23 + .../payloads/v10/index.d.ts.map | 1 + .../discord-api-types/payloads/v10/index.js | 39 + .../payloads/v10/index.js.map | 1 + .../discord-api-types/payloads/v10/index.mjs | 76 + .../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 | 122 + .../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 | 151 + .../payloads/v10/monetization.d.ts.map | 1 + .../payloads/v10/monetization.js | 80 + .../payloads/v10/monetization.js.map | 1 + .../payloads/v10/oauth2.d.ts | 132 + .../payloads/v10/oauth2.d.ts.map | 1 + .../discord-api-types/payloads/v10/oauth2.js | 136 + .../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 | 101 + .../payloads/v10/poll.d.ts.map | 1 + .../discord-api-types/payloads/v10/poll.js | 17 + .../payloads/v10/poll.js.map | 1 + .../payloads/v10/stageInstance.d.ts | 78 + .../payloads/v10/stageInstance.d.ts.map | 1 + .../payloads/v10/stageInstance.js | 20 + .../payloads/v10/stageInstance.js.map | 1 + .../payloads/v10/sticker.d.ts | 124 + .../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 | 63 + .../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 | 315 + .../payloads/v10/user.d.ts.map | 1 + .../discord-api-types/payloads/v10/user.js | 167 + .../payloads/v10/user.js.map | 1 + .../discord-api-types/payloads/v10/voice.d.ts | 90 + .../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 | 77 + .../payloads/v10/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v10/webhook.js | 22 + .../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 | 343 + .../payloads/v6/channel.d.ts.map | 1 + .../discord-api-types/payloads/v6/channel.js | 95 + .../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 | 1273 ++ .../payloads/v8/channel.d.ts.map | 1 + .../discord-api-types/payloads/v8/channel.js | 254 + .../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 | 18 + .../_chatInput/string.d.ts.map | 1 + .../_applicationCommands/_chatInput/string.js | 3 + .../_chatInput/string.js.map | 1 + .../_chatInput/subcommand.d.ts | 12 + .../_chatInput/subcommand.d.ts.map | 1 + .../_chatInput/subcommand.js | 3 + .../_chatInput/subcommand.js.map | 1 + .../_chatInput/subcommandGroup.d.ts | 12 + .../_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 | 61 + .../_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/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 | 111 + .../applicationCommands.d.ts.map | 1 + .../v9/_interactions/applicationCommands.js | 30 + .../_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 | 152 + .../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 | 111 + .../v9/_interactions/responses.d.ts.map | 1 + .../payloads/v9/_interactions/responses.js | 53 + .../v9/_interactions/responses.js.map | 1 + .../payloads/v9/application.d.ts | 276 + .../payloads/v9/application.d.ts.map | 1 + .../payloads/v9/application.js | 118 + .../payloads/v9/application.js.map | 1 + .../payloads/v9/auditLog.d.ts | 643 + .../payloads/v9/auditLog.d.ts.map | 1 + .../discord-api-types/payloads/v9/auditLog.js | 79 + .../payloads/v9/auditLog.js.map | 1 + .../payloads/v9/autoModeration.d.ts | 208 + .../payloads/v9/autoModeration.d.ts.map | 1 + .../payloads/v9/autoModeration.js | 76 + .../payloads/v9/autoModeration.js.map | 1 + .../payloads/v9/channel.d.ts | 1710 ++ .../payloads/v9/channel.d.ts.map | 1 + .../discord-api-types/payloads/v9/channel.js | 464 + .../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 | 362 + .../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 | 1078 + .../payloads/v9/guild.d.ts.map | 1 + .../discord-api-types/payloads/v9/guild.js | 355 + .../payloads/v9/guild.js.map | 1 + .../payloads/v9/guildScheduledEvent.d.ts | 139 + .../payloads/v9/guildScheduledEvent.d.ts.map | 1 + .../payloads/v9/guildScheduledEvent.js | 33 + .../payloads/v9/guildScheduledEvent.js.map | 1 + .../discord-api-types/payloads/v9/index.d.ts | 23 + .../payloads/v9/index.d.ts.map | 1 + .../discord-api-types/payloads/v9/index.js | 39 + .../payloads/v9/index.js.map | 1 + .../discord-api-types/payloads/v9/index.mjs | 76 + .../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 | 122 + .../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 | 151 + .../payloads/v9/monetization.d.ts.map | 1 + .../payloads/v9/monetization.js | 80 + .../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 | 101 + .../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/stageInstance.d.ts | 80 + .../payloads/v9/stageInstance.d.ts.map | 1 + .../payloads/v9/stageInstance.js | 20 + .../payloads/v9/stageInstance.js.map | 1 + .../payloads/v9/sticker.d.ts | 124 + .../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 | 63 + .../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 | 315 + .../payloads/v9/user.d.ts.map | 1 + .../discord-api-types/payloads/v9/user.js | 167 + .../discord-api-types/payloads/v9/user.js.map | 1 + .../discord-api-types/payloads/v9/voice.d.ts | 90 + .../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 | 77 + .../payloads/v9/webhook.d.ts.map | 1 + .../discord-api-types/payloads/v9/webhook.js | 22 + .../payloads/v9/webhook.js.map | 1 + .../discord-api-types/rest/common.d.ts | 255 + .../discord-api-types/rest/common.d.ts.map | 1 + .../discord-api-types/rest/common.js | 259 + .../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 | 13 + .../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 | 702 + .../rest/v10/channel.d.ts.map | 1 + .../discord-api-types/rest/v10/channel.js | 3 + .../discord-api-types/rest/v10/channel.js.map | 1 + .../discord-api-types/rest/v10/emoji.d.ts | 55 + .../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 | 862 + .../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 | 127 + .../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 | 862 + .../discord-api-types/rest/v10/index.d.ts.map | 1 + .../discord-api-types/rest/v10/index.js | 1112 + .../discord-api-types/rest/v10/index.js.map | 1 + .../discord-api-types/rest/v10/index.mjs | 13 + .../rest/v10/interactions.d.ts | 195 + .../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 | 83 + .../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 | 173 + .../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 | 44 + .../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/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 | 78 + .../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 | 121 + .../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 | 10 + .../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 | 251 + .../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 | 480 + .../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 | 728 + .../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 | 719 + .../rest/v9/channel.d.ts.map | 1 + .../discord-api-types/rest/v9/channel.js | 3 + .../discord-api-types/rest/v9/channel.js.map | 1 + .../discord-api-types/rest/v9/emoji.d.ts | 55 + .../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 | 868 + .../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 | 127 + .../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 | 864 + .../discord-api-types/rest/v9/index.d.ts.map | 1 + .../discord-api-types/rest/v9/index.js | 1119 + .../discord-api-types/rest/v9/index.js.map | 1 + .../discord-api-types/rest/v9/index.mjs | 13 + .../rest/v9/interactions.d.ts | 195 + .../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 | 83 + .../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 | 173 + .../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 | 44 + .../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 + .../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 | 78 + .../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 | 121 + .../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 | 10 + .../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 | 251 + .../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 | 33 + .../discord-api-types/rpc/common.d.ts.map | 1 + .../discord-api-types/rpc/common.js | 38 + .../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 | 5 + .../discord-api-types/rpc/v10.d.ts | 2 + .../discord-api-types/rpc/v10.d.ts.map | 1 + Bot/node_modules/discord-api-types/rpc/v10.js | 18 + .../discord-api-types/rpc/v10.js.map | 1 + .../discord-api-types/rpc/v10.mjs | 5 + .../discord-api-types/rpc/v8.d.ts | 2 + .../discord-api-types/rpc/v8.d.ts.map | 1 + Bot/node_modules/discord-api-types/rpc/v8.js | 18 + .../discord-api-types/rpc/v8.js.map | 1 + Bot/node_modules/discord-api-types/rpc/v8.mjs | 5 + .../discord-api-types/rpc/v9.d.ts | 2 + .../discord-api-types/rpc/v9.d.ts.map | 1 + Bot/node_modules/discord-api-types/rpc/v9.js | 18 + .../discord-api-types/rpc/v9.js.map | 1 + Bot/node_modules/discord-api-types/rpc/v9.mjs | 5 + .../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 | 29 + .../utils/internals.d.ts.map | 1 + .../discord-api-types/utils/internals.js | 3 + .../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 | 148 + .../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 | 97 + .../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 | 148 + .../discord-api-types/utils/v9.js.map | 1 + .../discord-api-types/utils/v9.mjs | 16 + Bot/node_modules/discord-api-types/v10.d.ts | 7 + .../discord-api-types/v10.d.ts.map | 1 + Bot/node_modules/discord-api-types/v10.js | 24 + Bot/node_modules/discord-api-types/v10.js.map | 1 + Bot/node_modules/discord-api-types/v10.mjs | 95 + Bot/node_modules/discord-api-types/v6.d.ts | 5 + .../discord-api-types/v6.d.ts.map | 1 + Bot/node_modules/discord-api-types/v6.js | 21 + Bot/node_modules/discord-api-types/v6.js.map | 1 + Bot/node_modules/discord-api-types/v6.mjs | 43 + Bot/node_modules/discord-api-types/v8.d.ts | 7 + .../discord-api-types/v8.d.ts.map | 1 + Bot/node_modules/discord-api-types/v8.js | 24 + Bot/node_modules/discord-api-types/v8.js.map | 1 + Bot/node_modules/discord-api-types/v8.mjs | 66 + Bot/node_modules/discord-api-types/v9.d.ts | 7 + .../discord-api-types/v9.d.ts.map | 1 + Bot/node_modules/discord-api-types/v9.js | 24 + Bot/node_modules/discord-api-types/v9.js.map | 1 + Bot/node_modules/discord-api-types/v9.mjs | 95 + .../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 | 108 + .../discord-api-types/voice/v4.d.ts.map | 1 + .../discord-api-types/voice/v4.js | 113 + .../discord-api-types/voice/v4.js.map | 1 + .../discord-api-types/voice/v4.mjs | 6 + Bot/node_modules/discord.js/LICENSE | 191 + Bot/node_modules/discord.js/README.md | 144 + Bot/node_modules/discord.js/package.json | 105 + .../discord.js/src/client/BaseClient.js | 120 + .../discord.js/src/client/Client.js | 611 + .../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 | 37 + .../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 | 55 + .../client/actions/MessageReactionRemove.js | 45 + .../actions/MessageReactionRemoveAll.js | 33 + .../actions/MessageReactionRemoveEmoji.js | 28 + .../src/client/actions/MessageUpdate.js | 26 + .../src/client/actions/PresenceUpdate.js | 42 + .../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 | 394 + .../src/client/websocket/WebSocketShard.js | 231 + .../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/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 + .../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 | 69 + .../discord.js/src/errors/DJSError.js | 48 + .../discord.js/src/errors/ErrorCodes.js | 347 + .../discord.js/src/errors/Messages.js | 178 + .../discord.js/src/errors/index.js | 5 + Bot/node_modules/discord.js/src/index.js | 231 + .../src/managers/ApplicationCommandManager.js | 266 + .../ApplicationCommandPermissionsManager.js | 428 + .../src/managers/AutoModerationRuleManager.js | 288 + .../src/managers/BaseGuildEmojiManager.js | 80 + .../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 | 139 + .../GuildApplicationCommandManager.js | 28 + .../src/managers/GuildBanManager.js | 249 + .../src/managers/GuildChannelManager.js | 507 + .../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 | 299 + .../src/managers/GuildMemberManager.js | 559 + .../src/managers/GuildMemberRoleManager.js | 204 + .../src/managers/GuildMessageManager.js | 17 + .../managers/GuildScheduledEventManager.js | 297 + .../src/managers/GuildStickerManager.js | 182 + .../src/managers/GuildTextThreadManager.js | 91 + .../discord.js/src/managers/MessageManager.js | 301 + .../managers/PermissionOverwriteManager.js | 168 + .../src/managers/PresenceManager.js | 58 + .../src/managers/ReactionManager.js | 68 + .../src/managers/ReactionUserManager.js | 77 + .../discord.js/src/managers/RoleManager.js | 360 + .../src/managers/StageInstanceManager.js | 159 + .../discord.js/src/managers/ThreadManager.js | 207 + .../src/managers/ThreadMemberManager.js | 184 + .../discord.js/src/managers/UserManager.js | 142 + .../src/managers/VoiceStateManager.js | 37 + .../discord.js/src/sharding/Shard.js | 475 + .../src/sharding/ShardClientUtil.js | 291 + .../src/sharding/ShardingManager.js | 333 + .../discord.js/src/structures/ActionRow.js | 46 + .../src/structures/ActionRowBuilder.js | 35 + .../src/structures/AnonymousGuild.js | 97 + .../src/structures/ApplicationCommand.js | 596 + .../ApplicationRoleConnectionMetadata.js | 46 + .../discord.js/src/structures/Attachment.js | 152 + .../src/structures/AttachmentBuilder.js | 111 + .../AutoModerationActionExecution.js | 116 + .../src/structures/AutoModerationRule.js | 284 + .../src/structures/AutocompleteInteraction.js | 102 + .../discord.js/src/structures/Base.js | 43 + .../discord.js/src/structures/BaseChannel.js | 163 + .../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 | 318 + .../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 | 310 + .../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 | 183 + .../discord.js/src/structures/ForumChannel.js | 31 + .../discord.js/src/structures/Guild.js | 1455 ++ .../src/structures/GuildAuditLogs.js | 91 + .../src/structures/GuildAuditLogsEntry.js | 486 + .../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 | 515 + .../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 | 484 + .../src/structures/GuildTemplate.js | 241 + .../discord.js/src/structures/Integration.js | 220 + .../src/structures/IntegrationApplication.js | 85 + .../src/structures/InteractionCollector.js | 269 + .../src/structures/InteractionResponse.js | 102 + .../src/structures/InteractionWebhook.js | 59 + .../discord.js/src/structures/Invite.js | 322 + .../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 | 1022 + .../src/structures/MessageCollector.js | 146 + .../structures/MessageComponentInteraction.js | 108 + .../MessageContextMenuCommandInteraction.js | 20 + .../src/structures/MessageMentions.js | 297 + .../src/structures/MessagePayload.js | 321 + .../src/structures/MessageReaction.js | 142 + .../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 | 60 + .../src/structures/PermissionOverwrites.js | 196 + .../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 | 267 + .../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/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 | 615 + .../discord.js/src/structures/ThreadMember.js | 113 + .../src/structures/ThreadOnlyChannel.js | 249 + .../discord.js/src/structures/Typing.js | 74 + .../discord.js/src/structures/User.js | 375 + .../UserContextMenuCommandInteraction.js | 29 + .../src/structures/UserSelectMenuBuilder.js | 31 + .../src/structures/UserSelectMenuComponent.js | 11 + .../structures/UserSelectMenuInteraction.js | 51 + .../discord.js/src/structures/VoiceChannel.js | 96 + .../discord.js/src/structures/VoiceRegion.js | 46 + .../discord.js/src/structures/VoiceState.js | 303 + .../discord.js/src/structures/Webhook.js | 481 + .../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 | 108 + .../src/structures/interfaces/Collector.js | 335 + .../interfaces/InteractionResponses.js | 340 + .../structures/interfaces/TextBasedChannel.js | 429 + .../discord.js/src/util/APITypes.js | 536 + .../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 | 152 + .../discord.js/src/util/Constants.js | 252 + .../discord.js/src/util/DataResolver.js | 141 + Bot/node_modules/discord.js/src/util/Enums.js | 13 + .../discord.js/src/util/Events.js | 172 + .../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 | 32 + .../discord.js/src/util/Options.js | 237 + .../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 | 36 + .../discord.js/src/util/UserFlagsBitField.js | 32 + Bot/node_modules/discord.js/src/util/Util.js | 526 + .../src/util/WebSocketShardEvents.js | 25 + .../discord.js/typings/index.d.mts | 6930 +++++++ .../discord.js/typings/index.d.ts | 6930 +++++++ .../discord.js/typings/index.test-d.ts | 2557 +++ .../discord.js/typings/rawDataTypes.d.mts | 210 + .../discord.js/typings/rawDataTypes.d.ts | 210 + .../discord.js/typings/tsdoc-metadata.json | 11 + Bot/node_modules/fast-deep-equal/LICENSE | 21 + Bot/node_modules/fast-deep-equal/README.md | 96 + .../fast-deep-equal/es6/index.d.ts | 2 + Bot/node_modules/fast-deep-equal/es6/index.js | 72 + .../fast-deep-equal/es6/react.d.ts | 2 + Bot/node_modules/fast-deep-equal/es6/react.js | 79 + Bot/node_modules/fast-deep-equal/index.d.ts | 4 + Bot/node_modules/fast-deep-equal/index.js | 46 + Bot/node_modules/fast-deep-equal/package.json | 61 + Bot/node_modules/fast-deep-equal/react.d.ts | 2 + Bot/node_modules/fast-deep-equal/react.js | 53 + Bot/node_modules/follow-redirects/LICENSE | 18 + Bot/node_modules/follow-redirects/README.md | 155 + Bot/node_modules/follow-redirects/debug.js | 15 + Bot/node_modules/follow-redirects/http.js | 1 + Bot/node_modules/follow-redirects/https.js | 1 + Bot/node_modules/follow-redirects/index.js | 672 + .../follow-redirects/package.json | 58 + Bot/node_modules/form-data/License | 19 + Bot/node_modules/form-data/README.md.bak | 358 + Bot/node_modules/form-data/Readme.md | 358 + Bot/node_modules/form-data/index.d.ts | 62 + Bot/node_modules/form-data/lib/browser.js | 2 + Bot/node_modules/form-data/lib/form_data.js | 501 + Bot/node_modules/form-data/lib/populate.js | 10 + Bot/node_modules/form-data/package.json | 68 + Bot/node_modules/lodash.snakecase/LICENSE | 47 + Bot/node_modules/lodash.snakecase/README.md | 18 + Bot/node_modules/lodash.snakecase/index.js | 435 + .../lodash.snakecase/package.json | 17 + Bot/node_modules/lodash/LICENSE | 47 + Bot/node_modules/lodash/README.md | 39 + Bot/node_modules/lodash/_DataView.js | 7 + Bot/node_modules/lodash/_Hash.js | 32 + Bot/node_modules/lodash/_LazyWrapper.js | 28 + Bot/node_modules/lodash/_ListCache.js | 32 + Bot/node_modules/lodash/_LodashWrapper.js | 22 + Bot/node_modules/lodash/_Map.js | 7 + Bot/node_modules/lodash/_MapCache.js | 32 + Bot/node_modules/lodash/_Promise.js | 7 + Bot/node_modules/lodash/_Set.js | 7 + Bot/node_modules/lodash/_SetCache.js | 27 + Bot/node_modules/lodash/_Stack.js | 27 + Bot/node_modules/lodash/_Symbol.js | 6 + Bot/node_modules/lodash/_Uint8Array.js | 6 + Bot/node_modules/lodash/_WeakMap.js | 7 + Bot/node_modules/lodash/_apply.js | 21 + Bot/node_modules/lodash/_arrayAggregator.js | 22 + Bot/node_modules/lodash/_arrayEach.js | 22 + Bot/node_modules/lodash/_arrayEachRight.js | 21 + Bot/node_modules/lodash/_arrayEvery.js | 23 + Bot/node_modules/lodash/_arrayFilter.js | 25 + Bot/node_modules/lodash/_arrayIncludes.js | 17 + Bot/node_modules/lodash/_arrayIncludesWith.js | 22 + Bot/node_modules/lodash/_arrayLikeKeys.js | 49 + Bot/node_modules/lodash/_arrayMap.js | 21 + Bot/node_modules/lodash/_arrayPush.js | 20 + Bot/node_modules/lodash/_arrayReduce.js | 26 + Bot/node_modules/lodash/_arrayReduceRight.js | 24 + Bot/node_modules/lodash/_arraySample.js | 15 + Bot/node_modules/lodash/_arraySampleSize.js | 17 + Bot/node_modules/lodash/_arrayShuffle.js | 15 + Bot/node_modules/lodash/_arraySome.js | 23 + Bot/node_modules/lodash/_asciiSize.js | 12 + Bot/node_modules/lodash/_asciiToArray.js | 12 + Bot/node_modules/lodash/_asciiWords.js | 15 + Bot/node_modules/lodash/_assignMergeValue.js | 20 + Bot/node_modules/lodash/_assignValue.js | 28 + Bot/node_modules/lodash/_assocIndexOf.js | 21 + Bot/node_modules/lodash/_baseAggregator.js | 21 + Bot/node_modules/lodash/_baseAssign.js | 17 + Bot/node_modules/lodash/_baseAssignIn.js | 17 + Bot/node_modules/lodash/_baseAssignValue.js | 25 + Bot/node_modules/lodash/_baseAt.js | 23 + Bot/node_modules/lodash/_baseClamp.js | 22 + Bot/node_modules/lodash/_baseClone.js | 166 + Bot/node_modules/lodash/_baseConforms.js | 18 + Bot/node_modules/lodash/_baseConformsTo.js | 27 + Bot/node_modules/lodash/_baseCreate.js | 30 + Bot/node_modules/lodash/_baseDelay.js | 21 + Bot/node_modules/lodash/_baseDifference.js | 67 + Bot/node_modules/lodash/_baseEach.js | 14 + Bot/node_modules/lodash/_baseEachRight.js | 14 + Bot/node_modules/lodash/_baseEvery.js | 21 + Bot/node_modules/lodash/_baseExtremum.js | 32 + Bot/node_modules/lodash/_baseFill.js | 32 + Bot/node_modules/lodash/_baseFilter.js | 21 + Bot/node_modules/lodash/_baseFindIndex.js | 24 + Bot/node_modules/lodash/_baseFindKey.js | 23 + Bot/node_modules/lodash/_baseFlatten.js | 38 + Bot/node_modules/lodash/_baseFor.js | 16 + Bot/node_modules/lodash/_baseForOwn.js | 16 + Bot/node_modules/lodash/_baseForOwnRight.js | 16 + Bot/node_modules/lodash/_baseForRight.js | 15 + Bot/node_modules/lodash/_baseFunctions.js | 19 + Bot/node_modules/lodash/_baseGet.js | 24 + Bot/node_modules/lodash/_baseGetAllKeys.js | 20 + Bot/node_modules/lodash/_baseGetTag.js | 28 + Bot/node_modules/lodash/_baseGt.js | 14 + Bot/node_modules/lodash/_baseHas.js | 19 + Bot/node_modules/lodash/_baseHasIn.js | 13 + Bot/node_modules/lodash/_baseInRange.js | 18 + Bot/node_modules/lodash/_baseIndexOf.js | 20 + Bot/node_modules/lodash/_baseIndexOfWith.js | 23 + Bot/node_modules/lodash/_baseIntersection.js | 74 + Bot/node_modules/lodash/_baseInverter.js | 21 + Bot/node_modules/lodash/_baseInvoke.js | 24 + Bot/node_modules/lodash/_baseIsArguments.js | 18 + Bot/node_modules/lodash/_baseIsArrayBuffer.js | 17 + Bot/node_modules/lodash/_baseIsDate.js | 18 + Bot/node_modules/lodash/_baseIsEqual.js | 28 + Bot/node_modules/lodash/_baseIsEqualDeep.js | 83 + Bot/node_modules/lodash/_baseIsMap.js | 18 + Bot/node_modules/lodash/_baseIsMatch.js | 62 + Bot/node_modules/lodash/_baseIsNaN.js | 12 + Bot/node_modules/lodash/_baseIsNative.js | 47 + Bot/node_modules/lodash/_baseIsRegExp.js | 18 + Bot/node_modules/lodash/_baseIsSet.js | 18 + Bot/node_modules/lodash/_baseIsTypedArray.js | 60 + Bot/node_modules/lodash/_baseIteratee.js | 31 + Bot/node_modules/lodash/_baseKeys.js | 30 + Bot/node_modules/lodash/_baseKeysIn.js | 33 + Bot/node_modules/lodash/_baseLodash.js | 10 + Bot/node_modules/lodash/_baseLt.js | 14 + Bot/node_modules/lodash/_baseMap.js | 22 + Bot/node_modules/lodash/_baseMatches.js | 22 + .../lodash/_baseMatchesProperty.js | 33 + Bot/node_modules/lodash/_baseMean.js | 20 + Bot/node_modules/lodash/_baseMerge.js | 42 + Bot/node_modules/lodash/_baseMergeDeep.js | 94 + Bot/node_modules/lodash/_baseNth.js | 20 + Bot/node_modules/lodash/_baseOrderBy.js | 49 + Bot/node_modules/lodash/_basePick.js | 19 + Bot/node_modules/lodash/_basePickBy.js | 30 + Bot/node_modules/lodash/_baseProperty.js | 14 + Bot/node_modules/lodash/_basePropertyDeep.js | 16 + Bot/node_modules/lodash/_basePropertyOf.js | 14 + Bot/node_modules/lodash/_basePullAll.js | 51 + Bot/node_modules/lodash/_basePullAt.js | 37 + Bot/node_modules/lodash/_baseRandom.js | 18 + Bot/node_modules/lodash/_baseRange.js | 28 + Bot/node_modules/lodash/_baseReduce.js | 23 + Bot/node_modules/lodash/_baseRepeat.js | 35 + Bot/node_modules/lodash/_baseRest.js | 17 + Bot/node_modules/lodash/_baseSample.js | 15 + Bot/node_modules/lodash/_baseSampleSize.js | 18 + Bot/node_modules/lodash/_baseSet.js | 51 + Bot/node_modules/lodash/_baseSetData.js | 17 + Bot/node_modules/lodash/_baseSetToString.js | 22 + Bot/node_modules/lodash/_baseShuffle.js | 15 + Bot/node_modules/lodash/_baseSlice.js | 31 + Bot/node_modules/lodash/_baseSome.js | 22 + Bot/node_modules/lodash/_baseSortBy.js | 21 + Bot/node_modules/lodash/_baseSortedIndex.js | 42 + Bot/node_modules/lodash/_baseSortedIndexBy.js | 67 + Bot/node_modules/lodash/_baseSortedUniq.js | 30 + Bot/node_modules/lodash/_baseSum.js | 24 + Bot/node_modules/lodash/_baseTimes.js | 20 + Bot/node_modules/lodash/_baseToNumber.js | 24 + Bot/node_modules/lodash/_baseToPairs.js | 18 + Bot/node_modules/lodash/_baseToString.js | 37 + Bot/node_modules/lodash/_baseTrim.js | 19 + Bot/node_modules/lodash/_baseUnary.js | 14 + Bot/node_modules/lodash/_baseUniq.js | 72 + Bot/node_modules/lodash/_baseUnset.js | 20 + Bot/node_modules/lodash/_baseUpdate.js | 18 + Bot/node_modules/lodash/_baseValues.js | 19 + Bot/node_modules/lodash/_baseWhile.js | 26 + Bot/node_modules/lodash/_baseWrapperValue.js | 25 + Bot/node_modules/lodash/_baseXor.js | 36 + Bot/node_modules/lodash/_baseZipObject.js | 23 + Bot/node_modules/lodash/_cacheHas.js | 13 + .../lodash/_castArrayLikeObject.js | 14 + Bot/node_modules/lodash/_castFunction.js | 14 + Bot/node_modules/lodash/_castPath.js | 21 + Bot/node_modules/lodash/_castRest.js | 14 + Bot/node_modules/lodash/_castSlice.js | 18 + Bot/node_modules/lodash/_charsEndIndex.js | 19 + Bot/node_modules/lodash/_charsStartIndex.js | 20 + Bot/node_modules/lodash/_cloneArrayBuffer.js | 16 + Bot/node_modules/lodash/_cloneBuffer.js | 35 + Bot/node_modules/lodash/_cloneDataView.js | 16 + Bot/node_modules/lodash/_cloneRegExp.js | 17 + Bot/node_modules/lodash/_cloneSymbol.js | 18 + Bot/node_modules/lodash/_cloneTypedArray.js | 16 + Bot/node_modules/lodash/_compareAscending.js | 41 + Bot/node_modules/lodash/_compareMultiple.js | 44 + Bot/node_modules/lodash/_composeArgs.js | 39 + Bot/node_modules/lodash/_composeArgsRight.js | 41 + Bot/node_modules/lodash/_copyArray.js | 20 + Bot/node_modules/lodash/_copyObject.js | 40 + Bot/node_modules/lodash/_copySymbols.js | 16 + Bot/node_modules/lodash/_copySymbolsIn.js | 16 + Bot/node_modules/lodash/_coreJsData.js | 6 + Bot/node_modules/lodash/_countHolders.js | 21 + Bot/node_modules/lodash/_createAggregator.js | 23 + Bot/node_modules/lodash/_createAssigner.js | 37 + Bot/node_modules/lodash/_createBaseEach.js | 32 + Bot/node_modules/lodash/_createBaseFor.js | 25 + Bot/node_modules/lodash/_createBind.js | 28 + Bot/node_modules/lodash/_createCaseFirst.js | 33 + Bot/node_modules/lodash/_createCompounder.js | 24 + Bot/node_modules/lodash/_createCtor.js | 37 + Bot/node_modules/lodash/_createCurry.js | 46 + Bot/node_modules/lodash/_createFind.js | 25 + Bot/node_modules/lodash/_createFlow.js | 78 + Bot/node_modules/lodash/_createHybrid.js | 92 + Bot/node_modules/lodash/_createInverter.js | 17 + .../lodash/_createMathOperation.js | 38 + Bot/node_modules/lodash/_createOver.js | 27 + Bot/node_modules/lodash/_createPadding.js | 33 + Bot/node_modules/lodash/_createPartial.js | 43 + Bot/node_modules/lodash/_createRange.js | 30 + Bot/node_modules/lodash/_createRecurry.js | 56 + .../lodash/_createRelationalOperation.js | 20 + Bot/node_modules/lodash/_createRound.js | 35 + Bot/node_modules/lodash/_createSet.js | 19 + Bot/node_modules/lodash/_createToPairs.js | 30 + Bot/node_modules/lodash/_createWrap.js | 106 + .../lodash/_customDefaultsAssignIn.js | 29 + .../lodash/_customDefaultsMerge.js | 28 + Bot/node_modules/lodash/_customOmitClone.js | 16 + Bot/node_modules/lodash/_deburrLetter.js | 71 + Bot/node_modules/lodash/_defineProperty.js | 11 + Bot/node_modules/lodash/_equalArrays.js | 84 + Bot/node_modules/lodash/_equalByTag.js | 112 + Bot/node_modules/lodash/_equalObjects.js | 90 + Bot/node_modules/lodash/_escapeHtmlChar.js | 21 + Bot/node_modules/lodash/_escapeStringChar.js | 22 + Bot/node_modules/lodash/_flatRest.js | 16 + Bot/node_modules/lodash/_freeGlobal.js | 4 + Bot/node_modules/lodash/_getAllKeys.js | 16 + Bot/node_modules/lodash/_getAllKeysIn.js | 17 + Bot/node_modules/lodash/_getData.js | 15 + Bot/node_modules/lodash/_getFuncName.js | 31 + Bot/node_modules/lodash/_getHolder.js | 13 + Bot/node_modules/lodash/_getMapData.js | 18 + Bot/node_modules/lodash/_getMatchData.js | 24 + Bot/node_modules/lodash/_getNative.js | 17 + Bot/node_modules/lodash/_getPrototype.js | 6 + Bot/node_modules/lodash/_getRawTag.js | 46 + Bot/node_modules/lodash/_getSymbols.js | 30 + Bot/node_modules/lodash/_getSymbolsIn.js | 25 + Bot/node_modules/lodash/_getTag.js | 58 + Bot/node_modules/lodash/_getValue.js | 13 + Bot/node_modules/lodash/_getView.js | 33 + Bot/node_modules/lodash/_getWrapDetails.js | 17 + Bot/node_modules/lodash/_hasPath.js | 39 + Bot/node_modules/lodash/_hasUnicode.js | 26 + Bot/node_modules/lodash/_hasUnicodeWord.js | 15 + Bot/node_modules/lodash/_hashClear.js | 15 + Bot/node_modules/lodash/_hashDelete.js | 17 + Bot/node_modules/lodash/_hashGet.js | 30 + Bot/node_modules/lodash/_hashHas.js | 23 + Bot/node_modules/lodash/_hashSet.js | 23 + Bot/node_modules/lodash/_initCloneArray.js | 26 + Bot/node_modules/lodash/_initCloneByTag.js | 77 + Bot/node_modules/lodash/_initCloneObject.js | 18 + Bot/node_modules/lodash/_insertWrapDetails.js | 23 + Bot/node_modules/lodash/_isFlattenable.js | 20 + Bot/node_modules/lodash/_isIndex.js | 25 + Bot/node_modules/lodash/_isIterateeCall.js | 30 + Bot/node_modules/lodash/_isKey.js | 29 + Bot/node_modules/lodash/_isKeyable.js | 15 + Bot/node_modules/lodash/_isLaziable.js | 28 + Bot/node_modules/lodash/_isMaskable.js | 14 + Bot/node_modules/lodash/_isMasked.js | 20 + Bot/node_modules/lodash/_isPrototype.js | 18 + .../lodash/_isStrictComparable.js | 15 + Bot/node_modules/lodash/_iteratorToArray.js | 18 + Bot/node_modules/lodash/_lazyClone.js | 23 + Bot/node_modules/lodash/_lazyReverse.js | 23 + Bot/node_modules/lodash/_lazyValue.js | 69 + Bot/node_modules/lodash/_listCacheClear.js | 13 + Bot/node_modules/lodash/_listCacheDelete.js | 35 + Bot/node_modules/lodash/_listCacheGet.js | 19 + Bot/node_modules/lodash/_listCacheHas.js | 16 + Bot/node_modules/lodash/_listCacheSet.js | 26 + Bot/node_modules/lodash/_mapCacheClear.js | 21 + Bot/node_modules/lodash/_mapCacheDelete.js | 18 + Bot/node_modules/lodash/_mapCacheGet.js | 16 + Bot/node_modules/lodash/_mapCacheHas.js | 16 + Bot/node_modules/lodash/_mapCacheSet.js | 22 + Bot/node_modules/lodash/_mapToArray.js | 18 + .../lodash/_matchesStrictComparable.js | 20 + Bot/node_modules/lodash/_memoizeCapped.js | 26 + Bot/node_modules/lodash/_mergeData.js | 90 + Bot/node_modules/lodash/_metaMap.js | 6 + Bot/node_modules/lodash/_nativeCreate.js | 6 + Bot/node_modules/lodash/_nativeKeys.js | 6 + Bot/node_modules/lodash/_nativeKeysIn.js | 20 + Bot/node_modules/lodash/_nodeUtil.js | 30 + Bot/node_modules/lodash/_objectToString.js | 22 + Bot/node_modules/lodash/_overArg.js | 15 + Bot/node_modules/lodash/_overRest.js | 36 + Bot/node_modules/lodash/_parent.js | 16 + Bot/node_modules/lodash/_reEscape.js | 4 + Bot/node_modules/lodash/_reEvaluate.js | 4 + Bot/node_modules/lodash/_reInterpolate.js | 4 + Bot/node_modules/lodash/_realNames.js | 4 + Bot/node_modules/lodash/_reorder.js | 29 + Bot/node_modules/lodash/_replaceHolders.js | 29 + Bot/node_modules/lodash/_root.js | 9 + Bot/node_modules/lodash/_safeGet.js | 21 + Bot/node_modules/lodash/_setCacheAdd.js | 19 + Bot/node_modules/lodash/_setCacheHas.js | 14 + Bot/node_modules/lodash/_setData.js | 20 + Bot/node_modules/lodash/_setToArray.js | 18 + Bot/node_modules/lodash/_setToPairs.js | 18 + Bot/node_modules/lodash/_setToString.js | 14 + Bot/node_modules/lodash/_setWrapToString.js | 21 + Bot/node_modules/lodash/_shortOut.js | 37 + Bot/node_modules/lodash/_shuffleSelf.js | 28 + Bot/node_modules/lodash/_stackClear.js | 15 + Bot/node_modules/lodash/_stackDelete.js | 18 + Bot/node_modules/lodash/_stackGet.js | 14 + Bot/node_modules/lodash/_stackHas.js | 14 + Bot/node_modules/lodash/_stackSet.js | 34 + Bot/node_modules/lodash/_strictIndexOf.js | 23 + Bot/node_modules/lodash/_strictLastIndexOf.js | 21 + Bot/node_modules/lodash/_stringSize.js | 18 + Bot/node_modules/lodash/_stringToArray.js | 18 + Bot/node_modules/lodash/_stringToPath.js | 27 + Bot/node_modules/lodash/_toKey.js | 21 + Bot/node_modules/lodash/_toSource.js | 26 + Bot/node_modules/lodash/_trimmedEndIndex.js | 19 + Bot/node_modules/lodash/_unescapeHtmlChar.js | 21 + Bot/node_modules/lodash/_unicodeSize.js | 44 + Bot/node_modules/lodash/_unicodeToArray.js | 40 + Bot/node_modules/lodash/_unicodeWords.js | 69 + Bot/node_modules/lodash/_updateWrapDetails.js | 46 + Bot/node_modules/lodash/_wrapperClone.js | 23 + Bot/node_modules/lodash/add.js | 22 + Bot/node_modules/lodash/after.js | 42 + Bot/node_modules/lodash/array.js | 67 + Bot/node_modules/lodash/ary.js | 29 + Bot/node_modules/lodash/assign.js | 58 + Bot/node_modules/lodash/assignIn.js | 40 + Bot/node_modules/lodash/assignInWith.js | 38 + Bot/node_modules/lodash/assignWith.js | 37 + Bot/node_modules/lodash/at.js | 23 + Bot/node_modules/lodash/attempt.js | 35 + Bot/node_modules/lodash/before.js | 40 + Bot/node_modules/lodash/bind.js | 57 + Bot/node_modules/lodash/bindAll.js | 41 + Bot/node_modules/lodash/bindKey.js | 68 + Bot/node_modules/lodash/camelCase.js | 29 + Bot/node_modules/lodash/capitalize.js | 23 + Bot/node_modules/lodash/castArray.js | 44 + Bot/node_modules/lodash/ceil.js | 26 + Bot/node_modules/lodash/chain.js | 38 + Bot/node_modules/lodash/chunk.js | 50 + Bot/node_modules/lodash/clamp.js | 39 + Bot/node_modules/lodash/clone.js | 36 + Bot/node_modules/lodash/cloneDeep.js | 29 + Bot/node_modules/lodash/cloneDeepWith.js | 40 + Bot/node_modules/lodash/cloneWith.js | 42 + Bot/node_modules/lodash/collection.js | 30 + Bot/node_modules/lodash/commit.js | 33 + Bot/node_modules/lodash/compact.js | 31 + Bot/node_modules/lodash/concat.js | 43 + Bot/node_modules/lodash/cond.js | 60 + Bot/node_modules/lodash/conforms.js | 35 + Bot/node_modules/lodash/conformsTo.js | 32 + Bot/node_modules/lodash/constant.js | 26 + Bot/node_modules/lodash/core.js | 3877 ++++ Bot/node_modules/lodash/core.min.js | 29 + Bot/node_modules/lodash/countBy.js | 40 + Bot/node_modules/lodash/create.js | 43 + Bot/node_modules/lodash/curry.js | 57 + Bot/node_modules/lodash/curryRight.js | 54 + Bot/node_modules/lodash/date.js | 3 + Bot/node_modules/lodash/debounce.js | 191 + Bot/node_modules/lodash/deburr.js | 45 + Bot/node_modules/lodash/defaultTo.js | 25 + Bot/node_modules/lodash/defaults.js | 64 + Bot/node_modules/lodash/defaultsDeep.js | 30 + Bot/node_modules/lodash/defer.js | 26 + Bot/node_modules/lodash/delay.js | 28 + Bot/node_modules/lodash/difference.js | 33 + Bot/node_modules/lodash/differenceBy.js | 44 + Bot/node_modules/lodash/differenceWith.js | 40 + Bot/node_modules/lodash/divide.js | 22 + Bot/node_modules/lodash/drop.js | 38 + Bot/node_modules/lodash/dropRight.js | 39 + Bot/node_modules/lodash/dropRightWhile.js | 45 + Bot/node_modules/lodash/dropWhile.js | 45 + Bot/node_modules/lodash/each.js | 1 + Bot/node_modules/lodash/eachRight.js | 1 + Bot/node_modules/lodash/endsWith.js | 43 + Bot/node_modules/lodash/entries.js | 1 + Bot/node_modules/lodash/entriesIn.js | 1 + Bot/node_modules/lodash/eq.js | 37 + Bot/node_modules/lodash/escape.js | 43 + Bot/node_modules/lodash/escapeRegExp.js | 32 + Bot/node_modules/lodash/every.js | 56 + Bot/node_modules/lodash/extend.js | 1 + Bot/node_modules/lodash/extendWith.js | 1 + Bot/node_modules/lodash/fill.js | 45 + Bot/node_modules/lodash/filter.js | 52 + Bot/node_modules/lodash/find.js | 42 + Bot/node_modules/lodash/findIndex.js | 55 + Bot/node_modules/lodash/findKey.js | 44 + Bot/node_modules/lodash/findLast.js | 25 + Bot/node_modules/lodash/findLastIndex.js | 59 + Bot/node_modules/lodash/findLastKey.js | 44 + Bot/node_modules/lodash/first.js | 1 + Bot/node_modules/lodash/flake.lock | 40 + Bot/node_modules/lodash/flake.nix | 20 + Bot/node_modules/lodash/flatMap.js | 29 + Bot/node_modules/lodash/flatMapDeep.js | 31 + Bot/node_modules/lodash/flatMapDepth.js | 31 + Bot/node_modules/lodash/flatten.js | 22 + Bot/node_modules/lodash/flattenDeep.js | 25 + Bot/node_modules/lodash/flattenDepth.js | 33 + Bot/node_modules/lodash/flip.js | 28 + Bot/node_modules/lodash/floor.js | 26 + Bot/node_modules/lodash/flow.js | 27 + Bot/node_modules/lodash/flowRight.js | 26 + Bot/node_modules/lodash/forEach.js | 41 + Bot/node_modules/lodash/forEachRight.js | 31 + Bot/node_modules/lodash/forIn.js | 39 + Bot/node_modules/lodash/forInRight.js | 37 + Bot/node_modules/lodash/forOwn.js | 36 + Bot/node_modules/lodash/forOwnRight.js | 34 + Bot/node_modules/lodash/fp.js | 2 + Bot/node_modules/lodash/fp/F.js | 1 + Bot/node_modules/lodash/fp/T.js | 1 + Bot/node_modules/lodash/fp/__.js | 1 + Bot/node_modules/lodash/fp/_baseConvert.js | 569 + Bot/node_modules/lodash/fp/_convertBrowser.js | 18 + Bot/node_modules/lodash/fp/_falseOptions.js | 7 + Bot/node_modules/lodash/fp/_mapping.js | 358 + Bot/node_modules/lodash/fp/_util.js | 16 + Bot/node_modules/lodash/fp/add.js | 5 + Bot/node_modules/lodash/fp/after.js | 5 + Bot/node_modules/lodash/fp/all.js | 1 + Bot/node_modules/lodash/fp/allPass.js | 1 + Bot/node_modules/lodash/fp/always.js | 1 + Bot/node_modules/lodash/fp/any.js | 1 + Bot/node_modules/lodash/fp/anyPass.js | 1 + Bot/node_modules/lodash/fp/apply.js | 1 + Bot/node_modules/lodash/fp/array.js | 2 + Bot/node_modules/lodash/fp/ary.js | 5 + Bot/node_modules/lodash/fp/assign.js | 5 + Bot/node_modules/lodash/fp/assignAll.js | 5 + Bot/node_modules/lodash/fp/assignAllWith.js | 5 + Bot/node_modules/lodash/fp/assignIn.js | 5 + Bot/node_modules/lodash/fp/assignInAll.js | 5 + Bot/node_modules/lodash/fp/assignInAllWith.js | 5 + Bot/node_modules/lodash/fp/assignInWith.js | 5 + Bot/node_modules/lodash/fp/assignWith.js | 5 + Bot/node_modules/lodash/fp/assoc.js | 1 + Bot/node_modules/lodash/fp/assocPath.js | 1 + Bot/node_modules/lodash/fp/at.js | 5 + Bot/node_modules/lodash/fp/attempt.js | 5 + Bot/node_modules/lodash/fp/before.js | 5 + Bot/node_modules/lodash/fp/bind.js | 5 + Bot/node_modules/lodash/fp/bindAll.js | 5 + Bot/node_modules/lodash/fp/bindKey.js | 5 + Bot/node_modules/lodash/fp/camelCase.js | 5 + Bot/node_modules/lodash/fp/capitalize.js | 5 + Bot/node_modules/lodash/fp/castArray.js | 5 + Bot/node_modules/lodash/fp/ceil.js | 5 + Bot/node_modules/lodash/fp/chain.js | 5 + Bot/node_modules/lodash/fp/chunk.js | 5 + Bot/node_modules/lodash/fp/clamp.js | 5 + Bot/node_modules/lodash/fp/clone.js | 5 + Bot/node_modules/lodash/fp/cloneDeep.js | 5 + Bot/node_modules/lodash/fp/cloneDeepWith.js | 5 + Bot/node_modules/lodash/fp/cloneWith.js | 5 + Bot/node_modules/lodash/fp/collection.js | 2 + Bot/node_modules/lodash/fp/commit.js | 5 + Bot/node_modules/lodash/fp/compact.js | 5 + Bot/node_modules/lodash/fp/complement.js | 1 + Bot/node_modules/lodash/fp/compose.js | 1 + Bot/node_modules/lodash/fp/concat.js | 5 + Bot/node_modules/lodash/fp/cond.js | 5 + Bot/node_modules/lodash/fp/conforms.js | 1 + Bot/node_modules/lodash/fp/conformsTo.js | 5 + Bot/node_modules/lodash/fp/constant.js | 5 + Bot/node_modules/lodash/fp/contains.js | 1 + Bot/node_modules/lodash/fp/convert.js | 18 + Bot/node_modules/lodash/fp/countBy.js | 5 + Bot/node_modules/lodash/fp/create.js | 5 + Bot/node_modules/lodash/fp/curry.js | 5 + Bot/node_modules/lodash/fp/curryN.js | 5 + Bot/node_modules/lodash/fp/curryRight.js | 5 + Bot/node_modules/lodash/fp/curryRightN.js | 5 + Bot/node_modules/lodash/fp/date.js | 2 + Bot/node_modules/lodash/fp/debounce.js | 5 + Bot/node_modules/lodash/fp/deburr.js | 5 + Bot/node_modules/lodash/fp/defaultTo.js | 5 + Bot/node_modules/lodash/fp/defaults.js | 5 + Bot/node_modules/lodash/fp/defaultsAll.js | 5 + Bot/node_modules/lodash/fp/defaultsDeep.js | 5 + Bot/node_modules/lodash/fp/defaultsDeepAll.js | 5 + Bot/node_modules/lodash/fp/defer.js | 5 + Bot/node_modules/lodash/fp/delay.js | 5 + Bot/node_modules/lodash/fp/difference.js | 5 + Bot/node_modules/lodash/fp/differenceBy.js | 5 + Bot/node_modules/lodash/fp/differenceWith.js | 5 + Bot/node_modules/lodash/fp/dissoc.js | 1 + Bot/node_modules/lodash/fp/dissocPath.js | 1 + Bot/node_modules/lodash/fp/divide.js | 5 + Bot/node_modules/lodash/fp/drop.js | 5 + Bot/node_modules/lodash/fp/dropLast.js | 1 + Bot/node_modules/lodash/fp/dropLastWhile.js | 1 + Bot/node_modules/lodash/fp/dropRight.js | 5 + Bot/node_modules/lodash/fp/dropRightWhile.js | 5 + Bot/node_modules/lodash/fp/dropWhile.js | 5 + Bot/node_modules/lodash/fp/each.js | 1 + Bot/node_modules/lodash/fp/eachRight.js | 1 + Bot/node_modules/lodash/fp/endsWith.js | 5 + Bot/node_modules/lodash/fp/entries.js | 1 + Bot/node_modules/lodash/fp/entriesIn.js | 1 + Bot/node_modules/lodash/fp/eq.js | 5 + Bot/node_modules/lodash/fp/equals.js | 1 + Bot/node_modules/lodash/fp/escape.js | 5 + Bot/node_modules/lodash/fp/escapeRegExp.js | 5 + Bot/node_modules/lodash/fp/every.js | 5 + Bot/node_modules/lodash/fp/extend.js | 1 + Bot/node_modules/lodash/fp/extendAll.js | 1 + Bot/node_modules/lodash/fp/extendAllWith.js | 1 + Bot/node_modules/lodash/fp/extendWith.js | 1 + Bot/node_modules/lodash/fp/fill.js | 5 + Bot/node_modules/lodash/fp/filter.js | 5 + Bot/node_modules/lodash/fp/find.js | 5 + Bot/node_modules/lodash/fp/findFrom.js | 5 + Bot/node_modules/lodash/fp/findIndex.js | 5 + Bot/node_modules/lodash/fp/findIndexFrom.js | 5 + Bot/node_modules/lodash/fp/findKey.js | 5 + Bot/node_modules/lodash/fp/findLast.js | 5 + Bot/node_modules/lodash/fp/findLastFrom.js | 5 + Bot/node_modules/lodash/fp/findLastIndex.js | 5 + .../lodash/fp/findLastIndexFrom.js | 5 + Bot/node_modules/lodash/fp/findLastKey.js | 5 + Bot/node_modules/lodash/fp/first.js | 1 + Bot/node_modules/lodash/fp/flatMap.js | 5 + Bot/node_modules/lodash/fp/flatMapDeep.js | 5 + Bot/node_modules/lodash/fp/flatMapDepth.js | 5 + Bot/node_modules/lodash/fp/flatten.js | 5 + Bot/node_modules/lodash/fp/flattenDeep.js | 5 + Bot/node_modules/lodash/fp/flattenDepth.js | 5 + Bot/node_modules/lodash/fp/flip.js | 5 + Bot/node_modules/lodash/fp/floor.js | 5 + Bot/node_modules/lodash/fp/flow.js | 5 + Bot/node_modules/lodash/fp/flowRight.js | 5 + Bot/node_modules/lodash/fp/forEach.js | 5 + Bot/node_modules/lodash/fp/forEachRight.js | 5 + Bot/node_modules/lodash/fp/forIn.js | 5 + Bot/node_modules/lodash/fp/forInRight.js | 5 + Bot/node_modules/lodash/fp/forOwn.js | 5 + Bot/node_modules/lodash/fp/forOwnRight.js | 5 + Bot/node_modules/lodash/fp/fromPairs.js | 5 + Bot/node_modules/lodash/fp/function.js | 2 + Bot/node_modules/lodash/fp/functions.js | 5 + Bot/node_modules/lodash/fp/functionsIn.js | 5 + Bot/node_modules/lodash/fp/get.js | 5 + Bot/node_modules/lodash/fp/getOr.js | 5 + Bot/node_modules/lodash/fp/groupBy.js | 5 + Bot/node_modules/lodash/fp/gt.js | 5 + Bot/node_modules/lodash/fp/gte.js | 5 + Bot/node_modules/lodash/fp/has.js | 5 + Bot/node_modules/lodash/fp/hasIn.js | 5 + Bot/node_modules/lodash/fp/head.js | 5 + Bot/node_modules/lodash/fp/identical.js | 1 + Bot/node_modules/lodash/fp/identity.js | 5 + Bot/node_modules/lodash/fp/inRange.js | 5 + Bot/node_modules/lodash/fp/includes.js | 5 + Bot/node_modules/lodash/fp/includesFrom.js | 5 + Bot/node_modules/lodash/fp/indexBy.js | 1 + Bot/node_modules/lodash/fp/indexOf.js | 5 + Bot/node_modules/lodash/fp/indexOfFrom.js | 5 + Bot/node_modules/lodash/fp/init.js | 1 + Bot/node_modules/lodash/fp/initial.js | 5 + Bot/node_modules/lodash/fp/intersection.js | 5 + Bot/node_modules/lodash/fp/intersectionBy.js | 5 + .../lodash/fp/intersectionWith.js | 5 + Bot/node_modules/lodash/fp/invert.js | 5 + Bot/node_modules/lodash/fp/invertBy.js | 5 + Bot/node_modules/lodash/fp/invertObj.js | 1 + Bot/node_modules/lodash/fp/invoke.js | 5 + Bot/node_modules/lodash/fp/invokeArgs.js | 5 + Bot/node_modules/lodash/fp/invokeArgsMap.js | 5 + Bot/node_modules/lodash/fp/invokeMap.js | 5 + Bot/node_modules/lodash/fp/isArguments.js | 5 + Bot/node_modules/lodash/fp/isArray.js | 5 + Bot/node_modules/lodash/fp/isArrayBuffer.js | 5 + Bot/node_modules/lodash/fp/isArrayLike.js | 5 + .../lodash/fp/isArrayLikeObject.js | 5 + Bot/node_modules/lodash/fp/isBoolean.js | 5 + Bot/node_modules/lodash/fp/isBuffer.js | 5 + Bot/node_modules/lodash/fp/isDate.js | 5 + Bot/node_modules/lodash/fp/isElement.js | 5 + Bot/node_modules/lodash/fp/isEmpty.js | 5 + Bot/node_modules/lodash/fp/isEqual.js | 5 + Bot/node_modules/lodash/fp/isEqualWith.js | 5 + Bot/node_modules/lodash/fp/isError.js | 5 + Bot/node_modules/lodash/fp/isFinite.js | 5 + Bot/node_modules/lodash/fp/isFunction.js | 5 + Bot/node_modules/lodash/fp/isInteger.js | 5 + Bot/node_modules/lodash/fp/isLength.js | 5 + Bot/node_modules/lodash/fp/isMap.js | 5 + Bot/node_modules/lodash/fp/isMatch.js | 5 + Bot/node_modules/lodash/fp/isMatchWith.js | 5 + Bot/node_modules/lodash/fp/isNaN.js | 5 + Bot/node_modules/lodash/fp/isNative.js | 5 + Bot/node_modules/lodash/fp/isNil.js | 5 + Bot/node_modules/lodash/fp/isNull.js | 5 + Bot/node_modules/lodash/fp/isNumber.js | 5 + Bot/node_modules/lodash/fp/isObject.js | 5 + Bot/node_modules/lodash/fp/isObjectLike.js | 5 + Bot/node_modules/lodash/fp/isPlainObject.js | 5 + Bot/node_modules/lodash/fp/isRegExp.js | 5 + Bot/node_modules/lodash/fp/isSafeInteger.js | 5 + Bot/node_modules/lodash/fp/isSet.js | 5 + Bot/node_modules/lodash/fp/isString.js | 5 + Bot/node_modules/lodash/fp/isSymbol.js | 5 + Bot/node_modules/lodash/fp/isTypedArray.js | 5 + Bot/node_modules/lodash/fp/isUndefined.js | 5 + Bot/node_modules/lodash/fp/isWeakMap.js | 5 + Bot/node_modules/lodash/fp/isWeakSet.js | 5 + Bot/node_modules/lodash/fp/iteratee.js | 5 + Bot/node_modules/lodash/fp/join.js | 5 + Bot/node_modules/lodash/fp/juxt.js | 1 + Bot/node_modules/lodash/fp/kebabCase.js | 5 + Bot/node_modules/lodash/fp/keyBy.js | 5 + Bot/node_modules/lodash/fp/keys.js | 5 + Bot/node_modules/lodash/fp/keysIn.js | 5 + Bot/node_modules/lodash/fp/lang.js | 2 + Bot/node_modules/lodash/fp/last.js | 5 + Bot/node_modules/lodash/fp/lastIndexOf.js | 5 + Bot/node_modules/lodash/fp/lastIndexOfFrom.js | 5 + Bot/node_modules/lodash/fp/lowerCase.js | 5 + Bot/node_modules/lodash/fp/lowerFirst.js | 5 + Bot/node_modules/lodash/fp/lt.js | 5 + Bot/node_modules/lodash/fp/lte.js | 5 + Bot/node_modules/lodash/fp/map.js | 5 + Bot/node_modules/lodash/fp/mapKeys.js | 5 + Bot/node_modules/lodash/fp/mapValues.js | 5 + Bot/node_modules/lodash/fp/matches.js | 1 + Bot/node_modules/lodash/fp/matchesProperty.js | 5 + Bot/node_modules/lodash/fp/math.js | 2 + Bot/node_modules/lodash/fp/max.js | 5 + Bot/node_modules/lodash/fp/maxBy.js | 5 + Bot/node_modules/lodash/fp/mean.js | 5 + Bot/node_modules/lodash/fp/meanBy.js | 5 + Bot/node_modules/lodash/fp/memoize.js | 5 + Bot/node_modules/lodash/fp/merge.js | 5 + Bot/node_modules/lodash/fp/mergeAll.js | 5 + Bot/node_modules/lodash/fp/mergeAllWith.js | 5 + Bot/node_modules/lodash/fp/mergeWith.js | 5 + Bot/node_modules/lodash/fp/method.js | 5 + Bot/node_modules/lodash/fp/methodOf.js | 5 + Bot/node_modules/lodash/fp/min.js | 5 + Bot/node_modules/lodash/fp/minBy.js | 5 + Bot/node_modules/lodash/fp/mixin.js | 5 + Bot/node_modules/lodash/fp/multiply.js | 5 + Bot/node_modules/lodash/fp/nAry.js | 1 + Bot/node_modules/lodash/fp/negate.js | 5 + Bot/node_modules/lodash/fp/next.js | 5 + Bot/node_modules/lodash/fp/noop.js | 5 + Bot/node_modules/lodash/fp/now.js | 5 + Bot/node_modules/lodash/fp/nth.js | 5 + Bot/node_modules/lodash/fp/nthArg.js | 5 + Bot/node_modules/lodash/fp/number.js | 2 + Bot/node_modules/lodash/fp/object.js | 2 + Bot/node_modules/lodash/fp/omit.js | 5 + Bot/node_modules/lodash/fp/omitAll.js | 1 + Bot/node_modules/lodash/fp/omitBy.js | 5 + Bot/node_modules/lodash/fp/once.js | 5 + Bot/node_modules/lodash/fp/orderBy.js | 5 + Bot/node_modules/lodash/fp/over.js | 5 + Bot/node_modules/lodash/fp/overArgs.js | 5 + Bot/node_modules/lodash/fp/overEvery.js | 5 + Bot/node_modules/lodash/fp/overSome.js | 5 + Bot/node_modules/lodash/fp/pad.js | 5 + Bot/node_modules/lodash/fp/padChars.js | 5 + Bot/node_modules/lodash/fp/padCharsEnd.js | 5 + Bot/node_modules/lodash/fp/padCharsStart.js | 5 + Bot/node_modules/lodash/fp/padEnd.js | 5 + Bot/node_modules/lodash/fp/padStart.js | 5 + Bot/node_modules/lodash/fp/parseInt.js | 5 + Bot/node_modules/lodash/fp/partial.js | 5 + Bot/node_modules/lodash/fp/partialRight.js | 5 + Bot/node_modules/lodash/fp/partition.js | 5 + Bot/node_modules/lodash/fp/path.js | 1 + Bot/node_modules/lodash/fp/pathEq.js | 1 + Bot/node_modules/lodash/fp/pathOr.js | 1 + Bot/node_modules/lodash/fp/paths.js | 1 + Bot/node_modules/lodash/fp/pick.js | 5 + Bot/node_modules/lodash/fp/pickAll.js | 1 + Bot/node_modules/lodash/fp/pickBy.js | 5 + Bot/node_modules/lodash/fp/pipe.js | 1 + Bot/node_modules/lodash/fp/placeholder.js | 6 + Bot/node_modules/lodash/fp/plant.js | 5 + Bot/node_modules/lodash/fp/pluck.js | 1 + Bot/node_modules/lodash/fp/prop.js | 1 + Bot/node_modules/lodash/fp/propEq.js | 1 + Bot/node_modules/lodash/fp/propOr.js | 1 + Bot/node_modules/lodash/fp/property.js | 1 + Bot/node_modules/lodash/fp/propertyOf.js | 5 + Bot/node_modules/lodash/fp/props.js | 1 + Bot/node_modules/lodash/fp/pull.js | 5 + Bot/node_modules/lodash/fp/pullAll.js | 5 + Bot/node_modules/lodash/fp/pullAllBy.js | 5 + Bot/node_modules/lodash/fp/pullAllWith.js | 5 + Bot/node_modules/lodash/fp/pullAt.js | 5 + Bot/node_modules/lodash/fp/random.js | 5 + Bot/node_modules/lodash/fp/range.js | 5 + Bot/node_modules/lodash/fp/rangeRight.js | 5 + Bot/node_modules/lodash/fp/rangeStep.js | 5 + Bot/node_modules/lodash/fp/rangeStepRight.js | 5 + Bot/node_modules/lodash/fp/rearg.js | 5 + Bot/node_modules/lodash/fp/reduce.js | 5 + Bot/node_modules/lodash/fp/reduceRight.js | 5 + Bot/node_modules/lodash/fp/reject.js | 5 + Bot/node_modules/lodash/fp/remove.js | 5 + Bot/node_modules/lodash/fp/repeat.js | 5 + Bot/node_modules/lodash/fp/replace.js | 5 + Bot/node_modules/lodash/fp/rest.js | 5 + Bot/node_modules/lodash/fp/restFrom.js | 5 + Bot/node_modules/lodash/fp/result.js | 5 + Bot/node_modules/lodash/fp/reverse.js | 5 + Bot/node_modules/lodash/fp/round.js | 5 + Bot/node_modules/lodash/fp/sample.js | 5 + Bot/node_modules/lodash/fp/sampleSize.js | 5 + Bot/node_modules/lodash/fp/seq.js | 2 + Bot/node_modules/lodash/fp/set.js | 5 + Bot/node_modules/lodash/fp/setWith.js | 5 + Bot/node_modules/lodash/fp/shuffle.js | 5 + Bot/node_modules/lodash/fp/size.js | 5 + Bot/node_modules/lodash/fp/slice.js | 5 + Bot/node_modules/lodash/fp/snakeCase.js | 5 + Bot/node_modules/lodash/fp/some.js | 5 + Bot/node_modules/lodash/fp/sortBy.js | 5 + Bot/node_modules/lodash/fp/sortedIndex.js | 5 + Bot/node_modules/lodash/fp/sortedIndexBy.js | 5 + Bot/node_modules/lodash/fp/sortedIndexOf.js | 5 + Bot/node_modules/lodash/fp/sortedLastIndex.js | 5 + .../lodash/fp/sortedLastIndexBy.js | 5 + .../lodash/fp/sortedLastIndexOf.js | 5 + Bot/node_modules/lodash/fp/sortedUniq.js | 5 + Bot/node_modules/lodash/fp/sortedUniqBy.js | 5 + Bot/node_modules/lodash/fp/split.js | 5 + Bot/node_modules/lodash/fp/spread.js | 5 + Bot/node_modules/lodash/fp/spreadFrom.js | 5 + Bot/node_modules/lodash/fp/startCase.js | 5 + Bot/node_modules/lodash/fp/startsWith.js | 5 + Bot/node_modules/lodash/fp/string.js | 2 + Bot/node_modules/lodash/fp/stubArray.js | 5 + Bot/node_modules/lodash/fp/stubFalse.js | 5 + Bot/node_modules/lodash/fp/stubObject.js | 5 + Bot/node_modules/lodash/fp/stubString.js | 5 + Bot/node_modules/lodash/fp/stubTrue.js | 5 + Bot/node_modules/lodash/fp/subtract.js | 5 + Bot/node_modules/lodash/fp/sum.js | 5 + Bot/node_modules/lodash/fp/sumBy.js | 5 + .../lodash/fp/symmetricDifference.js | 1 + .../lodash/fp/symmetricDifferenceBy.js | 1 + .../lodash/fp/symmetricDifferenceWith.js | 1 + Bot/node_modules/lodash/fp/tail.js | 5 + Bot/node_modules/lodash/fp/take.js | 5 + Bot/node_modules/lodash/fp/takeLast.js | 1 + Bot/node_modules/lodash/fp/takeLastWhile.js | 1 + Bot/node_modules/lodash/fp/takeRight.js | 5 + Bot/node_modules/lodash/fp/takeRightWhile.js | 5 + Bot/node_modules/lodash/fp/takeWhile.js | 5 + Bot/node_modules/lodash/fp/tap.js | 5 + Bot/node_modules/lodash/fp/template.js | 5 + .../lodash/fp/templateSettings.js | 5 + Bot/node_modules/lodash/fp/throttle.js | 5 + Bot/node_modules/lodash/fp/thru.js | 5 + Bot/node_modules/lodash/fp/times.js | 5 + Bot/node_modules/lodash/fp/toArray.js | 5 + Bot/node_modules/lodash/fp/toFinite.js | 5 + Bot/node_modules/lodash/fp/toInteger.js | 5 + Bot/node_modules/lodash/fp/toIterator.js | 5 + Bot/node_modules/lodash/fp/toJSON.js | 5 + Bot/node_modules/lodash/fp/toLength.js | 5 + Bot/node_modules/lodash/fp/toLower.js | 5 + Bot/node_modules/lodash/fp/toNumber.js | 5 + Bot/node_modules/lodash/fp/toPairs.js | 5 + Bot/node_modules/lodash/fp/toPairsIn.js | 5 + Bot/node_modules/lodash/fp/toPath.js | 5 + Bot/node_modules/lodash/fp/toPlainObject.js | 5 + Bot/node_modules/lodash/fp/toSafeInteger.js | 5 + Bot/node_modules/lodash/fp/toString.js | 5 + Bot/node_modules/lodash/fp/toUpper.js | 5 + Bot/node_modules/lodash/fp/transform.js | 5 + Bot/node_modules/lodash/fp/trim.js | 5 + Bot/node_modules/lodash/fp/trimChars.js | 5 + Bot/node_modules/lodash/fp/trimCharsEnd.js | 5 + Bot/node_modules/lodash/fp/trimCharsStart.js | 5 + Bot/node_modules/lodash/fp/trimEnd.js | 5 + Bot/node_modules/lodash/fp/trimStart.js | 5 + Bot/node_modules/lodash/fp/truncate.js | 5 + Bot/node_modules/lodash/fp/unapply.js | 1 + Bot/node_modules/lodash/fp/unary.js | 5 + Bot/node_modules/lodash/fp/unescape.js | 5 + Bot/node_modules/lodash/fp/union.js | 5 + Bot/node_modules/lodash/fp/unionBy.js | 5 + Bot/node_modules/lodash/fp/unionWith.js | 5 + Bot/node_modules/lodash/fp/uniq.js | 5 + Bot/node_modules/lodash/fp/uniqBy.js | 5 + Bot/node_modules/lodash/fp/uniqWith.js | 5 + Bot/node_modules/lodash/fp/uniqueId.js | 5 + Bot/node_modules/lodash/fp/unnest.js | 1 + Bot/node_modules/lodash/fp/unset.js | 5 + Bot/node_modules/lodash/fp/unzip.js | 5 + Bot/node_modules/lodash/fp/unzipWith.js | 5 + Bot/node_modules/lodash/fp/update.js | 5 + Bot/node_modules/lodash/fp/updateWith.js | 5 + Bot/node_modules/lodash/fp/upperCase.js | 5 + Bot/node_modules/lodash/fp/upperFirst.js | 5 + Bot/node_modules/lodash/fp/useWith.js | 1 + Bot/node_modules/lodash/fp/util.js | 2 + Bot/node_modules/lodash/fp/value.js | 5 + Bot/node_modules/lodash/fp/valueOf.js | 5 + Bot/node_modules/lodash/fp/values.js | 5 + Bot/node_modules/lodash/fp/valuesIn.js | 5 + Bot/node_modules/lodash/fp/where.js | 1 + Bot/node_modules/lodash/fp/whereEq.js | 1 + Bot/node_modules/lodash/fp/without.js | 5 + Bot/node_modules/lodash/fp/words.js | 5 + Bot/node_modules/lodash/fp/wrap.js | 5 + Bot/node_modules/lodash/fp/wrapperAt.js | 5 + Bot/node_modules/lodash/fp/wrapperChain.js | 5 + Bot/node_modules/lodash/fp/wrapperLodash.js | 5 + Bot/node_modules/lodash/fp/wrapperReverse.js | 5 + Bot/node_modules/lodash/fp/wrapperValue.js | 5 + Bot/node_modules/lodash/fp/xor.js | 5 + Bot/node_modules/lodash/fp/xorBy.js | 5 + Bot/node_modules/lodash/fp/xorWith.js | 5 + Bot/node_modules/lodash/fp/zip.js | 5 + Bot/node_modules/lodash/fp/zipAll.js | 5 + Bot/node_modules/lodash/fp/zipObj.js | 1 + Bot/node_modules/lodash/fp/zipObject.js | 5 + Bot/node_modules/lodash/fp/zipObjectDeep.js | 5 + Bot/node_modules/lodash/fp/zipWith.js | 5 + Bot/node_modules/lodash/fromPairs.js | 28 + Bot/node_modules/lodash/function.js | 25 + Bot/node_modules/lodash/functions.js | 31 + Bot/node_modules/lodash/functionsIn.js | 31 + Bot/node_modules/lodash/get.js | 33 + Bot/node_modules/lodash/groupBy.js | 41 + Bot/node_modules/lodash/gt.js | 29 + Bot/node_modules/lodash/gte.js | 30 + Bot/node_modules/lodash/has.js | 35 + Bot/node_modules/lodash/hasIn.js | 34 + Bot/node_modules/lodash/head.js | 23 + Bot/node_modules/lodash/identity.js | 21 + Bot/node_modules/lodash/inRange.js | 55 + Bot/node_modules/lodash/includes.js | 53 + Bot/node_modules/lodash/index.js | 1 + Bot/node_modules/lodash/indexOf.js | 42 + Bot/node_modules/lodash/initial.js | 22 + Bot/node_modules/lodash/intersection.js | 30 + Bot/node_modules/lodash/intersectionBy.js | 45 + Bot/node_modules/lodash/intersectionWith.js | 41 + Bot/node_modules/lodash/invert.js | 42 + Bot/node_modules/lodash/invertBy.js | 56 + Bot/node_modules/lodash/invoke.js | 24 + Bot/node_modules/lodash/invokeMap.js | 41 + Bot/node_modules/lodash/isArguments.js | 36 + Bot/node_modules/lodash/isArray.js | 26 + Bot/node_modules/lodash/isArrayBuffer.js | 27 + Bot/node_modules/lodash/isArrayLike.js | 33 + Bot/node_modules/lodash/isArrayLikeObject.js | 33 + Bot/node_modules/lodash/isBoolean.js | 29 + Bot/node_modules/lodash/isBuffer.js | 38 + Bot/node_modules/lodash/isDate.js | 27 + Bot/node_modules/lodash/isElement.js | 25 + Bot/node_modules/lodash/isEmpty.js | 77 + Bot/node_modules/lodash/isEqual.js | 35 + Bot/node_modules/lodash/isEqualWith.js | 41 + Bot/node_modules/lodash/isError.js | 36 + Bot/node_modules/lodash/isFinite.js | 36 + Bot/node_modules/lodash/isFunction.js | 37 + Bot/node_modules/lodash/isInteger.js | 33 + Bot/node_modules/lodash/isLength.js | 35 + Bot/node_modules/lodash/isMap.js | 27 + Bot/node_modules/lodash/isMatch.js | 36 + Bot/node_modules/lodash/isMatchWith.js | 41 + Bot/node_modules/lodash/isNaN.js | 38 + Bot/node_modules/lodash/isNative.js | 40 + Bot/node_modules/lodash/isNil.js | 25 + Bot/node_modules/lodash/isNull.js | 22 + Bot/node_modules/lodash/isNumber.js | 38 + Bot/node_modules/lodash/isObject.js | 31 + Bot/node_modules/lodash/isObjectLike.js | 29 + Bot/node_modules/lodash/isPlainObject.js | 62 + Bot/node_modules/lodash/isRegExp.js | 27 + Bot/node_modules/lodash/isSafeInteger.js | 37 + Bot/node_modules/lodash/isSet.js | 27 + Bot/node_modules/lodash/isString.js | 30 + Bot/node_modules/lodash/isSymbol.js | 29 + Bot/node_modules/lodash/isTypedArray.js | 27 + Bot/node_modules/lodash/isUndefined.js | 22 + Bot/node_modules/lodash/isWeakMap.js | 28 + Bot/node_modules/lodash/isWeakSet.js | 28 + Bot/node_modules/lodash/iteratee.js | 53 + Bot/node_modules/lodash/join.js | 26 + Bot/node_modules/lodash/kebabCase.js | 28 + Bot/node_modules/lodash/keyBy.js | 36 + Bot/node_modules/lodash/keys.js | 37 + Bot/node_modules/lodash/keysIn.js | 32 + Bot/node_modules/lodash/lang.js | 58 + Bot/node_modules/lodash/last.js | 20 + Bot/node_modules/lodash/lastIndexOf.js | 46 + Bot/node_modules/lodash/lodash.js | 17209 ++++++++++++++++ Bot/node_modules/lodash/lodash.min.js | 140 + Bot/node_modules/lodash/lowerCase.js | 27 + Bot/node_modules/lodash/lowerFirst.js | 22 + Bot/node_modules/lodash/lt.js | 29 + Bot/node_modules/lodash/lte.js | 30 + Bot/node_modules/lodash/map.js | 53 + Bot/node_modules/lodash/mapKeys.js | 36 + Bot/node_modules/lodash/mapValues.js | 43 + Bot/node_modules/lodash/matches.js | 46 + Bot/node_modules/lodash/matchesProperty.js | 44 + Bot/node_modules/lodash/math.js | 17 + Bot/node_modules/lodash/max.js | 29 + Bot/node_modules/lodash/maxBy.js | 34 + Bot/node_modules/lodash/mean.js | 22 + Bot/node_modules/lodash/meanBy.js | 31 + Bot/node_modules/lodash/memoize.js | 73 + Bot/node_modules/lodash/merge.js | 39 + Bot/node_modules/lodash/mergeWith.js | 39 + Bot/node_modules/lodash/method.js | 34 + Bot/node_modules/lodash/methodOf.js | 33 + Bot/node_modules/lodash/min.js | 29 + Bot/node_modules/lodash/minBy.js | 34 + Bot/node_modules/lodash/mixin.js | 74 + Bot/node_modules/lodash/multiply.js | 22 + Bot/node_modules/lodash/negate.js | 40 + Bot/node_modules/lodash/next.js | 35 + Bot/node_modules/lodash/noop.js | 17 + Bot/node_modules/lodash/now.js | 23 + Bot/node_modules/lodash/nth.js | 29 + Bot/node_modules/lodash/nthArg.js | 32 + Bot/node_modules/lodash/number.js | 5 + Bot/node_modules/lodash/object.js | 49 + Bot/node_modules/lodash/omit.js | 57 + Bot/node_modules/lodash/omitBy.js | 29 + Bot/node_modules/lodash/once.js | 25 + Bot/node_modules/lodash/orderBy.js | 47 + Bot/node_modules/lodash/over.js | 24 + Bot/node_modules/lodash/overArgs.js | 61 + Bot/node_modules/lodash/overEvery.js | 34 + Bot/node_modules/lodash/overSome.js | 37 + Bot/node_modules/lodash/package.json | 17 + Bot/node_modules/lodash/pad.js | 49 + Bot/node_modules/lodash/padEnd.js | 39 + Bot/node_modules/lodash/padStart.js | 39 + Bot/node_modules/lodash/parseInt.js | 43 + Bot/node_modules/lodash/partial.js | 50 + Bot/node_modules/lodash/partialRight.js | 49 + Bot/node_modules/lodash/partition.js | 43 + Bot/node_modules/lodash/pick.js | 25 + Bot/node_modules/lodash/pickBy.js | 37 + Bot/node_modules/lodash/plant.js | 48 + Bot/node_modules/lodash/property.js | 32 + Bot/node_modules/lodash/propertyOf.js | 30 + Bot/node_modules/lodash/pull.js | 29 + Bot/node_modules/lodash/pullAll.js | 29 + Bot/node_modules/lodash/pullAllBy.js | 33 + Bot/node_modules/lodash/pullAllWith.js | 32 + Bot/node_modules/lodash/pullAt.js | 43 + Bot/node_modules/lodash/random.js | 82 + Bot/node_modules/lodash/range.js | 46 + Bot/node_modules/lodash/rangeRight.js | 41 + Bot/node_modules/lodash/rearg.js | 33 + Bot/node_modules/lodash/reduce.js | 51 + Bot/node_modules/lodash/reduceRight.js | 36 + Bot/node_modules/lodash/reject.js | 46 + Bot/node_modules/lodash/release.md | 48 + Bot/node_modules/lodash/remove.js | 53 + Bot/node_modules/lodash/repeat.js | 37 + Bot/node_modules/lodash/replace.js | 29 + Bot/node_modules/lodash/rest.js | 40 + Bot/node_modules/lodash/result.js | 56 + Bot/node_modules/lodash/reverse.js | 34 + Bot/node_modules/lodash/round.js | 26 + Bot/node_modules/lodash/sample.js | 24 + Bot/node_modules/lodash/sampleSize.js | 37 + Bot/node_modules/lodash/seq.js | 16 + Bot/node_modules/lodash/set.js | 35 + Bot/node_modules/lodash/setWith.js | 32 + Bot/node_modules/lodash/shuffle.js | 25 + Bot/node_modules/lodash/size.js | 46 + Bot/node_modules/lodash/slice.js | 37 + Bot/node_modules/lodash/snakeCase.js | 28 + Bot/node_modules/lodash/some.js | 51 + Bot/node_modules/lodash/sortBy.js | 48 + Bot/node_modules/lodash/sortedIndex.js | 24 + Bot/node_modules/lodash/sortedIndexBy.js | 33 + Bot/node_modules/lodash/sortedIndexOf.js | 31 + Bot/node_modules/lodash/sortedLastIndex.js | 25 + Bot/node_modules/lodash/sortedLastIndexBy.js | 33 + Bot/node_modules/lodash/sortedLastIndexOf.js | 31 + Bot/node_modules/lodash/sortedUniq.js | 24 + Bot/node_modules/lodash/sortedUniqBy.js | 26 + Bot/node_modules/lodash/split.js | 52 + Bot/node_modules/lodash/spread.js | 63 + Bot/node_modules/lodash/startCase.js | 29 + Bot/node_modules/lodash/startsWith.js | 39 + Bot/node_modules/lodash/string.js | 33 + Bot/node_modules/lodash/stubArray.js | 23 + Bot/node_modules/lodash/stubFalse.js | 18 + Bot/node_modules/lodash/stubObject.js | 23 + Bot/node_modules/lodash/stubString.js | 18 + Bot/node_modules/lodash/stubTrue.js | 18 + Bot/node_modules/lodash/subtract.js | 22 + Bot/node_modules/lodash/sum.js | 24 + Bot/node_modules/lodash/sumBy.js | 33 + Bot/node_modules/lodash/tail.js | 22 + Bot/node_modules/lodash/take.js | 37 + Bot/node_modules/lodash/takeRight.js | 39 + Bot/node_modules/lodash/takeRightWhile.js | 45 + Bot/node_modules/lodash/takeWhile.js | 45 + Bot/node_modules/lodash/tap.js | 29 + Bot/node_modules/lodash/template.js | 272 + Bot/node_modules/lodash/templateSettings.js | 67 + Bot/node_modules/lodash/throttle.js | 69 + Bot/node_modules/lodash/thru.js | 28 + Bot/node_modules/lodash/times.js | 51 + Bot/node_modules/lodash/toArray.js | 58 + Bot/node_modules/lodash/toFinite.js | 42 + Bot/node_modules/lodash/toInteger.js | 36 + Bot/node_modules/lodash/toIterator.js | 23 + Bot/node_modules/lodash/toJSON.js | 1 + Bot/node_modules/lodash/toLength.js | 38 + Bot/node_modules/lodash/toLower.js | 28 + Bot/node_modules/lodash/toNumber.js | 64 + Bot/node_modules/lodash/toPairs.js | 30 + Bot/node_modules/lodash/toPairsIn.js | 30 + Bot/node_modules/lodash/toPath.js | 33 + Bot/node_modules/lodash/toPlainObject.js | 32 + Bot/node_modules/lodash/toSafeInteger.js | 37 + Bot/node_modules/lodash/toString.js | 28 + Bot/node_modules/lodash/toUpper.js | 28 + Bot/node_modules/lodash/transform.js | 65 + Bot/node_modules/lodash/trim.js | 47 + Bot/node_modules/lodash/trimEnd.js | 41 + Bot/node_modules/lodash/trimStart.js | 43 + Bot/node_modules/lodash/truncate.js | 111 + Bot/node_modules/lodash/unary.js | 22 + Bot/node_modules/lodash/unescape.js | 34 + Bot/node_modules/lodash/union.js | 26 + Bot/node_modules/lodash/unionBy.js | 39 + Bot/node_modules/lodash/unionWith.js | 34 + Bot/node_modules/lodash/uniq.js | 25 + Bot/node_modules/lodash/uniqBy.js | 31 + Bot/node_modules/lodash/uniqWith.js | 28 + Bot/node_modules/lodash/uniqueId.js | 28 + Bot/node_modules/lodash/unset.js | 34 + Bot/node_modules/lodash/unzip.js | 45 + Bot/node_modules/lodash/unzipWith.js | 39 + Bot/node_modules/lodash/update.js | 35 + Bot/node_modules/lodash/updateWith.js | 33 + Bot/node_modules/lodash/upperCase.js | 27 + Bot/node_modules/lodash/upperFirst.js | 22 + Bot/node_modules/lodash/util.js | 34 + Bot/node_modules/lodash/value.js | 1 + Bot/node_modules/lodash/valueOf.js | 1 + Bot/node_modules/lodash/values.js | 34 + Bot/node_modules/lodash/valuesIn.js | 32 + Bot/node_modules/lodash/without.js | 31 + Bot/node_modules/lodash/words.js | 35 + Bot/node_modules/lodash/wrap.js | 30 + Bot/node_modules/lodash/wrapperAt.js | 48 + Bot/node_modules/lodash/wrapperChain.js | 34 + Bot/node_modules/lodash/wrapperLodash.js | 147 + Bot/node_modules/lodash/wrapperReverse.js | 44 + Bot/node_modules/lodash/wrapperValue.js | 21 + Bot/node_modules/lodash/xor.js | 28 + Bot/node_modules/lodash/xorBy.js | 39 + Bot/node_modules/lodash/xorWith.js | 34 + Bot/node_modules/lodash/zip.js | 22 + Bot/node_modules/lodash/zipObject.js | 24 + Bot/node_modules/lodash/zipObjectDeep.js | 23 + Bot/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 + Bot/node_modules/magic-bytes.js/LICENSE | 21 + Bot/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 + Bot/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 + Bot/node_modules/magic-bytes.js/package.json | 72 + Bot/node_modules/magic-bytes.js/tsconfig.json | 78 + Bot/node_modules/mime-db/HISTORY.md | 507 + Bot/node_modules/mime-db/LICENSE | 23 + Bot/node_modules/mime-db/README.md | 100 + Bot/node_modules/mime-db/db.json | 8519 ++++++++ Bot/node_modules/mime-db/index.js | 12 + Bot/node_modules/mime-db/package.json | 60 + Bot/node_modules/mime-types/HISTORY.md | 397 + Bot/node_modules/mime-types/LICENSE | 23 + Bot/node_modules/mime-types/README.md | 113 + Bot/node_modules/mime-types/index.js | 188 + Bot/node_modules/mime-types/package.json | 44 + Bot/node_modules/proxy-from-env/.eslintrc | 29 + Bot/node_modules/proxy-from-env/.travis.yml | 10 + Bot/node_modules/proxy-from-env/LICENSE | 20 + Bot/node_modules/proxy-from-env/README.md | 131 + Bot/node_modules/proxy-from-env/index.js | 108 + Bot/node_modules/proxy-from-env/package.json | 34 + Bot/node_modules/proxy-from-env/test.js | 483 + Bot/node_modules/ts-mixer/CHANGELOG.md | 120 + Bot/node_modules/ts-mixer/LICENSE | 21 + Bot/node_modules/ts-mixer/README.md | 270 + .../ts-mixer/dist/cjs/decorator.js | 109 + Bot/node_modules/ts-mixer/dist/cjs/index.js | 12 + .../ts-mixer/dist/cjs/mixin-tracking.js | 42 + Bot/node_modules/ts-mixer/dist/cjs/mixins.js | 82 + Bot/node_modules/ts-mixer/dist/cjs/proxy.js | 82 + .../ts-mixer/dist/cjs/settings.js | 9 + Bot/node_modules/ts-mixer/dist/cjs/types.js | 2 + Bot/node_modules/ts-mixer/dist/cjs/util.js | 85 + .../ts-mixer/dist/esm/decorator.d.ts | 18 + Bot/node_modules/ts-mixer/dist/esm/index.d.ts | 4 + Bot/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 + Bot/node_modules/ts-mixer/dist/esm/proxy.d.ts | 16 + .../ts-mixer/dist/esm/settings.d.ts | 7 + Bot/node_modules/ts-mixer/dist/esm/types.d.ts | 13 + Bot/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 + Bot/node_modules/ts-mixer/package.json | 63 + Bot/node_modules/tslib/CopyrightNotice.txt | 15 + Bot/node_modules/tslib/LICENSE.txt | 12 + Bot/node_modules/tslib/README.md | 164 + Bot/node_modules/tslib/SECURITY.md | 41 + Bot/node_modules/tslib/modules/index.d.ts | 37 + Bot/node_modules/tslib/modules/index.js | 68 + Bot/node_modules/tslib/modules/package.json | 3 + Bot/node_modules/tslib/package.json | 47 + Bot/node_modules/tslib/tslib.d.ts | 453 + Bot/node_modules/tslib/tslib.es6.html | 1 + Bot/node_modules/tslib/tslib.es6.js | 370 + Bot/node_modules/tslib/tslib.es6.mjs | 370 + Bot/node_modules/tslib/tslib.html | 1 + Bot/node_modules/tslib/tslib.js | 421 + Bot/node_modules/undici-types/README.md | 6 + Bot/node_modules/undici-types/agent.d.ts | 31 + Bot/node_modules/undici-types/api.d.ts | 43 + .../undici-types/balanced-pool.d.ts | 18 + Bot/node_modules/undici-types/cache.d.ts | 36 + Bot/node_modules/undici-types/client.d.ts | 97 + Bot/node_modules/undici-types/connector.d.ts | 34 + .../undici-types/content-type.d.ts | 21 + Bot/node_modules/undici-types/cookies.d.ts | 28 + .../undici-types/diagnostics-channel.d.ts | 67 + Bot/node_modules/undici-types/dispatcher.d.ts | 241 + Bot/node_modules/undici-types/errors.d.ts | 128 + Bot/node_modules/undici-types/fetch.d.ts | 209 + Bot/node_modules/undici-types/file.d.ts | 39 + Bot/node_modules/undici-types/filereader.d.ts | 54 + Bot/node_modules/undici-types/formdata.d.ts | 108 + .../undici-types/global-dispatcher.d.ts | 9 + .../undici-types/global-origin.d.ts | 7 + Bot/node_modules/undici-types/handlers.d.ts | 9 + Bot/node_modules/undici-types/header.d.ts | 4 + Bot/node_modules/undici-types/index.d.ts | 63 + .../undici-types/interceptors.d.ts | 5 + Bot/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 + Bot/node_modules/undici-types/mock-pool.d.ts | 25 + Bot/node_modules/undici-types/package.json | 55 + Bot/node_modules/undici-types/patch.d.ts | 71 + Bot/node_modules/undici-types/pool-stats.d.ts | 19 + Bot/node_modules/undici-types/pool.d.ts | 28 + .../undici-types/proxy-agent.d.ts | 30 + Bot/node_modules/undici-types/readable.d.ts | 61 + Bot/node_modules/undici-types/webidl.d.ts | 220 + Bot/node_modules/undici-types/websocket.d.ts | 131 + Bot/node_modules/undici/LICENSE | 21 + Bot/node_modules/undici/README.md | 466 + .../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 | 1065 + .../undici/docs/docs/api/Errors.md | 48 + .../undici/docs/docs/api/EventSource.md | 21 + .../undici/docs/docs/api/Fetch.md | 57 + .../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 + Bot/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 | 114 + Bot/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 + Bot/node_modules/undici/index-fetch.js | 21 + Bot/node_modules/undici/index.d.ts | 3 + Bot/node_modules/undici/index.js | 165 + .../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 | 182 + Bot/node_modules/undici/lib/api/api-stream.js | 220 + .../undici/lib/api/api-upgrade.js | 108 + Bot/node_modules/undici/lib/api/index.js | 7 + Bot/node_modules/undici/lib/api/readable.js | 357 + Bot/node_modules/undici/lib/api/util.js | 86 + Bot/node_modules/undici/lib/core/connect.js | 193 + Bot/node_modules/undici/lib/core/constants.js | 118 + .../undici/lib/core/diagnostics.js | 202 + Bot/node_modules/undici/lib/core/errors.js | 231 + Bot/node_modules/undici/lib/core/request.js | 396 + Bot/node_modules/undici/lib/core/symbols.js | 64 + Bot/node_modules/undici/lib/core/tree.js | 152 + Bot/node_modules/undici/lib/core/util.js | 613 + .../undici/lib/dispatcher/agent.js | 129 + .../undici/lib/dispatcher/balanced-pool.js | 190 + .../undici/lib/dispatcher/client-h1.js | 1347 ++ .../undici/lib/dispatcher/client-h2.js | 695 + .../undici/lib/dispatcher/client.js | 615 + .../undici/lib/dispatcher/dispatcher-base.js | 192 + .../undici/lib/dispatcher/dispatcher.js | 65 + .../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 | 190 + .../undici/lib/dispatcher/retry-agent.js | 35 + Bot/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 | 350 + .../lib/interceptor/redirect-interceptor.js | 21 + .../undici/lib/interceptor/redirect.js | 24 + .../undici/lib/interceptor/retry.js | 19 + .../undici/lib/llhttp/constants.d.ts | 199 + .../undici/lib/llhttp/constants.js | 278 + .../undici/lib/llhttp/constants.js.map | 1 + .../undici/lib/llhttp/llhttp-wasm.js | 3 + .../undici/lib/llhttp/llhttp_simd-wasm.js | 3 + Bot/node_modules/undici/lib/llhttp/utils.d.ts | 4 + Bot/node_modules/undici/lib/llhttp/utils.js | 15 + .../undici/lib/llhttp/utils.js.map | 1 + .../undici/lib/llhttp/wasm_build_env.txt | 32 + .../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 + Bot/node_modules/undici/lib/mock/mock-pool.js | 59 + .../undici/lib/mock/mock-symbols.js | 23 + .../undici/lib/mock/mock-utils.js | 363 + .../mock/pending-interceptors-formatter.js | 43 + .../undici/lib/mock/pluralizer.js | 29 + Bot/node_modules/undici/lib/util/timers.js | 97 + .../undici/lib/web/cache/cache.js | 846 + .../undici/lib/web/cache/cachestorage.js | 144 + .../undici/lib/web/cache/symbols.js | 5 + Bot/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 | 307 + .../lib/web/eventsource/eventsource-stream.js | 398 + .../undici/lib/web/eventsource/eventsource.js | 480 + .../undici/lib/web/eventsource/util.js | 37 + Bot/node_modules/undici/lib/web/fetch/LICENSE | 21 + Bot/node_modules/undici/lib/web/fetch/body.js | 491 + .../undici/lib/web/fetch/constants.js | 115 + .../undici/lib/web/fetch/data-url.js | 743 + .../lib/web/fetch/dispatcher-weakref.js | 45 + Bot/node_modules/undici/lib/web/fetch/file.js | 337 + .../undici/lib/web/fetch/formdata-parser.js | 464 + .../undici/lib/web/fetch/formdata.js | 244 + .../undici/lib/web/fetch/global.js | 40 + .../undici/lib/web/fetch/headers.js | 625 + .../undici/lib/web/fetch/index.js | 2246 ++ .../undici/lib/web/fetch/request.js | 1022 + .../undici/lib/web/fetch/response.js | 607 + .../undici/lib/web/fetch/symbols.js | 11 + Bot/node_modules/undici/lib/web/fetch/util.js | 1617 ++ .../undici/lib/web/fetch/webidl.js | 680 + .../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 | 297 + .../undici/lib/web/websocket/constants.js | 58 + .../undici/lib/web/websocket/events.js | 303 + .../undici/lib/web/websocket/frame.js | 74 + .../undici/lib/web/websocket/receiver.js | 332 + .../undici/lib/web/websocket/symbols.js | 12 + .../undici/lib/web/websocket/util.js | 239 + .../undici/lib/web/websocket/websocket.js | 652 + Bot/node_modules/undici/package.json | 154 + .../undici/scripts/strip-comments.js | 8 + Bot/node_modules/undici/types/README.md | 6 + Bot/node_modules/undici/types/agent.d.ts | 31 + Bot/node_modules/undici/types/api.d.ts | 43 + .../undici/types/balanced-pool.d.ts | 29 + Bot/node_modules/undici/types/cache.d.ts | 36 + Bot/node_modules/undici/types/client.d.ts | 108 + Bot/node_modules/undici/types/connector.d.ts | 34 + .../undici/types/content-type.d.ts | 21 + Bot/node_modules/undici/types/cookies.d.ts | 28 + .../undici/types/diagnostics-channel.d.ts | 66 + Bot/node_modules/undici/types/dispatcher.d.ts | 255 + Bot/node_modules/undici/types/errors.d.ts | 128 + .../undici/types/eventsource.d.ts | 61 + Bot/node_modules/undici/types/fetch.d.ts | 208 + Bot/node_modules/undici/types/file.d.ts | 39 + Bot/node_modules/undici/types/filereader.d.ts | 54 + Bot/node_modules/undici/types/formdata.d.ts | 108 + .../undici/types/global-dispatcher.d.ts | 9 + .../undici/types/global-origin.d.ts | 7 + Bot/node_modules/undici/types/handlers.d.ts | 15 + Bot/node_modules/undici/types/header.d.ts | 4 + Bot/node_modules/undici/types/index.d.ts | 68 + .../undici/types/interceptors.d.ts | 5 + Bot/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 + Bot/node_modules/undici/types/mock-pool.d.ts | 25 + Bot/node_modules/undici/types/patch.d.ts | 71 + Bot/node_modules/undici/types/pool-stats.d.ts | 19 + Bot/node_modules/undici/types/pool.d.ts | 39 + .../undici/types/proxy-agent.d.ts | 28 + Bot/node_modules/undici/types/readable.d.ts | 60 + .../undici/types/retry-agent.d.ts | 11 + .../undici/types/retry-handler.d.ts | 116 + Bot/node_modules/undici/types/util.d.ts | 31 + Bot/node_modules/undici/types/webidl.d.ts | 225 + Bot/node_modules/undici/types/websocket.d.ts | 152 + Bot/node_modules/ws/LICENSE | 20 + Bot/node_modules/ws/README.md | 548 + Bot/node_modules/ws/browser.js | 8 + Bot/node_modules/ws/index.js | 13 + Bot/node_modules/ws/lib/buffer-util.js | 131 + Bot/node_modules/ws/lib/constants.js | 12 + Bot/node_modules/ws/lib/event-target.js | 292 + Bot/node_modules/ws/lib/extension.js | 203 + Bot/node_modules/ws/lib/limiter.js | 55 + Bot/node_modules/ws/lib/permessage-deflate.js | 514 + Bot/node_modules/ws/lib/receiver.js | 704 + Bot/node_modules/ws/lib/sender.js | 477 + Bot/node_modules/ws/lib/stream.js | 159 + Bot/node_modules/ws/lib/subprotocol.js | 62 + Bot/node_modules/ws/lib/validation.js | 130 + Bot/node_modules/ws/lib/websocket-server.js | 539 + Bot/node_modules/ws/lib/websocket.js | 1336 ++ Bot/node_modules/ws/package.json | 69 + Bot/node_modules/ws/wrapper.mjs | 8 + Bot/package-lock.json | 408 + Bot/package.json | 15 + 3073 files changed, 342012 insertions(+) create mode 100644 Bot/config.json create mode 100644 Bot/index.js create mode 100644 Bot/index_with_comments.js create mode 100644 Bot/node_modules/.package-lock.json create mode 100644 Bot/node_modules/.register-scheme-CCeiTIjy/build/Release/register-protocol-handler.node create mode 100644 Bot/node_modules/@discordjs/builders/LICENSE create mode 100644 Bot/node_modules/@discordjs/builders/README.md create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.js create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/builders/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/builders/package.json create mode 100644 Bot/node_modules/@discordjs/collection/CHANGELOG.md create mode 100644 Bot/node_modules/@discordjs/collection/LICENSE create mode 100644 Bot/node_modules/@discordjs/collection/README.md create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.js create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/collection/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/collection/package.json create mode 100644 Bot/node_modules/@discordjs/formatters/LICENSE create mode 100644 Bot/node_modules/@discordjs/formatters/README.md create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.js create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/formatters/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/formatters/package.json create mode 100644 Bot/node_modules/@discordjs/rest/LICENSE create mode 100644 Bot/node_modules/@discordjs/rest/README.md create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.js create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/rest/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.d.mts create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.d.ts create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.js create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.js.map create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.mjs create mode 100644 Bot/node_modules/@discordjs/rest/dist/strategies/undiciRequest.mjs.map create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.d.mts create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.d.ts create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.js create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.js.map create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.mjs create mode 100644 Bot/node_modules/@discordjs/rest/dist/web.mjs.map create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/LICENSE create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/README.md create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.js create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/rest/node_modules/@discordjs/collection/package.json create mode 100644 Bot/node_modules/@discordjs/rest/package.json create mode 100644 Bot/node_modules/@discordjs/util/LICENSE create mode 100644 Bot/node_modules/@discordjs/util/README.md create mode 100644 Bot/node_modules/@discordjs/util/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/util/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/util/dist/index.js create mode 100644 Bot/node_modules/@discordjs/util/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/util/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/util/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/util/package.json create mode 100644 Bot/node_modules/@discordjs/ws/LICENSE create mode 100644 Bot/node_modules/@discordjs/ws/README.md create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.d.mts create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.d.ts create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.js create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.js.map create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.mjs create mode 100644 Bot/node_modules/@discordjs/ws/dist/defaultWorker.mjs.map create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.js create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/ws/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/LICENSE create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/README.md create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.d.mts create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.d.ts create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.js create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.js.map create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.mjs create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/dist/index.mjs.map create mode 100644 Bot/node_modules/@discordjs/ws/node_modules/@discordjs/collection/package.json create mode 100644 Bot/node_modules/@discordjs/ws/package.json create mode 100644 Bot/node_modules/@sapphire/async-queue/CHANGELOG.md create mode 100644 Bot/node_modules/@sapphire/async-queue/README.md create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/cjs/index.cjs create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/cjs/index.cjs.map create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/cjs/index.d.cts create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/esm/index.d.mts create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/esm/index.mjs create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/esm/index.mjs.map create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/iife/index.global.js create mode 100644 Bot/node_modules/@sapphire/async-queue/dist/iife/index.global.js.map create mode 100644 Bot/node_modules/@sapphire/async-queue/package.json create mode 100644 Bot/node_modules/@sapphire/shapeshift/CHANGELOG.md create mode 100644 Bot/node_modules/@sapphire/shapeshift/LICENSE.md create mode 100644 Bot/node_modules/@sapphire/shapeshift/README.md create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/cjs/index.cjs create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/cjs/index.cjs.map create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/cjs/index.d.cts create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/esm/index.d.mts create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/esm/index.mjs create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/esm/index.mjs.map create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/iife/index.global.js create mode 100644 Bot/node_modules/@sapphire/shapeshift/dist/iife/index.global.js.map create mode 100644 Bot/node_modules/@sapphire/shapeshift/package.json create mode 100644 Bot/node_modules/@sapphire/snowflake/CHANGELOG.md create mode 100644 Bot/node_modules/@sapphire/snowflake/README.md create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/cjs/index.cjs create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/cjs/index.cjs.map create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/cjs/index.d.cts create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/esm/index.d.mts create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/esm/index.mjs create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/esm/index.mjs.map create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/iife/index.global.js create mode 100644 Bot/node_modules/@sapphire/snowflake/dist/iife/index.global.js.map create mode 100644 Bot/node_modules/@sapphire/snowflake/package.json create mode 100644 Bot/node_modules/@types/node/LICENSE create mode 100644 Bot/node_modules/@types/node/README.md create mode 100644 Bot/node_modules/@types/node/assert.d.ts create mode 100644 Bot/node_modules/@types/node/assert/strict.d.ts create mode 100644 Bot/node_modules/@types/node/async_hooks.d.ts create mode 100644 Bot/node_modules/@types/node/buffer.d.ts create mode 100644 Bot/node_modules/@types/node/child_process.d.ts create mode 100644 Bot/node_modules/@types/node/cluster.d.ts create mode 100644 Bot/node_modules/@types/node/console.d.ts create mode 100644 Bot/node_modules/@types/node/constants.d.ts create mode 100644 Bot/node_modules/@types/node/crypto.d.ts create mode 100644 Bot/node_modules/@types/node/dgram.d.ts create mode 100644 Bot/node_modules/@types/node/diagnostics_channel.d.ts create mode 100644 Bot/node_modules/@types/node/dns.d.ts create mode 100644 Bot/node_modules/@types/node/dns/promises.d.ts create mode 100644 Bot/node_modules/@types/node/dom-events.d.ts create mode 100644 Bot/node_modules/@types/node/domain.d.ts create mode 100644 Bot/node_modules/@types/node/events.d.ts create mode 100644 Bot/node_modules/@types/node/fs.d.ts create mode 100644 Bot/node_modules/@types/node/fs/promises.d.ts create mode 100644 Bot/node_modules/@types/node/globals.d.ts create mode 100644 Bot/node_modules/@types/node/globals.global.d.ts create mode 100644 Bot/node_modules/@types/node/http.d.ts create mode 100644 Bot/node_modules/@types/node/http2.d.ts create mode 100644 Bot/node_modules/@types/node/https.d.ts create mode 100644 Bot/node_modules/@types/node/index.d.ts create mode 100644 Bot/node_modules/@types/node/inspector.d.ts create mode 100644 Bot/node_modules/@types/node/module.d.ts create mode 100644 Bot/node_modules/@types/node/net.d.ts create mode 100644 Bot/node_modules/@types/node/os.d.ts create mode 100644 Bot/node_modules/@types/node/package.json create mode 100644 Bot/node_modules/@types/node/path.d.ts create mode 100644 Bot/node_modules/@types/node/perf_hooks.d.ts create mode 100644 Bot/node_modules/@types/node/process.d.ts create mode 100644 Bot/node_modules/@types/node/punycode.d.ts create mode 100644 Bot/node_modules/@types/node/querystring.d.ts create mode 100644 Bot/node_modules/@types/node/readline.d.ts create mode 100644 Bot/node_modules/@types/node/readline/promises.d.ts create mode 100644 Bot/node_modules/@types/node/repl.d.ts create mode 100644 Bot/node_modules/@types/node/sea.d.ts create mode 100644 Bot/node_modules/@types/node/stream.d.ts create mode 100644 Bot/node_modules/@types/node/stream/consumers.d.ts create mode 100644 Bot/node_modules/@types/node/stream/promises.d.ts create mode 100644 Bot/node_modules/@types/node/stream/web.d.ts create mode 100644 Bot/node_modules/@types/node/string_decoder.d.ts create mode 100644 Bot/node_modules/@types/node/test.d.ts create mode 100644 Bot/node_modules/@types/node/timers.d.ts create mode 100644 Bot/node_modules/@types/node/timers/promises.d.ts create mode 100644 Bot/node_modules/@types/node/tls.d.ts create mode 100644 Bot/node_modules/@types/node/trace_events.d.ts create mode 100644 Bot/node_modules/@types/node/tty.d.ts create mode 100644 Bot/node_modules/@types/node/url.d.ts create mode 100644 Bot/node_modules/@types/node/util.d.ts create mode 100644 Bot/node_modules/@types/node/v8.d.ts create mode 100644 Bot/node_modules/@types/node/vm.d.ts create mode 100644 Bot/node_modules/@types/node/wasi.d.ts create mode 100644 Bot/node_modules/@types/node/worker_threads.d.ts create mode 100644 Bot/node_modules/@types/node/zlib.d.ts create mode 100644 Bot/node_modules/@types/ws/LICENSE create mode 100644 Bot/node_modules/@types/ws/README.md create mode 100644 Bot/node_modules/@types/ws/index.d.mts create mode 100644 Bot/node_modules/@types/ws/index.d.ts create mode 100644 Bot/node_modules/@types/ws/package.json create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/CHANGELOG.md create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/LICENSE.md create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/README.md create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/THIRD_PARTY_LICENSE.md create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.cjs create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.cjs.map create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.d.mts create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.d.ts create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.global.js create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.global.js.map create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.mjs create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/dist/index.mjs.map create mode 100644 Bot/node_modules/@vladfrangu/async_event_emitter/package.json create mode 100644 Bot/node_modules/asynckit/LICENSE create mode 100644 Bot/node_modules/asynckit/README.md create mode 100644 Bot/node_modules/asynckit/bench.js create mode 100644 Bot/node_modules/asynckit/index.js create mode 100644 Bot/node_modules/asynckit/lib/abort.js create mode 100644 Bot/node_modules/asynckit/lib/async.js create mode 100644 Bot/node_modules/asynckit/lib/defer.js create mode 100644 Bot/node_modules/asynckit/lib/iterate.js create mode 100644 Bot/node_modules/asynckit/lib/readable_asynckit.js create mode 100644 Bot/node_modules/asynckit/lib/readable_parallel.js create mode 100644 Bot/node_modules/asynckit/lib/readable_serial.js create mode 100644 Bot/node_modules/asynckit/lib/readable_serial_ordered.js create mode 100644 Bot/node_modules/asynckit/lib/state.js create mode 100644 Bot/node_modules/asynckit/lib/streamify.js create mode 100644 Bot/node_modules/asynckit/lib/terminator.js create mode 100644 Bot/node_modules/asynckit/package.json create mode 100644 Bot/node_modules/asynckit/parallel.js create mode 100644 Bot/node_modules/asynckit/serial.js create mode 100644 Bot/node_modules/asynckit/serialOrdered.js create mode 100644 Bot/node_modules/asynckit/stream.js create mode 100644 Bot/node_modules/axios/CHANGELOG.md create mode 100644 Bot/node_modules/axios/LICENSE create mode 100644 Bot/node_modules/axios/MIGRATION_GUIDE.md create mode 100644 Bot/node_modules/axios/README.md create mode 100644 Bot/node_modules/axios/SECURITY.md create mode 100644 Bot/node_modules/axios/dist/axios.js create mode 100644 Bot/node_modules/axios/dist/axios.js.map create mode 100644 Bot/node_modules/axios/dist/axios.min.js create mode 100644 Bot/node_modules/axios/dist/axios.min.js.map create mode 100644 Bot/node_modules/axios/dist/browser/axios.cjs create mode 100644 Bot/node_modules/axios/dist/browser/axios.cjs.map create mode 100644 Bot/node_modules/axios/dist/esm/axios.js create mode 100644 Bot/node_modules/axios/dist/esm/axios.js.map create mode 100644 Bot/node_modules/axios/dist/esm/axios.min.js create mode 100644 Bot/node_modules/axios/dist/esm/axios.min.js.map create mode 100644 Bot/node_modules/axios/dist/node/axios.cjs create mode 100644 Bot/node_modules/axios/dist/node/axios.cjs.map create mode 100644 Bot/node_modules/axios/index.d.cts create mode 100644 Bot/node_modules/axios/index.d.ts create mode 100644 Bot/node_modules/axios/index.js create mode 100644 Bot/node_modules/axios/lib/adapters/README.md create mode 100644 Bot/node_modules/axios/lib/adapters/adapters.js create mode 100644 Bot/node_modules/axios/lib/adapters/fetch.js create mode 100644 Bot/node_modules/axios/lib/adapters/http.js create mode 100644 Bot/node_modules/axios/lib/adapters/xhr.js create mode 100644 Bot/node_modules/axios/lib/axios.js create mode 100644 Bot/node_modules/axios/lib/cancel/CancelToken.js create mode 100644 Bot/node_modules/axios/lib/cancel/CanceledError.js create mode 100644 Bot/node_modules/axios/lib/cancel/isCancel.js create mode 100644 Bot/node_modules/axios/lib/core/Axios.js create mode 100644 Bot/node_modules/axios/lib/core/AxiosError.js create mode 100644 Bot/node_modules/axios/lib/core/AxiosHeaders.js create mode 100644 Bot/node_modules/axios/lib/core/InterceptorManager.js create mode 100644 Bot/node_modules/axios/lib/core/README.md create mode 100644 Bot/node_modules/axios/lib/core/buildFullPath.js create mode 100644 Bot/node_modules/axios/lib/core/dispatchRequest.js create mode 100644 Bot/node_modules/axios/lib/core/mergeConfig.js create mode 100644 Bot/node_modules/axios/lib/core/settle.js create mode 100644 Bot/node_modules/axios/lib/core/transformData.js create mode 100644 Bot/node_modules/axios/lib/defaults/index.js create mode 100644 Bot/node_modules/axios/lib/defaults/transitional.js create mode 100644 Bot/node_modules/axios/lib/env/README.md create mode 100644 Bot/node_modules/axios/lib/env/classes/FormData.js create mode 100644 Bot/node_modules/axios/lib/env/data.js create mode 100644 Bot/node_modules/axios/lib/helpers/AxiosTransformStream.js create mode 100644 Bot/node_modules/axios/lib/helpers/AxiosURLSearchParams.js create mode 100644 Bot/node_modules/axios/lib/helpers/HttpStatusCode.js create mode 100644 Bot/node_modules/axios/lib/helpers/README.md create mode 100644 Bot/node_modules/axios/lib/helpers/ZlibHeaderTransformStream.js create mode 100644 Bot/node_modules/axios/lib/helpers/bind.js create mode 100644 Bot/node_modules/axios/lib/helpers/buildURL.js create mode 100644 Bot/node_modules/axios/lib/helpers/callbackify.js create mode 100644 Bot/node_modules/axios/lib/helpers/combineURLs.js create mode 100644 Bot/node_modules/axios/lib/helpers/composeSignals.js create mode 100644 Bot/node_modules/axios/lib/helpers/cookies.js create mode 100644 Bot/node_modules/axios/lib/helpers/deprecatedMethod.js create mode 100644 Bot/node_modules/axios/lib/helpers/formDataToJSON.js create mode 100644 Bot/node_modules/axios/lib/helpers/formDataToStream.js create mode 100644 Bot/node_modules/axios/lib/helpers/fromDataURI.js create mode 100644 Bot/node_modules/axios/lib/helpers/isAbsoluteURL.js create mode 100644 Bot/node_modules/axios/lib/helpers/isAxiosError.js create mode 100644 Bot/node_modules/axios/lib/helpers/isURLSameOrigin.js create mode 100644 Bot/node_modules/axios/lib/helpers/null.js create mode 100644 Bot/node_modules/axios/lib/helpers/parseHeaders.js create mode 100644 Bot/node_modules/axios/lib/helpers/parseProtocol.js create mode 100644 Bot/node_modules/axios/lib/helpers/progressEventReducer.js create mode 100644 Bot/node_modules/axios/lib/helpers/readBlob.js create mode 100644 Bot/node_modules/axios/lib/helpers/resolveConfig.js create mode 100644 Bot/node_modules/axios/lib/helpers/speedometer.js create mode 100644 Bot/node_modules/axios/lib/helpers/spread.js create mode 100644 Bot/node_modules/axios/lib/helpers/throttle.js create mode 100644 Bot/node_modules/axios/lib/helpers/toFormData.js create mode 100644 Bot/node_modules/axios/lib/helpers/toURLEncodedForm.js create mode 100644 Bot/node_modules/axios/lib/helpers/trackStream.js create mode 100644 Bot/node_modules/axios/lib/helpers/validator.js create mode 100644 Bot/node_modules/axios/lib/platform/browser/classes/Blob.js create mode 100644 Bot/node_modules/axios/lib/platform/browser/classes/FormData.js create mode 100644 Bot/node_modules/axios/lib/platform/browser/classes/URLSearchParams.js create mode 100644 Bot/node_modules/axios/lib/platform/browser/index.js create mode 100644 Bot/node_modules/axios/lib/platform/common/utils.js create mode 100644 Bot/node_modules/axios/lib/platform/index.js create mode 100644 Bot/node_modules/axios/lib/platform/node/classes/FormData.js create mode 100644 Bot/node_modules/axios/lib/platform/node/classes/URLSearchParams.js create mode 100644 Bot/node_modules/axios/lib/platform/node/index.js create mode 100644 Bot/node_modules/axios/lib/utils.js create mode 100644 Bot/node_modules/axios/package.json create mode 100644 Bot/node_modules/combined-stream/License create mode 100644 Bot/node_modules/combined-stream/Readme.md create mode 100644 Bot/node_modules/combined-stream/lib/combined_stream.js create mode 100644 Bot/node_modules/combined-stream/package.json create mode 100644 Bot/node_modules/combined-stream/yarn.lock create mode 100644 Bot/node_modules/delayed-stream/.npmignore create mode 100644 Bot/node_modules/delayed-stream/License create mode 100644 Bot/node_modules/delayed-stream/Makefile create mode 100644 Bot/node_modules/delayed-stream/Readme.md create mode 100644 Bot/node_modules/delayed-stream/lib/delayed_stream.js create mode 100644 Bot/node_modules/delayed-stream/package.json create mode 100644 Bot/node_modules/discord-api-types/LICENSE create mode 100644 Bot/node_modules/discord-api-types/README.md create mode 100644 Bot/node_modules/discord-api-types/gateway/common.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/common.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/common.js create mode 100644 Bot/node_modules/discord-api-types/gateway/common.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/index.js create mode 100644 Bot/node_modules/discord-api-types/gateway/index.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/index.mjs create mode 100644 Bot/node_modules/discord-api-types/gateway/v10.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/v10.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v10.js create mode 100644 Bot/node_modules/discord-api-types/gateway/v10.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v10.mjs create mode 100644 Bot/node_modules/discord-api-types/gateway/v6.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/v6.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v6.js create mode 100644 Bot/node_modules/discord-api-types/gateway/v6.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v6.mjs create mode 100644 Bot/node_modules/discord-api-types/gateway/v8.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/v8.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v8.js create mode 100644 Bot/node_modules/discord-api-types/gateway/v8.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v8.mjs create mode 100644 Bot/node_modules/discord-api-types/gateway/v9.d.ts create mode 100644 Bot/node_modules/discord-api-types/gateway/v9.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v9.js create mode 100644 Bot/node_modules/discord-api-types/gateway/v9.js.map create mode 100644 Bot/node_modules/discord-api-types/gateway/v9.mjs create mode 100644 Bot/node_modules/discord-api-types/globals.d.ts create mode 100644 Bot/node_modules/discord-api-types/globals.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/globals.js create mode 100644 Bot/node_modules/discord-api-types/globals.js.map create mode 100644 Bot/node_modules/discord-api-types/globals.mjs create mode 100644 Bot/node_modules/discord-api-types/package.json create mode 100644 Bot/node_modules/discord-api-types/payloads/common.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/common.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/common.js create mode 100644 Bot/node_modules/discord-api-types/payloads/common.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/index.js create mode 100644 Bot/node_modules/discord-api-types/payloads/index.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/index.mjs create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/chatInput.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/internals.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/_applicationCommands/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/applicationCommands.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/autocomplete.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/messageComponents.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/modalSubmit.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/ping.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/ping.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/ping.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/ping.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/responses.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/responses.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/responses.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/_interactions/responses.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/application.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/application.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/application.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/application.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/autoModeration.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/autoModeration.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/autoModeration.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/autoModeration.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/emoji.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/gateway.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guild.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/index.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/index.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/index.mjs create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/interactions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/invite.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/monetization.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/monetization.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/monetization.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/monetization.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/poll.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/poll.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/poll.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/poll.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/sticker.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/teams.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/teams.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/teams.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/teams.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/template.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/template.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/voice.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/webhook.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v10/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/emoji.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/gateway.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/guild.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/index.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/index.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/index.mjs create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/invite.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/teams.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/teams.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/teams.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/teams.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/voice.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/webhook.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v6/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/chatInput.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/internals.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/_applicationCommands/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/applicationCommands.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/autocomplete.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/messageComponents.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/modalSubmit.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/ping.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/ping.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/ping.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/ping.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/responses.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/responses.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/responses.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/_interactions/responses.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/application.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/application.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/application.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/application.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/emoji.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/gateway.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guild.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/index.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/index.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/index.mjs create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/interactions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/invite.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/sticker.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/teams.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/teams.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/teams.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/teams.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/template.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/template.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/voice.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/webhook.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v8/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/attachment.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/boolean.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/integer.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/mentionable.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/number.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/role.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/shared.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/string.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommand.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/subcommandGroup.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/_chatInput/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/chatInput.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/contextMenu.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/internals.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/_applicationCommands/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/applicationCommands.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/autocomplete.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/base.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/base.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/base.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/base.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/messageComponents.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/modalSubmit.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/ping.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/ping.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/ping.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/ping.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/responses.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/responses.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/responses.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/_interactions/responses.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/application.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/application.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/application.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/application.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/autoModeration.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/autoModeration.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/autoModeration.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/autoModeration.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/channel.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/emoji.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/gateway.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guild.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/index.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/index.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/index.mjs create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/interactions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/invite.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/monetization.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/monetization.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/monetization.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/monetization.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/permissions.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/permissions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/permissions.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/permissions.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/poll.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/poll.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/poll.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/poll.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/sticker.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/teams.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/teams.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/teams.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/teams.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/template.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/template.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/user.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/user.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/voice.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/webhook.js create mode 100644 Bot/node_modules/discord-api-types/payloads/v9/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/common.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/common.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/common.js create mode 100644 Bot/node_modules/discord-api-types/rest/common.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/index.js create mode 100644 Bot/node_modules/discord-api-types/rest/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rest/v10/application.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/application.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/application.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/application.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/autoModeration.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/autoModeration.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/autoModeration.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/autoModeration.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/channel.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/emoji.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/gateway.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guild.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/index.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rest/v10/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/interactions.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/invite.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/monetization.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/monetization.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/monetization.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/monetization.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/poll.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/poll.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/poll.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/poll.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/sticker.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/template.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/template.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/user.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/user.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/voice.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v10/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v10/webhook.js create mode 100644 Bot/node_modules/discord-api-types/rest/v10/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/channel.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/emoji.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/gateway.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/guild.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/index.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rest/v6/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/invite.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/user.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/user.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/voice.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v6/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v6/webhook.js create mode 100644 Bot/node_modules/discord-api-types/rest/v6/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/channel.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/emoji.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/gateway.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guild.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/index.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rest/v8/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/interactions.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/invite.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/sticker.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/template.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/template.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/user.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/user.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/voice.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v8/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v8/webhook.js create mode 100644 Bot/node_modules/discord-api-types/rest/v8/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/application.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/application.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/application.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/application.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/auditLog.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/auditLog.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/auditLog.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/auditLog.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/autoModeration.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/autoModeration.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/autoModeration.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/autoModeration.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/channel.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/channel.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/channel.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/channel.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/emoji.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/emoji.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/emoji.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/emoji.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/gateway.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/gateway.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/gateway.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/gateway.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guild.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guild.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guild.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guild.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guildScheduledEvent.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guildScheduledEvent.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guildScheduledEvent.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/guildScheduledEvent.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/index.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rest/v9/interactions.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/interactions.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/interactions.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/interactions.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/invite.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/invite.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/invite.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/invite.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/monetization.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/monetization.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/monetization.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/monetization.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/oauth2.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/oauth2.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/oauth2.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/oauth2.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/poll.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/poll.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/poll.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/poll.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/stageInstance.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/stageInstance.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/stageInstance.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/stageInstance.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/sticker.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/sticker.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/sticker.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/sticker.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/template.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/template.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/template.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/template.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/user.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/user.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/user.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/user.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/voice.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/voice.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/voice.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/voice.js.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/webhook.d.ts create mode 100644 Bot/node_modules/discord-api-types/rest/v9/webhook.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rest/v9/webhook.js create mode 100644 Bot/node_modules/discord-api-types/rest/v9/webhook.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/common.d.ts create mode 100644 Bot/node_modules/discord-api-types/rpc/common.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rpc/common.js create mode 100644 Bot/node_modules/discord-api-types/rpc/common.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/rpc/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rpc/index.js create mode 100644 Bot/node_modules/discord-api-types/rpc/index.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/index.mjs create mode 100644 Bot/node_modules/discord-api-types/rpc/v10.d.ts create mode 100644 Bot/node_modules/discord-api-types/rpc/v10.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v10.js create mode 100644 Bot/node_modules/discord-api-types/rpc/v10.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v10.mjs create mode 100644 Bot/node_modules/discord-api-types/rpc/v8.d.ts create mode 100644 Bot/node_modules/discord-api-types/rpc/v8.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v8.js create mode 100644 Bot/node_modules/discord-api-types/rpc/v8.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v8.mjs create mode 100644 Bot/node_modules/discord-api-types/rpc/v9.d.ts create mode 100644 Bot/node_modules/discord-api-types/rpc/v9.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v9.js create mode 100644 Bot/node_modules/discord-api-types/rpc/v9.js.map create mode 100644 Bot/node_modules/discord-api-types/rpc/v9.mjs create mode 100644 Bot/node_modules/discord-api-types/utils/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/utils/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/utils/index.js create mode 100644 Bot/node_modules/discord-api-types/utils/index.js.map create mode 100644 Bot/node_modules/discord-api-types/utils/index.mjs create mode 100644 Bot/node_modules/discord-api-types/utils/internals.d.ts create mode 100644 Bot/node_modules/discord-api-types/utils/internals.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/utils/internals.js create mode 100644 Bot/node_modules/discord-api-types/utils/internals.js.map create mode 100644 Bot/node_modules/discord-api-types/utils/v10.d.ts create mode 100644 Bot/node_modules/discord-api-types/utils/v10.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/utils/v10.js create mode 100644 Bot/node_modules/discord-api-types/utils/v10.js.map create mode 100644 Bot/node_modules/discord-api-types/utils/v10.mjs create mode 100644 Bot/node_modules/discord-api-types/utils/v8.d.ts create mode 100644 Bot/node_modules/discord-api-types/utils/v8.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/utils/v8.js create mode 100644 Bot/node_modules/discord-api-types/utils/v8.js.map create mode 100644 Bot/node_modules/discord-api-types/utils/v8.mjs create mode 100644 Bot/node_modules/discord-api-types/utils/v9.d.ts create mode 100644 Bot/node_modules/discord-api-types/utils/v9.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/utils/v9.js create mode 100644 Bot/node_modules/discord-api-types/utils/v9.js.map create mode 100644 Bot/node_modules/discord-api-types/utils/v9.mjs create mode 100644 Bot/node_modules/discord-api-types/v10.d.ts create mode 100644 Bot/node_modules/discord-api-types/v10.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/v10.js create mode 100644 Bot/node_modules/discord-api-types/v10.js.map create mode 100644 Bot/node_modules/discord-api-types/v10.mjs create mode 100644 Bot/node_modules/discord-api-types/v6.d.ts create mode 100644 Bot/node_modules/discord-api-types/v6.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/v6.js create mode 100644 Bot/node_modules/discord-api-types/v6.js.map create mode 100644 Bot/node_modules/discord-api-types/v6.mjs create mode 100644 Bot/node_modules/discord-api-types/v8.d.ts create mode 100644 Bot/node_modules/discord-api-types/v8.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/v8.js create mode 100644 Bot/node_modules/discord-api-types/v8.js.map create mode 100644 Bot/node_modules/discord-api-types/v8.mjs create mode 100644 Bot/node_modules/discord-api-types/v9.d.ts create mode 100644 Bot/node_modules/discord-api-types/v9.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/v9.js create mode 100644 Bot/node_modules/discord-api-types/v9.js.map create mode 100644 Bot/node_modules/discord-api-types/v9.mjs create mode 100644 Bot/node_modules/discord-api-types/voice/index.d.ts create mode 100644 Bot/node_modules/discord-api-types/voice/index.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/voice/index.js create mode 100644 Bot/node_modules/discord-api-types/voice/index.js.map create mode 100644 Bot/node_modules/discord-api-types/voice/index.mjs create mode 100644 Bot/node_modules/discord-api-types/voice/v4.d.ts create mode 100644 Bot/node_modules/discord-api-types/voice/v4.d.ts.map create mode 100644 Bot/node_modules/discord-api-types/voice/v4.js create mode 100644 Bot/node_modules/discord-api-types/voice/v4.js.map create mode 100644 Bot/node_modules/discord-api-types/voice/v4.mjs create mode 100644 Bot/node_modules/discord.js/LICENSE create mode 100644 Bot/node_modules/discord.js/README.md create mode 100644 Bot/node_modules/discord.js/package.json create mode 100644 Bot/node_modules/discord.js/src/client/BaseClient.js create mode 100644 Bot/node_modules/discord.js/src/client/Client.js create mode 100644 Bot/node_modules/discord.js/src/client/WebhookClient.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/Action.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ActionsManager.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ApplicationCommandPermissionsUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/AutoModerationActionExecution.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/AutoModerationRuleCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/AutoModerationRuleDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/AutoModerationRuleUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ChannelCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ChannelDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ChannelUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/EntitlementCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/EntitlementDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/EntitlementUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildAuditLogEntryCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildBanAdd.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildBanRemove.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildChannelsPositionUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildEmojiCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildEmojiDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildEmojiUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildEmojisUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildIntegrationsUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildMemberRemove.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildMemberUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildRoleCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildRoleDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildRoleUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildRolesPositionUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildScheduledEventCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildScheduledEventDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildScheduledEventUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildScheduledEventUserAdd.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildScheduledEventUserRemove.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildStickerCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildStickerDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildStickerUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildStickersUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/GuildUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/InteractionCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/InviteCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/InviteDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageDeleteBulk.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessagePollVoteAdd.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessagePollVoteRemove.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageReactionAdd.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageReactionRemove.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageReactionRemoveAll.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageReactionRemoveEmoji.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/MessageUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/PresenceUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/StageInstanceCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/StageInstanceDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/StageInstanceUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ThreadCreate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ThreadDelete.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ThreadListSync.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ThreadMemberUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/ThreadMembersUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/TypingStart.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/UserUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/VoiceStateUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/actions/WebhooksUpdate.js create mode 100644 Bot/node_modules/discord.js/src/client/voice/ClientVoiceManager.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/WebSocketManager.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/WebSocketShard.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/CHANNEL_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/ENTITLEMENT_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_BAN_ADD.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_BAN_REMOVE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_ADD.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/GUILD_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/INTERACTION_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/INVITE_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/INVITE_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/MESSAGE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/PRESENCE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/READY.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/RESUMED.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_CREATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_DELETE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_LIST_SYNC.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/THREAD_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/TYPING_START.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/USER_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/VOICE_STATE_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/WEBHOOKS_UPDATE.js create mode 100644 Bot/node_modules/discord.js/src/client/websocket/handlers/index.js create mode 100644 Bot/node_modules/discord.js/src/errors/DJSError.js create mode 100644 Bot/node_modules/discord.js/src/errors/ErrorCodes.js create mode 100644 Bot/node_modules/discord.js/src/errors/Messages.js create mode 100644 Bot/node_modules/discord.js/src/errors/index.js create mode 100644 Bot/node_modules/discord.js/src/index.js create mode 100644 Bot/node_modules/discord.js/src/managers/ApplicationCommandManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ApplicationCommandPermissionsManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/AutoModerationRuleManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/BaseGuildEmojiManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/BaseManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/CachedManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/CategoryChannelChildManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ChannelManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/DMMessageManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/DataManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/EntitlementManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildApplicationCommandManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildBanManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildChannelManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildEmojiManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildEmojiRoleManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildForumThreadManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildInviteManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildMemberManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildMemberRoleManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildMessageManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildScheduledEventManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildStickerManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/GuildTextThreadManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/MessageManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/PermissionOverwriteManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/PresenceManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ReactionManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ReactionUserManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/RoleManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/StageInstanceManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ThreadManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/ThreadMemberManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/UserManager.js create mode 100644 Bot/node_modules/discord.js/src/managers/VoiceStateManager.js create mode 100644 Bot/node_modules/discord.js/src/sharding/Shard.js create mode 100644 Bot/node_modules/discord.js/src/sharding/ShardClientUtil.js create mode 100644 Bot/node_modules/discord.js/src/sharding/ShardingManager.js create mode 100644 Bot/node_modules/discord.js/src/structures/ActionRow.js create mode 100644 Bot/node_modules/discord.js/src/structures/ActionRowBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/AnonymousGuild.js create mode 100644 Bot/node_modules/discord.js/src/structures/ApplicationCommand.js create mode 100644 Bot/node_modules/discord.js/src/structures/ApplicationRoleConnectionMetadata.js create mode 100644 Bot/node_modules/discord.js/src/structures/Attachment.js create mode 100644 Bot/node_modules/discord.js/src/structures/AttachmentBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/AutoModerationActionExecution.js create mode 100644 Bot/node_modules/discord.js/src/structures/AutoModerationRule.js create mode 100644 Bot/node_modules/discord.js/src/structures/AutocompleteInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/Base.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseGuild.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseGuildEmoji.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseGuildTextChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseGuildVoiceChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/BaseSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/ButtonBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/ButtonComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/ButtonInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/CategoryChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/ChannelSelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/ChannelSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/ChannelSelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/ChatInputCommandInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/ClientApplication.js create mode 100644 Bot/node_modules/discord.js/src/structures/ClientPresence.js create mode 100644 Bot/node_modules/discord.js/src/structures/ClientUser.js create mode 100644 Bot/node_modules/discord.js/src/structures/CommandInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/CommandInteractionOptionResolver.js create mode 100644 Bot/node_modules/discord.js/src/structures/Component.js create mode 100644 Bot/node_modules/discord.js/src/structures/ContextMenuCommandInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/DMChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/DirectoryChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/Embed.js create mode 100644 Bot/node_modules/discord.js/src/structures/EmbedBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/Emoji.js create mode 100644 Bot/node_modules/discord.js/src/structures/Entitlement.js create mode 100644 Bot/node_modules/discord.js/src/structures/ForumChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/Guild.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildAuditLogs.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildAuditLogsEntry.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildBan.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildEmoji.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildMember.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildOnboarding.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildOnboardingPrompt.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildOnboardingPromptOption.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildPreview.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildPreviewEmoji.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildScheduledEvent.js create mode 100644 Bot/node_modules/discord.js/src/structures/GuildTemplate.js create mode 100644 Bot/node_modules/discord.js/src/structures/Integration.js create mode 100644 Bot/node_modules/discord.js/src/structures/IntegrationApplication.js create mode 100644 Bot/node_modules/discord.js/src/structures/InteractionCollector.js create mode 100644 Bot/node_modules/discord.js/src/structures/InteractionResponse.js create mode 100644 Bot/node_modules/discord.js/src/structures/InteractionWebhook.js create mode 100644 Bot/node_modules/discord.js/src/structures/Invite.js create mode 100644 Bot/node_modules/discord.js/src/structures/InviteGuild.js create mode 100644 Bot/node_modules/discord.js/src/structures/InviteStageInstance.js create mode 100644 Bot/node_modules/discord.js/src/structures/MediaChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/MentionableSelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/MentionableSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/MentionableSelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/Message.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessageCollector.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessageComponentInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessageContextMenuCommandInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessageMentions.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessagePayload.js create mode 100644 Bot/node_modules/discord.js/src/structures/MessageReaction.js create mode 100644 Bot/node_modules/discord.js/src/structures/ModalBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/ModalSubmitFields.js create mode 100644 Bot/node_modules/discord.js/src/structures/ModalSubmitInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/NewsChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/OAuth2Guild.js create mode 100644 Bot/node_modules/discord.js/src/structures/PartialGroupDMChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/PermissionOverwrites.js create mode 100644 Bot/node_modules/discord.js/src/structures/Poll.js create mode 100644 Bot/node_modules/discord.js/src/structures/PollAnswer.js create mode 100644 Bot/node_modules/discord.js/src/structures/Presence.js create mode 100644 Bot/node_modules/discord.js/src/structures/ReactionCollector.js create mode 100644 Bot/node_modules/discord.js/src/structures/ReactionEmoji.js create mode 100644 Bot/node_modules/discord.js/src/structures/Role.js create mode 100644 Bot/node_modules/discord.js/src/structures/RoleSelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/RoleSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/RoleSelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/SKU.js create mode 100644 Bot/node_modules/discord.js/src/structures/SelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/SelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/SelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/SelectMenuOptionBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/StageChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/StageInstance.js create mode 100644 Bot/node_modules/discord.js/src/structures/Sticker.js create mode 100644 Bot/node_modules/discord.js/src/structures/StickerPack.js create mode 100644 Bot/node_modules/discord.js/src/structures/StringSelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/StringSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/StringSelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/StringSelectMenuOptionBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/Team.js create mode 100644 Bot/node_modules/discord.js/src/structures/TeamMember.js create mode 100644 Bot/node_modules/discord.js/src/structures/TextChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/TextInputBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/TextInputComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/ThreadChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/ThreadMember.js create mode 100644 Bot/node_modules/discord.js/src/structures/ThreadOnlyChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/Typing.js create mode 100644 Bot/node_modules/discord.js/src/structures/User.js create mode 100644 Bot/node_modules/discord.js/src/structures/UserContextMenuCommandInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/UserSelectMenuBuilder.js create mode 100644 Bot/node_modules/discord.js/src/structures/UserSelectMenuComponent.js create mode 100644 Bot/node_modules/discord.js/src/structures/UserSelectMenuInteraction.js create mode 100644 Bot/node_modules/discord.js/src/structures/VoiceChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/VoiceRegion.js create mode 100644 Bot/node_modules/discord.js/src/structures/VoiceState.js create mode 100644 Bot/node_modules/discord.js/src/structures/Webhook.js create mode 100644 Bot/node_modules/discord.js/src/structures/WelcomeChannel.js create mode 100644 Bot/node_modules/discord.js/src/structures/WelcomeScreen.js create mode 100644 Bot/node_modules/discord.js/src/structures/Widget.js create mode 100644 Bot/node_modules/discord.js/src/structures/WidgetMember.js create mode 100644 Bot/node_modules/discord.js/src/structures/interfaces/Application.js create mode 100644 Bot/node_modules/discord.js/src/structures/interfaces/Collector.js create mode 100644 Bot/node_modules/discord.js/src/structures/interfaces/InteractionResponses.js create mode 100644 Bot/node_modules/discord.js/src/structures/interfaces/TextBasedChannel.js create mode 100644 Bot/node_modules/discord.js/src/util/APITypes.js create mode 100644 Bot/node_modules/discord.js/src/util/ActivityFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/ApplicationFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/AttachmentFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/BitField.js create mode 100644 Bot/node_modules/discord.js/src/util/ChannelFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/Channels.js create mode 100644 Bot/node_modules/discord.js/src/util/Colors.js create mode 100644 Bot/node_modules/discord.js/src/util/Components.js create mode 100644 Bot/node_modules/discord.js/src/util/Constants.js create mode 100644 Bot/node_modules/discord.js/src/util/DataResolver.js create mode 100644 Bot/node_modules/discord.js/src/util/Enums.js create mode 100644 Bot/node_modules/discord.js/src/util/Events.js create mode 100644 Bot/node_modules/discord.js/src/util/Formatters.js create mode 100644 Bot/node_modules/discord.js/src/util/GuildMemberFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/IntentsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/LimitedCollection.js create mode 100644 Bot/node_modules/discord.js/src/util/MessageFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/Options.js create mode 100644 Bot/node_modules/discord.js/src/util/Partials.js create mode 100644 Bot/node_modules/discord.js/src/util/PermissionsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/RoleFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/SKUFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/ShardEvents.js create mode 100644 Bot/node_modules/discord.js/src/util/Status.js create mode 100644 Bot/node_modules/discord.js/src/util/Sweepers.js create mode 100644 Bot/node_modules/discord.js/src/util/Symbols.js create mode 100644 Bot/node_modules/discord.js/src/util/SystemChannelFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/ThreadMemberFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/Transformers.js create mode 100644 Bot/node_modules/discord.js/src/util/UserFlagsBitField.js create mode 100644 Bot/node_modules/discord.js/src/util/Util.js create mode 100644 Bot/node_modules/discord.js/src/util/WebSocketShardEvents.js create mode 100644 Bot/node_modules/discord.js/typings/index.d.mts create mode 100644 Bot/node_modules/discord.js/typings/index.d.ts create mode 100644 Bot/node_modules/discord.js/typings/index.test-d.ts create mode 100644 Bot/node_modules/discord.js/typings/rawDataTypes.d.mts create mode 100644 Bot/node_modules/discord.js/typings/rawDataTypes.d.ts create mode 100644 Bot/node_modules/discord.js/typings/tsdoc-metadata.json create mode 100644 Bot/node_modules/fast-deep-equal/LICENSE create mode 100644 Bot/node_modules/fast-deep-equal/README.md create mode 100644 Bot/node_modules/fast-deep-equal/es6/index.d.ts create mode 100644 Bot/node_modules/fast-deep-equal/es6/index.js create mode 100644 Bot/node_modules/fast-deep-equal/es6/react.d.ts create mode 100644 Bot/node_modules/fast-deep-equal/es6/react.js create mode 100644 Bot/node_modules/fast-deep-equal/index.d.ts create mode 100644 Bot/node_modules/fast-deep-equal/index.js create mode 100644 Bot/node_modules/fast-deep-equal/package.json create mode 100644 Bot/node_modules/fast-deep-equal/react.d.ts create mode 100644 Bot/node_modules/fast-deep-equal/react.js create mode 100644 Bot/node_modules/follow-redirects/LICENSE create mode 100644 Bot/node_modules/follow-redirects/README.md create mode 100644 Bot/node_modules/follow-redirects/debug.js create mode 100644 Bot/node_modules/follow-redirects/http.js create mode 100644 Bot/node_modules/follow-redirects/https.js create mode 100644 Bot/node_modules/follow-redirects/index.js create mode 100644 Bot/node_modules/follow-redirects/package.json create mode 100644 Bot/node_modules/form-data/License create mode 100644 Bot/node_modules/form-data/README.md.bak create mode 100644 Bot/node_modules/form-data/Readme.md create mode 100644 Bot/node_modules/form-data/index.d.ts create mode 100644 Bot/node_modules/form-data/lib/browser.js create mode 100644 Bot/node_modules/form-data/lib/form_data.js create mode 100644 Bot/node_modules/form-data/lib/populate.js create mode 100644 Bot/node_modules/form-data/package.json create mode 100644 Bot/node_modules/lodash.snakecase/LICENSE create mode 100644 Bot/node_modules/lodash.snakecase/README.md create mode 100644 Bot/node_modules/lodash.snakecase/index.js create mode 100644 Bot/node_modules/lodash.snakecase/package.json create mode 100644 Bot/node_modules/lodash/LICENSE create mode 100644 Bot/node_modules/lodash/README.md create mode 100644 Bot/node_modules/lodash/_DataView.js create mode 100644 Bot/node_modules/lodash/_Hash.js create mode 100644 Bot/node_modules/lodash/_LazyWrapper.js create mode 100644 Bot/node_modules/lodash/_ListCache.js create mode 100644 Bot/node_modules/lodash/_LodashWrapper.js create mode 100644 Bot/node_modules/lodash/_Map.js create mode 100644 Bot/node_modules/lodash/_MapCache.js create mode 100644 Bot/node_modules/lodash/_Promise.js create mode 100644 Bot/node_modules/lodash/_Set.js create mode 100644 Bot/node_modules/lodash/_SetCache.js create mode 100644 Bot/node_modules/lodash/_Stack.js create mode 100644 Bot/node_modules/lodash/_Symbol.js create mode 100644 Bot/node_modules/lodash/_Uint8Array.js create mode 100644 Bot/node_modules/lodash/_WeakMap.js create mode 100644 Bot/node_modules/lodash/_apply.js create mode 100644 Bot/node_modules/lodash/_arrayAggregator.js create mode 100644 Bot/node_modules/lodash/_arrayEach.js create mode 100644 Bot/node_modules/lodash/_arrayEachRight.js create mode 100644 Bot/node_modules/lodash/_arrayEvery.js create mode 100644 Bot/node_modules/lodash/_arrayFilter.js create mode 100644 Bot/node_modules/lodash/_arrayIncludes.js create mode 100644 Bot/node_modules/lodash/_arrayIncludesWith.js create mode 100644 Bot/node_modules/lodash/_arrayLikeKeys.js create mode 100644 Bot/node_modules/lodash/_arrayMap.js create mode 100644 Bot/node_modules/lodash/_arrayPush.js create mode 100644 Bot/node_modules/lodash/_arrayReduce.js create mode 100644 Bot/node_modules/lodash/_arrayReduceRight.js create mode 100644 Bot/node_modules/lodash/_arraySample.js create mode 100644 Bot/node_modules/lodash/_arraySampleSize.js create mode 100644 Bot/node_modules/lodash/_arrayShuffle.js create mode 100644 Bot/node_modules/lodash/_arraySome.js create mode 100644 Bot/node_modules/lodash/_asciiSize.js create mode 100644 Bot/node_modules/lodash/_asciiToArray.js create mode 100644 Bot/node_modules/lodash/_asciiWords.js create mode 100644 Bot/node_modules/lodash/_assignMergeValue.js create mode 100644 Bot/node_modules/lodash/_assignValue.js create mode 100644 Bot/node_modules/lodash/_assocIndexOf.js create mode 100644 Bot/node_modules/lodash/_baseAggregator.js create mode 100644 Bot/node_modules/lodash/_baseAssign.js create mode 100644 Bot/node_modules/lodash/_baseAssignIn.js create mode 100644 Bot/node_modules/lodash/_baseAssignValue.js create mode 100644 Bot/node_modules/lodash/_baseAt.js create mode 100644 Bot/node_modules/lodash/_baseClamp.js create mode 100644 Bot/node_modules/lodash/_baseClone.js create mode 100644 Bot/node_modules/lodash/_baseConforms.js create mode 100644 Bot/node_modules/lodash/_baseConformsTo.js create mode 100644 Bot/node_modules/lodash/_baseCreate.js create mode 100644 Bot/node_modules/lodash/_baseDelay.js create mode 100644 Bot/node_modules/lodash/_baseDifference.js create mode 100644 Bot/node_modules/lodash/_baseEach.js create mode 100644 Bot/node_modules/lodash/_baseEachRight.js create mode 100644 Bot/node_modules/lodash/_baseEvery.js create mode 100644 Bot/node_modules/lodash/_baseExtremum.js create mode 100644 Bot/node_modules/lodash/_baseFill.js create mode 100644 Bot/node_modules/lodash/_baseFilter.js create mode 100644 Bot/node_modules/lodash/_baseFindIndex.js create mode 100644 Bot/node_modules/lodash/_baseFindKey.js create mode 100644 Bot/node_modules/lodash/_baseFlatten.js create mode 100644 Bot/node_modules/lodash/_baseFor.js create mode 100644 Bot/node_modules/lodash/_baseForOwn.js create mode 100644 Bot/node_modules/lodash/_baseForOwnRight.js create mode 100644 Bot/node_modules/lodash/_baseForRight.js create mode 100644 Bot/node_modules/lodash/_baseFunctions.js create mode 100644 Bot/node_modules/lodash/_baseGet.js create mode 100644 Bot/node_modules/lodash/_baseGetAllKeys.js create mode 100644 Bot/node_modules/lodash/_baseGetTag.js create mode 100644 Bot/node_modules/lodash/_baseGt.js create mode 100644 Bot/node_modules/lodash/_baseHas.js create mode 100644 Bot/node_modules/lodash/_baseHasIn.js create mode 100644 Bot/node_modules/lodash/_baseInRange.js create mode 100644 Bot/node_modules/lodash/_baseIndexOf.js create mode 100644 Bot/node_modules/lodash/_baseIndexOfWith.js create mode 100644 Bot/node_modules/lodash/_baseIntersection.js create mode 100644 Bot/node_modules/lodash/_baseInverter.js create mode 100644 Bot/node_modules/lodash/_baseInvoke.js create mode 100644 Bot/node_modules/lodash/_baseIsArguments.js create mode 100644 Bot/node_modules/lodash/_baseIsArrayBuffer.js create mode 100644 Bot/node_modules/lodash/_baseIsDate.js create mode 100644 Bot/node_modules/lodash/_baseIsEqual.js create mode 100644 Bot/node_modules/lodash/_baseIsEqualDeep.js create mode 100644 Bot/node_modules/lodash/_baseIsMap.js create mode 100644 Bot/node_modules/lodash/_baseIsMatch.js create mode 100644 Bot/node_modules/lodash/_baseIsNaN.js create mode 100644 Bot/node_modules/lodash/_baseIsNative.js create mode 100644 Bot/node_modules/lodash/_baseIsRegExp.js create mode 100644 Bot/node_modules/lodash/_baseIsSet.js create mode 100644 Bot/node_modules/lodash/_baseIsTypedArray.js create mode 100644 Bot/node_modules/lodash/_baseIteratee.js create mode 100644 Bot/node_modules/lodash/_baseKeys.js create mode 100644 Bot/node_modules/lodash/_baseKeysIn.js create mode 100644 Bot/node_modules/lodash/_baseLodash.js create mode 100644 Bot/node_modules/lodash/_baseLt.js create mode 100644 Bot/node_modules/lodash/_baseMap.js create mode 100644 Bot/node_modules/lodash/_baseMatches.js create mode 100644 Bot/node_modules/lodash/_baseMatchesProperty.js create mode 100644 Bot/node_modules/lodash/_baseMean.js create mode 100644 Bot/node_modules/lodash/_baseMerge.js create mode 100644 Bot/node_modules/lodash/_baseMergeDeep.js create mode 100644 Bot/node_modules/lodash/_baseNth.js create mode 100644 Bot/node_modules/lodash/_baseOrderBy.js create mode 100644 Bot/node_modules/lodash/_basePick.js create mode 100644 Bot/node_modules/lodash/_basePickBy.js create mode 100644 Bot/node_modules/lodash/_baseProperty.js create mode 100644 Bot/node_modules/lodash/_basePropertyDeep.js create mode 100644 Bot/node_modules/lodash/_basePropertyOf.js create mode 100644 Bot/node_modules/lodash/_basePullAll.js create mode 100644 Bot/node_modules/lodash/_basePullAt.js create mode 100644 Bot/node_modules/lodash/_baseRandom.js create mode 100644 Bot/node_modules/lodash/_baseRange.js create mode 100644 Bot/node_modules/lodash/_baseReduce.js create mode 100644 Bot/node_modules/lodash/_baseRepeat.js create mode 100644 Bot/node_modules/lodash/_baseRest.js create mode 100644 Bot/node_modules/lodash/_baseSample.js create mode 100644 Bot/node_modules/lodash/_baseSampleSize.js create mode 100644 Bot/node_modules/lodash/_baseSet.js create mode 100644 Bot/node_modules/lodash/_baseSetData.js create mode 100644 Bot/node_modules/lodash/_baseSetToString.js create mode 100644 Bot/node_modules/lodash/_baseShuffle.js create mode 100644 Bot/node_modules/lodash/_baseSlice.js create mode 100644 Bot/node_modules/lodash/_baseSome.js create mode 100644 Bot/node_modules/lodash/_baseSortBy.js create mode 100644 Bot/node_modules/lodash/_baseSortedIndex.js create mode 100644 Bot/node_modules/lodash/_baseSortedIndexBy.js create mode 100644 Bot/node_modules/lodash/_baseSortedUniq.js create mode 100644 Bot/node_modules/lodash/_baseSum.js create mode 100644 Bot/node_modules/lodash/_baseTimes.js create mode 100644 Bot/node_modules/lodash/_baseToNumber.js create mode 100644 Bot/node_modules/lodash/_baseToPairs.js create mode 100644 Bot/node_modules/lodash/_baseToString.js create mode 100644 Bot/node_modules/lodash/_baseTrim.js create mode 100644 Bot/node_modules/lodash/_baseUnary.js create mode 100644 Bot/node_modules/lodash/_baseUniq.js create mode 100644 Bot/node_modules/lodash/_baseUnset.js create mode 100644 Bot/node_modules/lodash/_baseUpdate.js create mode 100644 Bot/node_modules/lodash/_baseValues.js create mode 100644 Bot/node_modules/lodash/_baseWhile.js create mode 100644 Bot/node_modules/lodash/_baseWrapperValue.js create mode 100644 Bot/node_modules/lodash/_baseXor.js create mode 100644 Bot/node_modules/lodash/_baseZipObject.js create mode 100644 Bot/node_modules/lodash/_cacheHas.js create mode 100644 Bot/node_modules/lodash/_castArrayLikeObject.js create mode 100644 Bot/node_modules/lodash/_castFunction.js create mode 100644 Bot/node_modules/lodash/_castPath.js create mode 100644 Bot/node_modules/lodash/_castRest.js create mode 100644 Bot/node_modules/lodash/_castSlice.js create mode 100644 Bot/node_modules/lodash/_charsEndIndex.js create mode 100644 Bot/node_modules/lodash/_charsStartIndex.js create mode 100644 Bot/node_modules/lodash/_cloneArrayBuffer.js create mode 100644 Bot/node_modules/lodash/_cloneBuffer.js create mode 100644 Bot/node_modules/lodash/_cloneDataView.js create mode 100644 Bot/node_modules/lodash/_cloneRegExp.js create mode 100644 Bot/node_modules/lodash/_cloneSymbol.js create mode 100644 Bot/node_modules/lodash/_cloneTypedArray.js create mode 100644 Bot/node_modules/lodash/_compareAscending.js create mode 100644 Bot/node_modules/lodash/_compareMultiple.js create mode 100644 Bot/node_modules/lodash/_composeArgs.js create mode 100644 Bot/node_modules/lodash/_composeArgsRight.js create mode 100644 Bot/node_modules/lodash/_copyArray.js create mode 100644 Bot/node_modules/lodash/_copyObject.js create mode 100644 Bot/node_modules/lodash/_copySymbols.js create mode 100644 Bot/node_modules/lodash/_copySymbolsIn.js create mode 100644 Bot/node_modules/lodash/_coreJsData.js create mode 100644 Bot/node_modules/lodash/_countHolders.js create mode 100644 Bot/node_modules/lodash/_createAggregator.js create mode 100644 Bot/node_modules/lodash/_createAssigner.js create mode 100644 Bot/node_modules/lodash/_createBaseEach.js create mode 100644 Bot/node_modules/lodash/_createBaseFor.js create mode 100644 Bot/node_modules/lodash/_createBind.js create mode 100644 Bot/node_modules/lodash/_createCaseFirst.js create mode 100644 Bot/node_modules/lodash/_createCompounder.js create mode 100644 Bot/node_modules/lodash/_createCtor.js create mode 100644 Bot/node_modules/lodash/_createCurry.js create mode 100644 Bot/node_modules/lodash/_createFind.js create mode 100644 Bot/node_modules/lodash/_createFlow.js create mode 100644 Bot/node_modules/lodash/_createHybrid.js create mode 100644 Bot/node_modules/lodash/_createInverter.js create mode 100644 Bot/node_modules/lodash/_createMathOperation.js create mode 100644 Bot/node_modules/lodash/_createOver.js create mode 100644 Bot/node_modules/lodash/_createPadding.js create mode 100644 Bot/node_modules/lodash/_createPartial.js create mode 100644 Bot/node_modules/lodash/_createRange.js create mode 100644 Bot/node_modules/lodash/_createRecurry.js create mode 100644 Bot/node_modules/lodash/_createRelationalOperation.js create mode 100644 Bot/node_modules/lodash/_createRound.js create mode 100644 Bot/node_modules/lodash/_createSet.js create mode 100644 Bot/node_modules/lodash/_createToPairs.js create mode 100644 Bot/node_modules/lodash/_createWrap.js create mode 100644 Bot/node_modules/lodash/_customDefaultsAssignIn.js create mode 100644 Bot/node_modules/lodash/_customDefaultsMerge.js create mode 100644 Bot/node_modules/lodash/_customOmitClone.js create mode 100644 Bot/node_modules/lodash/_deburrLetter.js create mode 100644 Bot/node_modules/lodash/_defineProperty.js create mode 100644 Bot/node_modules/lodash/_equalArrays.js create mode 100644 Bot/node_modules/lodash/_equalByTag.js create mode 100644 Bot/node_modules/lodash/_equalObjects.js create mode 100644 Bot/node_modules/lodash/_escapeHtmlChar.js create mode 100644 Bot/node_modules/lodash/_escapeStringChar.js create mode 100644 Bot/node_modules/lodash/_flatRest.js create mode 100644 Bot/node_modules/lodash/_freeGlobal.js create mode 100644 Bot/node_modules/lodash/_getAllKeys.js create mode 100644 Bot/node_modules/lodash/_getAllKeysIn.js create mode 100644 Bot/node_modules/lodash/_getData.js create mode 100644 Bot/node_modules/lodash/_getFuncName.js create mode 100644 Bot/node_modules/lodash/_getHolder.js create mode 100644 Bot/node_modules/lodash/_getMapData.js create mode 100644 Bot/node_modules/lodash/_getMatchData.js create mode 100644 Bot/node_modules/lodash/_getNative.js create mode 100644 Bot/node_modules/lodash/_getPrototype.js create mode 100644 Bot/node_modules/lodash/_getRawTag.js create mode 100644 Bot/node_modules/lodash/_getSymbols.js create mode 100644 Bot/node_modules/lodash/_getSymbolsIn.js create mode 100644 Bot/node_modules/lodash/_getTag.js create mode 100644 Bot/node_modules/lodash/_getValue.js create mode 100644 Bot/node_modules/lodash/_getView.js create mode 100644 Bot/node_modules/lodash/_getWrapDetails.js create mode 100644 Bot/node_modules/lodash/_hasPath.js create mode 100644 Bot/node_modules/lodash/_hasUnicode.js create mode 100644 Bot/node_modules/lodash/_hasUnicodeWord.js create mode 100644 Bot/node_modules/lodash/_hashClear.js create mode 100644 Bot/node_modules/lodash/_hashDelete.js create mode 100644 Bot/node_modules/lodash/_hashGet.js create mode 100644 Bot/node_modules/lodash/_hashHas.js create mode 100644 Bot/node_modules/lodash/_hashSet.js create mode 100644 Bot/node_modules/lodash/_initCloneArray.js create mode 100644 Bot/node_modules/lodash/_initCloneByTag.js create mode 100644 Bot/node_modules/lodash/_initCloneObject.js create mode 100644 Bot/node_modules/lodash/_insertWrapDetails.js create mode 100644 Bot/node_modules/lodash/_isFlattenable.js create mode 100644 Bot/node_modules/lodash/_isIndex.js create mode 100644 Bot/node_modules/lodash/_isIterateeCall.js create mode 100644 Bot/node_modules/lodash/_isKey.js create mode 100644 Bot/node_modules/lodash/_isKeyable.js create mode 100644 Bot/node_modules/lodash/_isLaziable.js create mode 100644 Bot/node_modules/lodash/_isMaskable.js create mode 100644 Bot/node_modules/lodash/_isMasked.js create mode 100644 Bot/node_modules/lodash/_isPrototype.js create mode 100644 Bot/node_modules/lodash/_isStrictComparable.js create mode 100644 Bot/node_modules/lodash/_iteratorToArray.js create mode 100644 Bot/node_modules/lodash/_lazyClone.js create mode 100644 Bot/node_modules/lodash/_lazyReverse.js create mode 100644 Bot/node_modules/lodash/_lazyValue.js create mode 100644 Bot/node_modules/lodash/_listCacheClear.js create mode 100644 Bot/node_modules/lodash/_listCacheDelete.js create mode 100644 Bot/node_modules/lodash/_listCacheGet.js create mode 100644 Bot/node_modules/lodash/_listCacheHas.js create mode 100644 Bot/node_modules/lodash/_listCacheSet.js create mode 100644 Bot/node_modules/lodash/_mapCacheClear.js create mode 100644 Bot/node_modules/lodash/_mapCacheDelete.js create mode 100644 Bot/node_modules/lodash/_mapCacheGet.js create mode 100644 Bot/node_modules/lodash/_mapCacheHas.js create mode 100644 Bot/node_modules/lodash/_mapCacheSet.js create mode 100644 Bot/node_modules/lodash/_mapToArray.js create mode 100644 Bot/node_modules/lodash/_matchesStrictComparable.js create mode 100644 Bot/node_modules/lodash/_memoizeCapped.js create mode 100644 Bot/node_modules/lodash/_mergeData.js create mode 100644 Bot/node_modules/lodash/_metaMap.js create mode 100644 Bot/node_modules/lodash/_nativeCreate.js create mode 100644 Bot/node_modules/lodash/_nativeKeys.js create mode 100644 Bot/node_modules/lodash/_nativeKeysIn.js create mode 100644 Bot/node_modules/lodash/_nodeUtil.js create mode 100644 Bot/node_modules/lodash/_objectToString.js create mode 100644 Bot/node_modules/lodash/_overArg.js create mode 100644 Bot/node_modules/lodash/_overRest.js create mode 100644 Bot/node_modules/lodash/_parent.js create mode 100644 Bot/node_modules/lodash/_reEscape.js create mode 100644 Bot/node_modules/lodash/_reEvaluate.js create mode 100644 Bot/node_modules/lodash/_reInterpolate.js create mode 100644 Bot/node_modules/lodash/_realNames.js create mode 100644 Bot/node_modules/lodash/_reorder.js create mode 100644 Bot/node_modules/lodash/_replaceHolders.js create mode 100644 Bot/node_modules/lodash/_root.js create mode 100644 Bot/node_modules/lodash/_safeGet.js create mode 100644 Bot/node_modules/lodash/_setCacheAdd.js create mode 100644 Bot/node_modules/lodash/_setCacheHas.js create mode 100644 Bot/node_modules/lodash/_setData.js create mode 100644 Bot/node_modules/lodash/_setToArray.js create mode 100644 Bot/node_modules/lodash/_setToPairs.js create mode 100644 Bot/node_modules/lodash/_setToString.js create mode 100644 Bot/node_modules/lodash/_setWrapToString.js create mode 100644 Bot/node_modules/lodash/_shortOut.js create mode 100644 Bot/node_modules/lodash/_shuffleSelf.js create mode 100644 Bot/node_modules/lodash/_stackClear.js create mode 100644 Bot/node_modules/lodash/_stackDelete.js create mode 100644 Bot/node_modules/lodash/_stackGet.js create mode 100644 Bot/node_modules/lodash/_stackHas.js create mode 100644 Bot/node_modules/lodash/_stackSet.js create mode 100644 Bot/node_modules/lodash/_strictIndexOf.js create mode 100644 Bot/node_modules/lodash/_strictLastIndexOf.js create mode 100644 Bot/node_modules/lodash/_stringSize.js create mode 100644 Bot/node_modules/lodash/_stringToArray.js create mode 100644 Bot/node_modules/lodash/_stringToPath.js create mode 100644 Bot/node_modules/lodash/_toKey.js create mode 100644 Bot/node_modules/lodash/_toSource.js create mode 100644 Bot/node_modules/lodash/_trimmedEndIndex.js create mode 100644 Bot/node_modules/lodash/_unescapeHtmlChar.js create mode 100644 Bot/node_modules/lodash/_unicodeSize.js create mode 100644 Bot/node_modules/lodash/_unicodeToArray.js create mode 100644 Bot/node_modules/lodash/_unicodeWords.js create mode 100644 Bot/node_modules/lodash/_updateWrapDetails.js create mode 100644 Bot/node_modules/lodash/_wrapperClone.js create mode 100644 Bot/node_modules/lodash/add.js create mode 100644 Bot/node_modules/lodash/after.js create mode 100644 Bot/node_modules/lodash/array.js create mode 100644 Bot/node_modules/lodash/ary.js create mode 100644 Bot/node_modules/lodash/assign.js create mode 100644 Bot/node_modules/lodash/assignIn.js create mode 100644 Bot/node_modules/lodash/assignInWith.js create mode 100644 Bot/node_modules/lodash/assignWith.js create mode 100644 Bot/node_modules/lodash/at.js create mode 100644 Bot/node_modules/lodash/attempt.js create mode 100644 Bot/node_modules/lodash/before.js create mode 100644 Bot/node_modules/lodash/bind.js create mode 100644 Bot/node_modules/lodash/bindAll.js create mode 100644 Bot/node_modules/lodash/bindKey.js create mode 100644 Bot/node_modules/lodash/camelCase.js create mode 100644 Bot/node_modules/lodash/capitalize.js create mode 100644 Bot/node_modules/lodash/castArray.js create mode 100644 Bot/node_modules/lodash/ceil.js create mode 100644 Bot/node_modules/lodash/chain.js create mode 100644 Bot/node_modules/lodash/chunk.js create mode 100644 Bot/node_modules/lodash/clamp.js create mode 100644 Bot/node_modules/lodash/clone.js create mode 100644 Bot/node_modules/lodash/cloneDeep.js create mode 100644 Bot/node_modules/lodash/cloneDeepWith.js create mode 100644 Bot/node_modules/lodash/cloneWith.js create mode 100644 Bot/node_modules/lodash/collection.js create mode 100644 Bot/node_modules/lodash/commit.js create mode 100644 Bot/node_modules/lodash/compact.js create mode 100644 Bot/node_modules/lodash/concat.js create mode 100644 Bot/node_modules/lodash/cond.js create mode 100644 Bot/node_modules/lodash/conforms.js create mode 100644 Bot/node_modules/lodash/conformsTo.js create mode 100644 Bot/node_modules/lodash/constant.js create mode 100644 Bot/node_modules/lodash/core.js create mode 100644 Bot/node_modules/lodash/core.min.js create mode 100644 Bot/node_modules/lodash/countBy.js create mode 100644 Bot/node_modules/lodash/create.js create mode 100644 Bot/node_modules/lodash/curry.js create mode 100644 Bot/node_modules/lodash/curryRight.js create mode 100644 Bot/node_modules/lodash/date.js create mode 100644 Bot/node_modules/lodash/debounce.js create mode 100644 Bot/node_modules/lodash/deburr.js create mode 100644 Bot/node_modules/lodash/defaultTo.js create mode 100644 Bot/node_modules/lodash/defaults.js create mode 100644 Bot/node_modules/lodash/defaultsDeep.js create mode 100644 Bot/node_modules/lodash/defer.js create mode 100644 Bot/node_modules/lodash/delay.js create mode 100644 Bot/node_modules/lodash/difference.js create mode 100644 Bot/node_modules/lodash/differenceBy.js create mode 100644 Bot/node_modules/lodash/differenceWith.js create mode 100644 Bot/node_modules/lodash/divide.js create mode 100644 Bot/node_modules/lodash/drop.js create mode 100644 Bot/node_modules/lodash/dropRight.js create mode 100644 Bot/node_modules/lodash/dropRightWhile.js create mode 100644 Bot/node_modules/lodash/dropWhile.js create mode 100644 Bot/node_modules/lodash/each.js create mode 100644 Bot/node_modules/lodash/eachRight.js create mode 100644 Bot/node_modules/lodash/endsWith.js create mode 100644 Bot/node_modules/lodash/entries.js create mode 100644 Bot/node_modules/lodash/entriesIn.js create mode 100644 Bot/node_modules/lodash/eq.js create mode 100644 Bot/node_modules/lodash/escape.js create mode 100644 Bot/node_modules/lodash/escapeRegExp.js create mode 100644 Bot/node_modules/lodash/every.js create mode 100644 Bot/node_modules/lodash/extend.js create mode 100644 Bot/node_modules/lodash/extendWith.js create mode 100644 Bot/node_modules/lodash/fill.js create mode 100644 Bot/node_modules/lodash/filter.js create mode 100644 Bot/node_modules/lodash/find.js create mode 100644 Bot/node_modules/lodash/findIndex.js create mode 100644 Bot/node_modules/lodash/findKey.js create mode 100644 Bot/node_modules/lodash/findLast.js create mode 100644 Bot/node_modules/lodash/findLastIndex.js create mode 100644 Bot/node_modules/lodash/findLastKey.js create mode 100644 Bot/node_modules/lodash/first.js create mode 100644 Bot/node_modules/lodash/flake.lock create mode 100644 Bot/node_modules/lodash/flake.nix create mode 100644 Bot/node_modules/lodash/flatMap.js create mode 100644 Bot/node_modules/lodash/flatMapDeep.js create mode 100644 Bot/node_modules/lodash/flatMapDepth.js create mode 100644 Bot/node_modules/lodash/flatten.js create mode 100644 Bot/node_modules/lodash/flattenDeep.js create mode 100644 Bot/node_modules/lodash/flattenDepth.js create mode 100644 Bot/node_modules/lodash/flip.js create mode 100644 Bot/node_modules/lodash/floor.js create mode 100644 Bot/node_modules/lodash/flow.js create mode 100644 Bot/node_modules/lodash/flowRight.js create mode 100644 Bot/node_modules/lodash/forEach.js create mode 100644 Bot/node_modules/lodash/forEachRight.js create mode 100644 Bot/node_modules/lodash/forIn.js create mode 100644 Bot/node_modules/lodash/forInRight.js create mode 100644 Bot/node_modules/lodash/forOwn.js create mode 100644 Bot/node_modules/lodash/forOwnRight.js create mode 100644 Bot/node_modules/lodash/fp.js create mode 100644 Bot/node_modules/lodash/fp/F.js create mode 100644 Bot/node_modules/lodash/fp/T.js create mode 100644 Bot/node_modules/lodash/fp/__.js create mode 100644 Bot/node_modules/lodash/fp/_baseConvert.js create mode 100644 Bot/node_modules/lodash/fp/_convertBrowser.js create mode 100644 Bot/node_modules/lodash/fp/_falseOptions.js create mode 100644 Bot/node_modules/lodash/fp/_mapping.js create mode 100644 Bot/node_modules/lodash/fp/_util.js create mode 100644 Bot/node_modules/lodash/fp/add.js create mode 100644 Bot/node_modules/lodash/fp/after.js create mode 100644 Bot/node_modules/lodash/fp/all.js create mode 100644 Bot/node_modules/lodash/fp/allPass.js create mode 100644 Bot/node_modules/lodash/fp/always.js create mode 100644 Bot/node_modules/lodash/fp/any.js create mode 100644 Bot/node_modules/lodash/fp/anyPass.js create mode 100644 Bot/node_modules/lodash/fp/apply.js create mode 100644 Bot/node_modules/lodash/fp/array.js create mode 100644 Bot/node_modules/lodash/fp/ary.js create mode 100644 Bot/node_modules/lodash/fp/assign.js create mode 100644 Bot/node_modules/lodash/fp/assignAll.js create mode 100644 Bot/node_modules/lodash/fp/assignAllWith.js create mode 100644 Bot/node_modules/lodash/fp/assignIn.js create mode 100644 Bot/node_modules/lodash/fp/assignInAll.js create mode 100644 Bot/node_modules/lodash/fp/assignInAllWith.js create mode 100644 Bot/node_modules/lodash/fp/assignInWith.js create mode 100644 Bot/node_modules/lodash/fp/assignWith.js create mode 100644 Bot/node_modules/lodash/fp/assoc.js create mode 100644 Bot/node_modules/lodash/fp/assocPath.js create mode 100644 Bot/node_modules/lodash/fp/at.js create mode 100644 Bot/node_modules/lodash/fp/attempt.js create mode 100644 Bot/node_modules/lodash/fp/before.js create mode 100644 Bot/node_modules/lodash/fp/bind.js create mode 100644 Bot/node_modules/lodash/fp/bindAll.js create mode 100644 Bot/node_modules/lodash/fp/bindKey.js create mode 100644 Bot/node_modules/lodash/fp/camelCase.js create mode 100644 Bot/node_modules/lodash/fp/capitalize.js create mode 100644 Bot/node_modules/lodash/fp/castArray.js create mode 100644 Bot/node_modules/lodash/fp/ceil.js create mode 100644 Bot/node_modules/lodash/fp/chain.js create mode 100644 Bot/node_modules/lodash/fp/chunk.js create mode 100644 Bot/node_modules/lodash/fp/clamp.js create mode 100644 Bot/node_modules/lodash/fp/clone.js create mode 100644 Bot/node_modules/lodash/fp/cloneDeep.js create mode 100644 Bot/node_modules/lodash/fp/cloneDeepWith.js create mode 100644 Bot/node_modules/lodash/fp/cloneWith.js create mode 100644 Bot/node_modules/lodash/fp/collection.js create mode 100644 Bot/node_modules/lodash/fp/commit.js create mode 100644 Bot/node_modules/lodash/fp/compact.js create mode 100644 Bot/node_modules/lodash/fp/complement.js create mode 100644 Bot/node_modules/lodash/fp/compose.js create mode 100644 Bot/node_modules/lodash/fp/concat.js create mode 100644 Bot/node_modules/lodash/fp/cond.js create mode 100644 Bot/node_modules/lodash/fp/conforms.js create mode 100644 Bot/node_modules/lodash/fp/conformsTo.js create mode 100644 Bot/node_modules/lodash/fp/constant.js create mode 100644 Bot/node_modules/lodash/fp/contains.js create mode 100644 Bot/node_modules/lodash/fp/convert.js create mode 100644 Bot/node_modules/lodash/fp/countBy.js create mode 100644 Bot/node_modules/lodash/fp/create.js create mode 100644 Bot/node_modules/lodash/fp/curry.js create mode 100644 Bot/node_modules/lodash/fp/curryN.js create mode 100644 Bot/node_modules/lodash/fp/curryRight.js create mode 100644 Bot/node_modules/lodash/fp/curryRightN.js create mode 100644 Bot/node_modules/lodash/fp/date.js create mode 100644 Bot/node_modules/lodash/fp/debounce.js create mode 100644 Bot/node_modules/lodash/fp/deburr.js create mode 100644 Bot/node_modules/lodash/fp/defaultTo.js create mode 100644 Bot/node_modules/lodash/fp/defaults.js create mode 100644 Bot/node_modules/lodash/fp/defaultsAll.js create mode 100644 Bot/node_modules/lodash/fp/defaultsDeep.js create mode 100644 Bot/node_modules/lodash/fp/defaultsDeepAll.js create mode 100644 Bot/node_modules/lodash/fp/defer.js create mode 100644 Bot/node_modules/lodash/fp/delay.js create mode 100644 Bot/node_modules/lodash/fp/difference.js create mode 100644 Bot/node_modules/lodash/fp/differenceBy.js create mode 100644 Bot/node_modules/lodash/fp/differenceWith.js create mode 100644 Bot/node_modules/lodash/fp/dissoc.js create mode 100644 Bot/node_modules/lodash/fp/dissocPath.js create mode 100644 Bot/node_modules/lodash/fp/divide.js create mode 100644 Bot/node_modules/lodash/fp/drop.js create mode 100644 Bot/node_modules/lodash/fp/dropLast.js create mode 100644 Bot/node_modules/lodash/fp/dropLastWhile.js create mode 100644 Bot/node_modules/lodash/fp/dropRight.js create mode 100644 Bot/node_modules/lodash/fp/dropRightWhile.js create mode 100644 Bot/node_modules/lodash/fp/dropWhile.js create mode 100644 Bot/node_modules/lodash/fp/each.js create mode 100644 Bot/node_modules/lodash/fp/eachRight.js create mode 100644 Bot/node_modules/lodash/fp/endsWith.js create mode 100644 Bot/node_modules/lodash/fp/entries.js create mode 100644 Bot/node_modules/lodash/fp/entriesIn.js create mode 100644 Bot/node_modules/lodash/fp/eq.js create mode 100644 Bot/node_modules/lodash/fp/equals.js create mode 100644 Bot/node_modules/lodash/fp/escape.js create mode 100644 Bot/node_modules/lodash/fp/escapeRegExp.js create mode 100644 Bot/node_modules/lodash/fp/every.js create mode 100644 Bot/node_modules/lodash/fp/extend.js create mode 100644 Bot/node_modules/lodash/fp/extendAll.js create mode 100644 Bot/node_modules/lodash/fp/extendAllWith.js create mode 100644 Bot/node_modules/lodash/fp/extendWith.js create mode 100644 Bot/node_modules/lodash/fp/fill.js create mode 100644 Bot/node_modules/lodash/fp/filter.js create mode 100644 Bot/node_modules/lodash/fp/find.js create mode 100644 Bot/node_modules/lodash/fp/findFrom.js create mode 100644 Bot/node_modules/lodash/fp/findIndex.js create mode 100644 Bot/node_modules/lodash/fp/findIndexFrom.js create mode 100644 Bot/node_modules/lodash/fp/findKey.js create mode 100644 Bot/node_modules/lodash/fp/findLast.js create mode 100644 Bot/node_modules/lodash/fp/findLastFrom.js create mode 100644 Bot/node_modules/lodash/fp/findLastIndex.js create mode 100644 Bot/node_modules/lodash/fp/findLastIndexFrom.js create mode 100644 Bot/node_modules/lodash/fp/findLastKey.js create mode 100644 Bot/node_modules/lodash/fp/first.js create mode 100644 Bot/node_modules/lodash/fp/flatMap.js create mode 100644 Bot/node_modules/lodash/fp/flatMapDeep.js create mode 100644 Bot/node_modules/lodash/fp/flatMapDepth.js create mode 100644 Bot/node_modules/lodash/fp/flatten.js create mode 100644 Bot/node_modules/lodash/fp/flattenDeep.js create mode 100644 Bot/node_modules/lodash/fp/flattenDepth.js create mode 100644 Bot/node_modules/lodash/fp/flip.js create mode 100644 Bot/node_modules/lodash/fp/floor.js create mode 100644 Bot/node_modules/lodash/fp/flow.js create mode 100644 Bot/node_modules/lodash/fp/flowRight.js create mode 100644 Bot/node_modules/lodash/fp/forEach.js create mode 100644 Bot/node_modules/lodash/fp/forEachRight.js create mode 100644 Bot/node_modules/lodash/fp/forIn.js create mode 100644 Bot/node_modules/lodash/fp/forInRight.js create mode 100644 Bot/node_modules/lodash/fp/forOwn.js create mode 100644 Bot/node_modules/lodash/fp/forOwnRight.js create mode 100644 Bot/node_modules/lodash/fp/fromPairs.js create mode 100644 Bot/node_modules/lodash/fp/function.js create mode 100644 Bot/node_modules/lodash/fp/functions.js create mode 100644 Bot/node_modules/lodash/fp/functionsIn.js create mode 100644 Bot/node_modules/lodash/fp/get.js create mode 100644 Bot/node_modules/lodash/fp/getOr.js create mode 100644 Bot/node_modules/lodash/fp/groupBy.js create mode 100644 Bot/node_modules/lodash/fp/gt.js create mode 100644 Bot/node_modules/lodash/fp/gte.js create mode 100644 Bot/node_modules/lodash/fp/has.js create mode 100644 Bot/node_modules/lodash/fp/hasIn.js create mode 100644 Bot/node_modules/lodash/fp/head.js create mode 100644 Bot/node_modules/lodash/fp/identical.js create mode 100644 Bot/node_modules/lodash/fp/identity.js create mode 100644 Bot/node_modules/lodash/fp/inRange.js create mode 100644 Bot/node_modules/lodash/fp/includes.js create mode 100644 Bot/node_modules/lodash/fp/includesFrom.js create mode 100644 Bot/node_modules/lodash/fp/indexBy.js create mode 100644 Bot/node_modules/lodash/fp/indexOf.js create mode 100644 Bot/node_modules/lodash/fp/indexOfFrom.js create mode 100644 Bot/node_modules/lodash/fp/init.js create mode 100644 Bot/node_modules/lodash/fp/initial.js create mode 100644 Bot/node_modules/lodash/fp/intersection.js create mode 100644 Bot/node_modules/lodash/fp/intersectionBy.js create mode 100644 Bot/node_modules/lodash/fp/intersectionWith.js create mode 100644 Bot/node_modules/lodash/fp/invert.js create mode 100644 Bot/node_modules/lodash/fp/invertBy.js create mode 100644 Bot/node_modules/lodash/fp/invertObj.js create mode 100644 Bot/node_modules/lodash/fp/invoke.js create mode 100644 Bot/node_modules/lodash/fp/invokeArgs.js create mode 100644 Bot/node_modules/lodash/fp/invokeArgsMap.js create mode 100644 Bot/node_modules/lodash/fp/invokeMap.js create mode 100644 Bot/node_modules/lodash/fp/isArguments.js create mode 100644 Bot/node_modules/lodash/fp/isArray.js create mode 100644 Bot/node_modules/lodash/fp/isArrayBuffer.js create mode 100644 Bot/node_modules/lodash/fp/isArrayLike.js create mode 100644 Bot/node_modules/lodash/fp/isArrayLikeObject.js create mode 100644 Bot/node_modules/lodash/fp/isBoolean.js create mode 100644 Bot/node_modules/lodash/fp/isBuffer.js create mode 100644 Bot/node_modules/lodash/fp/isDate.js create mode 100644 Bot/node_modules/lodash/fp/isElement.js create mode 100644 Bot/node_modules/lodash/fp/isEmpty.js create mode 100644 Bot/node_modules/lodash/fp/isEqual.js create mode 100644 Bot/node_modules/lodash/fp/isEqualWith.js create mode 100644 Bot/node_modules/lodash/fp/isError.js create mode 100644 Bot/node_modules/lodash/fp/isFinite.js create mode 100644 Bot/node_modules/lodash/fp/isFunction.js create mode 100644 Bot/node_modules/lodash/fp/isInteger.js create mode 100644 Bot/node_modules/lodash/fp/isLength.js create mode 100644 Bot/node_modules/lodash/fp/isMap.js create mode 100644 Bot/node_modules/lodash/fp/isMatch.js create mode 100644 Bot/node_modules/lodash/fp/isMatchWith.js create mode 100644 Bot/node_modules/lodash/fp/isNaN.js create mode 100644 Bot/node_modules/lodash/fp/isNative.js create mode 100644 Bot/node_modules/lodash/fp/isNil.js create mode 100644 Bot/node_modules/lodash/fp/isNull.js create mode 100644 Bot/node_modules/lodash/fp/isNumber.js create mode 100644 Bot/node_modules/lodash/fp/isObject.js create mode 100644 Bot/node_modules/lodash/fp/isObjectLike.js create mode 100644 Bot/node_modules/lodash/fp/isPlainObject.js create mode 100644 Bot/node_modules/lodash/fp/isRegExp.js create mode 100644 Bot/node_modules/lodash/fp/isSafeInteger.js create mode 100644 Bot/node_modules/lodash/fp/isSet.js create mode 100644 Bot/node_modules/lodash/fp/isString.js create mode 100644 Bot/node_modules/lodash/fp/isSymbol.js create mode 100644 Bot/node_modules/lodash/fp/isTypedArray.js create mode 100644 Bot/node_modules/lodash/fp/isUndefined.js create mode 100644 Bot/node_modules/lodash/fp/isWeakMap.js create mode 100644 Bot/node_modules/lodash/fp/isWeakSet.js create mode 100644 Bot/node_modules/lodash/fp/iteratee.js create mode 100644 Bot/node_modules/lodash/fp/join.js create mode 100644 Bot/node_modules/lodash/fp/juxt.js create mode 100644 Bot/node_modules/lodash/fp/kebabCase.js create mode 100644 Bot/node_modules/lodash/fp/keyBy.js create mode 100644 Bot/node_modules/lodash/fp/keys.js create mode 100644 Bot/node_modules/lodash/fp/keysIn.js create mode 100644 Bot/node_modules/lodash/fp/lang.js create mode 100644 Bot/node_modules/lodash/fp/last.js create mode 100644 Bot/node_modules/lodash/fp/lastIndexOf.js create mode 100644 Bot/node_modules/lodash/fp/lastIndexOfFrom.js create mode 100644 Bot/node_modules/lodash/fp/lowerCase.js create mode 100644 Bot/node_modules/lodash/fp/lowerFirst.js create mode 100644 Bot/node_modules/lodash/fp/lt.js create mode 100644 Bot/node_modules/lodash/fp/lte.js create mode 100644 Bot/node_modules/lodash/fp/map.js create mode 100644 Bot/node_modules/lodash/fp/mapKeys.js create mode 100644 Bot/node_modules/lodash/fp/mapValues.js create mode 100644 Bot/node_modules/lodash/fp/matches.js create mode 100644 Bot/node_modules/lodash/fp/matchesProperty.js create mode 100644 Bot/node_modules/lodash/fp/math.js create mode 100644 Bot/node_modules/lodash/fp/max.js create mode 100644 Bot/node_modules/lodash/fp/maxBy.js create mode 100644 Bot/node_modules/lodash/fp/mean.js create mode 100644 Bot/node_modules/lodash/fp/meanBy.js create mode 100644 Bot/node_modules/lodash/fp/memoize.js create mode 100644 Bot/node_modules/lodash/fp/merge.js create mode 100644 Bot/node_modules/lodash/fp/mergeAll.js create mode 100644 Bot/node_modules/lodash/fp/mergeAllWith.js create mode 100644 Bot/node_modules/lodash/fp/mergeWith.js create mode 100644 Bot/node_modules/lodash/fp/method.js create mode 100644 Bot/node_modules/lodash/fp/methodOf.js create mode 100644 Bot/node_modules/lodash/fp/min.js create mode 100644 Bot/node_modules/lodash/fp/minBy.js create mode 100644 Bot/node_modules/lodash/fp/mixin.js create mode 100644 Bot/node_modules/lodash/fp/multiply.js create mode 100644 Bot/node_modules/lodash/fp/nAry.js create mode 100644 Bot/node_modules/lodash/fp/negate.js create mode 100644 Bot/node_modules/lodash/fp/next.js create mode 100644 Bot/node_modules/lodash/fp/noop.js create mode 100644 Bot/node_modules/lodash/fp/now.js create mode 100644 Bot/node_modules/lodash/fp/nth.js create mode 100644 Bot/node_modules/lodash/fp/nthArg.js create mode 100644 Bot/node_modules/lodash/fp/number.js create mode 100644 Bot/node_modules/lodash/fp/object.js create mode 100644 Bot/node_modules/lodash/fp/omit.js create mode 100644 Bot/node_modules/lodash/fp/omitAll.js create mode 100644 Bot/node_modules/lodash/fp/omitBy.js create mode 100644 Bot/node_modules/lodash/fp/once.js create mode 100644 Bot/node_modules/lodash/fp/orderBy.js create mode 100644 Bot/node_modules/lodash/fp/over.js create mode 100644 Bot/node_modules/lodash/fp/overArgs.js create mode 100644 Bot/node_modules/lodash/fp/overEvery.js create mode 100644 Bot/node_modules/lodash/fp/overSome.js create mode 100644 Bot/node_modules/lodash/fp/pad.js create mode 100644 Bot/node_modules/lodash/fp/padChars.js create mode 100644 Bot/node_modules/lodash/fp/padCharsEnd.js create mode 100644 Bot/node_modules/lodash/fp/padCharsStart.js create mode 100644 Bot/node_modules/lodash/fp/padEnd.js create mode 100644 Bot/node_modules/lodash/fp/padStart.js create mode 100644 Bot/node_modules/lodash/fp/parseInt.js create mode 100644 Bot/node_modules/lodash/fp/partial.js create mode 100644 Bot/node_modules/lodash/fp/partialRight.js create mode 100644 Bot/node_modules/lodash/fp/partition.js create mode 100644 Bot/node_modules/lodash/fp/path.js create mode 100644 Bot/node_modules/lodash/fp/pathEq.js create mode 100644 Bot/node_modules/lodash/fp/pathOr.js create mode 100644 Bot/node_modules/lodash/fp/paths.js create mode 100644 Bot/node_modules/lodash/fp/pick.js create mode 100644 Bot/node_modules/lodash/fp/pickAll.js create mode 100644 Bot/node_modules/lodash/fp/pickBy.js create mode 100644 Bot/node_modules/lodash/fp/pipe.js create mode 100644 Bot/node_modules/lodash/fp/placeholder.js create mode 100644 Bot/node_modules/lodash/fp/plant.js create mode 100644 Bot/node_modules/lodash/fp/pluck.js create mode 100644 Bot/node_modules/lodash/fp/prop.js create mode 100644 Bot/node_modules/lodash/fp/propEq.js create mode 100644 Bot/node_modules/lodash/fp/propOr.js create mode 100644 Bot/node_modules/lodash/fp/property.js create mode 100644 Bot/node_modules/lodash/fp/propertyOf.js create mode 100644 Bot/node_modules/lodash/fp/props.js create mode 100644 Bot/node_modules/lodash/fp/pull.js create mode 100644 Bot/node_modules/lodash/fp/pullAll.js create mode 100644 Bot/node_modules/lodash/fp/pullAllBy.js create mode 100644 Bot/node_modules/lodash/fp/pullAllWith.js create mode 100644 Bot/node_modules/lodash/fp/pullAt.js create mode 100644 Bot/node_modules/lodash/fp/random.js create mode 100644 Bot/node_modules/lodash/fp/range.js create mode 100644 Bot/node_modules/lodash/fp/rangeRight.js create mode 100644 Bot/node_modules/lodash/fp/rangeStep.js create mode 100644 Bot/node_modules/lodash/fp/rangeStepRight.js create mode 100644 Bot/node_modules/lodash/fp/rearg.js create mode 100644 Bot/node_modules/lodash/fp/reduce.js create mode 100644 Bot/node_modules/lodash/fp/reduceRight.js create mode 100644 Bot/node_modules/lodash/fp/reject.js create mode 100644 Bot/node_modules/lodash/fp/remove.js create mode 100644 Bot/node_modules/lodash/fp/repeat.js create mode 100644 Bot/node_modules/lodash/fp/replace.js create mode 100644 Bot/node_modules/lodash/fp/rest.js create mode 100644 Bot/node_modules/lodash/fp/restFrom.js create mode 100644 Bot/node_modules/lodash/fp/result.js create mode 100644 Bot/node_modules/lodash/fp/reverse.js create mode 100644 Bot/node_modules/lodash/fp/round.js create mode 100644 Bot/node_modules/lodash/fp/sample.js create mode 100644 Bot/node_modules/lodash/fp/sampleSize.js create mode 100644 Bot/node_modules/lodash/fp/seq.js create mode 100644 Bot/node_modules/lodash/fp/set.js create mode 100644 Bot/node_modules/lodash/fp/setWith.js create mode 100644 Bot/node_modules/lodash/fp/shuffle.js create mode 100644 Bot/node_modules/lodash/fp/size.js create mode 100644 Bot/node_modules/lodash/fp/slice.js create mode 100644 Bot/node_modules/lodash/fp/snakeCase.js create mode 100644 Bot/node_modules/lodash/fp/some.js create mode 100644 Bot/node_modules/lodash/fp/sortBy.js create mode 100644 Bot/node_modules/lodash/fp/sortedIndex.js create mode 100644 Bot/node_modules/lodash/fp/sortedIndexBy.js create mode 100644 Bot/node_modules/lodash/fp/sortedIndexOf.js create mode 100644 Bot/node_modules/lodash/fp/sortedLastIndex.js create mode 100644 Bot/node_modules/lodash/fp/sortedLastIndexBy.js create mode 100644 Bot/node_modules/lodash/fp/sortedLastIndexOf.js create mode 100644 Bot/node_modules/lodash/fp/sortedUniq.js create mode 100644 Bot/node_modules/lodash/fp/sortedUniqBy.js create mode 100644 Bot/node_modules/lodash/fp/split.js create mode 100644 Bot/node_modules/lodash/fp/spread.js create mode 100644 Bot/node_modules/lodash/fp/spreadFrom.js create mode 100644 Bot/node_modules/lodash/fp/startCase.js create mode 100644 Bot/node_modules/lodash/fp/startsWith.js create mode 100644 Bot/node_modules/lodash/fp/string.js create mode 100644 Bot/node_modules/lodash/fp/stubArray.js create mode 100644 Bot/node_modules/lodash/fp/stubFalse.js create mode 100644 Bot/node_modules/lodash/fp/stubObject.js create mode 100644 Bot/node_modules/lodash/fp/stubString.js create mode 100644 Bot/node_modules/lodash/fp/stubTrue.js create mode 100644 Bot/node_modules/lodash/fp/subtract.js create mode 100644 Bot/node_modules/lodash/fp/sum.js create mode 100644 Bot/node_modules/lodash/fp/sumBy.js create mode 100644 Bot/node_modules/lodash/fp/symmetricDifference.js create mode 100644 Bot/node_modules/lodash/fp/symmetricDifferenceBy.js create mode 100644 Bot/node_modules/lodash/fp/symmetricDifferenceWith.js create mode 100644 Bot/node_modules/lodash/fp/tail.js create mode 100644 Bot/node_modules/lodash/fp/take.js create mode 100644 Bot/node_modules/lodash/fp/takeLast.js create mode 100644 Bot/node_modules/lodash/fp/takeLastWhile.js create mode 100644 Bot/node_modules/lodash/fp/takeRight.js create mode 100644 Bot/node_modules/lodash/fp/takeRightWhile.js create mode 100644 Bot/node_modules/lodash/fp/takeWhile.js create mode 100644 Bot/node_modules/lodash/fp/tap.js create mode 100644 Bot/node_modules/lodash/fp/template.js create mode 100644 Bot/node_modules/lodash/fp/templateSettings.js create mode 100644 Bot/node_modules/lodash/fp/throttle.js create mode 100644 Bot/node_modules/lodash/fp/thru.js create mode 100644 Bot/node_modules/lodash/fp/times.js create mode 100644 Bot/node_modules/lodash/fp/toArray.js create mode 100644 Bot/node_modules/lodash/fp/toFinite.js create mode 100644 Bot/node_modules/lodash/fp/toInteger.js create mode 100644 Bot/node_modules/lodash/fp/toIterator.js create mode 100644 Bot/node_modules/lodash/fp/toJSON.js create mode 100644 Bot/node_modules/lodash/fp/toLength.js create mode 100644 Bot/node_modules/lodash/fp/toLower.js create mode 100644 Bot/node_modules/lodash/fp/toNumber.js create mode 100644 Bot/node_modules/lodash/fp/toPairs.js create mode 100644 Bot/node_modules/lodash/fp/toPairsIn.js create mode 100644 Bot/node_modules/lodash/fp/toPath.js create mode 100644 Bot/node_modules/lodash/fp/toPlainObject.js create mode 100644 Bot/node_modules/lodash/fp/toSafeInteger.js create mode 100644 Bot/node_modules/lodash/fp/toString.js create mode 100644 Bot/node_modules/lodash/fp/toUpper.js create mode 100644 Bot/node_modules/lodash/fp/transform.js create mode 100644 Bot/node_modules/lodash/fp/trim.js create mode 100644 Bot/node_modules/lodash/fp/trimChars.js create mode 100644 Bot/node_modules/lodash/fp/trimCharsEnd.js create mode 100644 Bot/node_modules/lodash/fp/trimCharsStart.js create mode 100644 Bot/node_modules/lodash/fp/trimEnd.js create mode 100644 Bot/node_modules/lodash/fp/trimStart.js create mode 100644 Bot/node_modules/lodash/fp/truncate.js create mode 100644 Bot/node_modules/lodash/fp/unapply.js create mode 100644 Bot/node_modules/lodash/fp/unary.js create mode 100644 Bot/node_modules/lodash/fp/unescape.js create mode 100644 Bot/node_modules/lodash/fp/union.js create mode 100644 Bot/node_modules/lodash/fp/unionBy.js create mode 100644 Bot/node_modules/lodash/fp/unionWith.js create mode 100644 Bot/node_modules/lodash/fp/uniq.js create mode 100644 Bot/node_modules/lodash/fp/uniqBy.js create mode 100644 Bot/node_modules/lodash/fp/uniqWith.js create mode 100644 Bot/node_modules/lodash/fp/uniqueId.js create mode 100644 Bot/node_modules/lodash/fp/unnest.js create mode 100644 Bot/node_modules/lodash/fp/unset.js create mode 100644 Bot/node_modules/lodash/fp/unzip.js create mode 100644 Bot/node_modules/lodash/fp/unzipWith.js create mode 100644 Bot/node_modules/lodash/fp/update.js create mode 100644 Bot/node_modules/lodash/fp/updateWith.js create mode 100644 Bot/node_modules/lodash/fp/upperCase.js create mode 100644 Bot/node_modules/lodash/fp/upperFirst.js create mode 100644 Bot/node_modules/lodash/fp/useWith.js create mode 100644 Bot/node_modules/lodash/fp/util.js create mode 100644 Bot/node_modules/lodash/fp/value.js create mode 100644 Bot/node_modules/lodash/fp/valueOf.js create mode 100644 Bot/node_modules/lodash/fp/values.js create mode 100644 Bot/node_modules/lodash/fp/valuesIn.js create mode 100644 Bot/node_modules/lodash/fp/where.js create mode 100644 Bot/node_modules/lodash/fp/whereEq.js create mode 100644 Bot/node_modules/lodash/fp/without.js create mode 100644 Bot/node_modules/lodash/fp/words.js create mode 100644 Bot/node_modules/lodash/fp/wrap.js create mode 100644 Bot/node_modules/lodash/fp/wrapperAt.js create mode 100644 Bot/node_modules/lodash/fp/wrapperChain.js create mode 100644 Bot/node_modules/lodash/fp/wrapperLodash.js create mode 100644 Bot/node_modules/lodash/fp/wrapperReverse.js create mode 100644 Bot/node_modules/lodash/fp/wrapperValue.js create mode 100644 Bot/node_modules/lodash/fp/xor.js create mode 100644 Bot/node_modules/lodash/fp/xorBy.js create mode 100644 Bot/node_modules/lodash/fp/xorWith.js create mode 100644 Bot/node_modules/lodash/fp/zip.js create mode 100644 Bot/node_modules/lodash/fp/zipAll.js create mode 100644 Bot/node_modules/lodash/fp/zipObj.js create mode 100644 Bot/node_modules/lodash/fp/zipObject.js create mode 100644 Bot/node_modules/lodash/fp/zipObjectDeep.js create mode 100644 Bot/node_modules/lodash/fp/zipWith.js create mode 100644 Bot/node_modules/lodash/fromPairs.js create mode 100644 Bot/node_modules/lodash/function.js create mode 100644 Bot/node_modules/lodash/functions.js create mode 100644 Bot/node_modules/lodash/functionsIn.js create mode 100644 Bot/node_modules/lodash/get.js create mode 100644 Bot/node_modules/lodash/groupBy.js create mode 100644 Bot/node_modules/lodash/gt.js create mode 100644 Bot/node_modules/lodash/gte.js create mode 100644 Bot/node_modules/lodash/has.js create mode 100644 Bot/node_modules/lodash/hasIn.js create mode 100644 Bot/node_modules/lodash/head.js create mode 100644 Bot/node_modules/lodash/identity.js create mode 100644 Bot/node_modules/lodash/inRange.js create mode 100644 Bot/node_modules/lodash/includes.js create mode 100644 Bot/node_modules/lodash/index.js create mode 100644 Bot/node_modules/lodash/indexOf.js create mode 100644 Bot/node_modules/lodash/initial.js create mode 100644 Bot/node_modules/lodash/intersection.js create mode 100644 Bot/node_modules/lodash/intersectionBy.js create mode 100644 Bot/node_modules/lodash/intersectionWith.js create mode 100644 Bot/node_modules/lodash/invert.js create mode 100644 Bot/node_modules/lodash/invertBy.js create mode 100644 Bot/node_modules/lodash/invoke.js create mode 100644 Bot/node_modules/lodash/invokeMap.js create mode 100644 Bot/node_modules/lodash/isArguments.js create mode 100644 Bot/node_modules/lodash/isArray.js create mode 100644 Bot/node_modules/lodash/isArrayBuffer.js create mode 100644 Bot/node_modules/lodash/isArrayLike.js create mode 100644 Bot/node_modules/lodash/isArrayLikeObject.js create mode 100644 Bot/node_modules/lodash/isBoolean.js create mode 100644 Bot/node_modules/lodash/isBuffer.js create mode 100644 Bot/node_modules/lodash/isDate.js create mode 100644 Bot/node_modules/lodash/isElement.js create mode 100644 Bot/node_modules/lodash/isEmpty.js create mode 100644 Bot/node_modules/lodash/isEqual.js create mode 100644 Bot/node_modules/lodash/isEqualWith.js create mode 100644 Bot/node_modules/lodash/isError.js create mode 100644 Bot/node_modules/lodash/isFinite.js create mode 100644 Bot/node_modules/lodash/isFunction.js create mode 100644 Bot/node_modules/lodash/isInteger.js create mode 100644 Bot/node_modules/lodash/isLength.js create mode 100644 Bot/node_modules/lodash/isMap.js create mode 100644 Bot/node_modules/lodash/isMatch.js create mode 100644 Bot/node_modules/lodash/isMatchWith.js create mode 100644 Bot/node_modules/lodash/isNaN.js create mode 100644 Bot/node_modules/lodash/isNative.js create mode 100644 Bot/node_modules/lodash/isNil.js create mode 100644 Bot/node_modules/lodash/isNull.js create mode 100644 Bot/node_modules/lodash/isNumber.js create mode 100644 Bot/node_modules/lodash/isObject.js create mode 100644 Bot/node_modules/lodash/isObjectLike.js create mode 100644 Bot/node_modules/lodash/isPlainObject.js create mode 100644 Bot/node_modules/lodash/isRegExp.js create mode 100644 Bot/node_modules/lodash/isSafeInteger.js create mode 100644 Bot/node_modules/lodash/isSet.js create mode 100644 Bot/node_modules/lodash/isString.js create mode 100644 Bot/node_modules/lodash/isSymbol.js create mode 100644 Bot/node_modules/lodash/isTypedArray.js create mode 100644 Bot/node_modules/lodash/isUndefined.js create mode 100644 Bot/node_modules/lodash/isWeakMap.js create mode 100644 Bot/node_modules/lodash/isWeakSet.js create mode 100644 Bot/node_modules/lodash/iteratee.js create mode 100644 Bot/node_modules/lodash/join.js create mode 100644 Bot/node_modules/lodash/kebabCase.js create mode 100644 Bot/node_modules/lodash/keyBy.js create mode 100644 Bot/node_modules/lodash/keys.js create mode 100644 Bot/node_modules/lodash/keysIn.js create mode 100644 Bot/node_modules/lodash/lang.js create mode 100644 Bot/node_modules/lodash/last.js create mode 100644 Bot/node_modules/lodash/lastIndexOf.js create mode 100644 Bot/node_modules/lodash/lodash.js create mode 100644 Bot/node_modules/lodash/lodash.min.js create mode 100644 Bot/node_modules/lodash/lowerCase.js create mode 100644 Bot/node_modules/lodash/lowerFirst.js create mode 100644 Bot/node_modules/lodash/lt.js create mode 100644 Bot/node_modules/lodash/lte.js create mode 100644 Bot/node_modules/lodash/map.js create mode 100644 Bot/node_modules/lodash/mapKeys.js create mode 100644 Bot/node_modules/lodash/mapValues.js create mode 100644 Bot/node_modules/lodash/matches.js create mode 100644 Bot/node_modules/lodash/matchesProperty.js create mode 100644 Bot/node_modules/lodash/math.js create mode 100644 Bot/node_modules/lodash/max.js create mode 100644 Bot/node_modules/lodash/maxBy.js create mode 100644 Bot/node_modules/lodash/mean.js create mode 100644 Bot/node_modules/lodash/meanBy.js create mode 100644 Bot/node_modules/lodash/memoize.js create mode 100644 Bot/node_modules/lodash/merge.js create mode 100644 Bot/node_modules/lodash/mergeWith.js create mode 100644 Bot/node_modules/lodash/method.js create mode 100644 Bot/node_modules/lodash/methodOf.js create mode 100644 Bot/node_modules/lodash/min.js create mode 100644 Bot/node_modules/lodash/minBy.js create mode 100644 Bot/node_modules/lodash/mixin.js create mode 100644 Bot/node_modules/lodash/multiply.js create mode 100644 Bot/node_modules/lodash/negate.js create mode 100644 Bot/node_modules/lodash/next.js create mode 100644 Bot/node_modules/lodash/noop.js create mode 100644 Bot/node_modules/lodash/now.js create mode 100644 Bot/node_modules/lodash/nth.js create mode 100644 Bot/node_modules/lodash/nthArg.js create mode 100644 Bot/node_modules/lodash/number.js create mode 100644 Bot/node_modules/lodash/object.js create mode 100644 Bot/node_modules/lodash/omit.js create mode 100644 Bot/node_modules/lodash/omitBy.js create mode 100644 Bot/node_modules/lodash/once.js create mode 100644 Bot/node_modules/lodash/orderBy.js create mode 100644 Bot/node_modules/lodash/over.js create mode 100644 Bot/node_modules/lodash/overArgs.js create mode 100644 Bot/node_modules/lodash/overEvery.js create mode 100644 Bot/node_modules/lodash/overSome.js create mode 100644 Bot/node_modules/lodash/package.json create mode 100644 Bot/node_modules/lodash/pad.js create mode 100644 Bot/node_modules/lodash/padEnd.js create mode 100644 Bot/node_modules/lodash/padStart.js create mode 100644 Bot/node_modules/lodash/parseInt.js create mode 100644 Bot/node_modules/lodash/partial.js create mode 100644 Bot/node_modules/lodash/partialRight.js create mode 100644 Bot/node_modules/lodash/partition.js create mode 100644 Bot/node_modules/lodash/pick.js create mode 100644 Bot/node_modules/lodash/pickBy.js create mode 100644 Bot/node_modules/lodash/plant.js create mode 100644 Bot/node_modules/lodash/property.js create mode 100644 Bot/node_modules/lodash/propertyOf.js create mode 100644 Bot/node_modules/lodash/pull.js create mode 100644 Bot/node_modules/lodash/pullAll.js create mode 100644 Bot/node_modules/lodash/pullAllBy.js create mode 100644 Bot/node_modules/lodash/pullAllWith.js create mode 100644 Bot/node_modules/lodash/pullAt.js create mode 100644 Bot/node_modules/lodash/random.js create mode 100644 Bot/node_modules/lodash/range.js create mode 100644 Bot/node_modules/lodash/rangeRight.js create mode 100644 Bot/node_modules/lodash/rearg.js create mode 100644 Bot/node_modules/lodash/reduce.js create mode 100644 Bot/node_modules/lodash/reduceRight.js create mode 100644 Bot/node_modules/lodash/reject.js create mode 100644 Bot/node_modules/lodash/release.md create mode 100644 Bot/node_modules/lodash/remove.js create mode 100644 Bot/node_modules/lodash/repeat.js create mode 100644 Bot/node_modules/lodash/replace.js create mode 100644 Bot/node_modules/lodash/rest.js create mode 100644 Bot/node_modules/lodash/result.js create mode 100644 Bot/node_modules/lodash/reverse.js create mode 100644 Bot/node_modules/lodash/round.js create mode 100644 Bot/node_modules/lodash/sample.js create mode 100644 Bot/node_modules/lodash/sampleSize.js create mode 100644 Bot/node_modules/lodash/seq.js create mode 100644 Bot/node_modules/lodash/set.js create mode 100644 Bot/node_modules/lodash/setWith.js create mode 100644 Bot/node_modules/lodash/shuffle.js create mode 100644 Bot/node_modules/lodash/size.js create mode 100644 Bot/node_modules/lodash/slice.js create mode 100644 Bot/node_modules/lodash/snakeCase.js create mode 100644 Bot/node_modules/lodash/some.js create mode 100644 Bot/node_modules/lodash/sortBy.js create mode 100644 Bot/node_modules/lodash/sortedIndex.js create mode 100644 Bot/node_modules/lodash/sortedIndexBy.js create mode 100644 Bot/node_modules/lodash/sortedIndexOf.js create mode 100644 Bot/node_modules/lodash/sortedLastIndex.js create mode 100644 Bot/node_modules/lodash/sortedLastIndexBy.js create mode 100644 Bot/node_modules/lodash/sortedLastIndexOf.js create mode 100644 Bot/node_modules/lodash/sortedUniq.js create mode 100644 Bot/node_modules/lodash/sortedUniqBy.js create mode 100644 Bot/node_modules/lodash/split.js create mode 100644 Bot/node_modules/lodash/spread.js create mode 100644 Bot/node_modules/lodash/startCase.js create mode 100644 Bot/node_modules/lodash/startsWith.js create mode 100644 Bot/node_modules/lodash/string.js create mode 100644 Bot/node_modules/lodash/stubArray.js create mode 100644 Bot/node_modules/lodash/stubFalse.js create mode 100644 Bot/node_modules/lodash/stubObject.js create mode 100644 Bot/node_modules/lodash/stubString.js create mode 100644 Bot/node_modules/lodash/stubTrue.js create mode 100644 Bot/node_modules/lodash/subtract.js create mode 100644 Bot/node_modules/lodash/sum.js create mode 100644 Bot/node_modules/lodash/sumBy.js create mode 100644 Bot/node_modules/lodash/tail.js create mode 100644 Bot/node_modules/lodash/take.js create mode 100644 Bot/node_modules/lodash/takeRight.js create mode 100644 Bot/node_modules/lodash/takeRightWhile.js create mode 100644 Bot/node_modules/lodash/takeWhile.js create mode 100644 Bot/node_modules/lodash/tap.js create mode 100644 Bot/node_modules/lodash/template.js create mode 100644 Bot/node_modules/lodash/templateSettings.js create mode 100644 Bot/node_modules/lodash/throttle.js create mode 100644 Bot/node_modules/lodash/thru.js create mode 100644 Bot/node_modules/lodash/times.js create mode 100644 Bot/node_modules/lodash/toArray.js create mode 100644 Bot/node_modules/lodash/toFinite.js create mode 100644 Bot/node_modules/lodash/toInteger.js create mode 100644 Bot/node_modules/lodash/toIterator.js create mode 100644 Bot/node_modules/lodash/toJSON.js create mode 100644 Bot/node_modules/lodash/toLength.js create mode 100644 Bot/node_modules/lodash/toLower.js create mode 100644 Bot/node_modules/lodash/toNumber.js create mode 100644 Bot/node_modules/lodash/toPairs.js create mode 100644 Bot/node_modules/lodash/toPairsIn.js create mode 100644 Bot/node_modules/lodash/toPath.js create mode 100644 Bot/node_modules/lodash/toPlainObject.js create mode 100644 Bot/node_modules/lodash/toSafeInteger.js create mode 100644 Bot/node_modules/lodash/toString.js create mode 100644 Bot/node_modules/lodash/toUpper.js create mode 100644 Bot/node_modules/lodash/transform.js create mode 100644 Bot/node_modules/lodash/trim.js create mode 100644 Bot/node_modules/lodash/trimEnd.js create mode 100644 Bot/node_modules/lodash/trimStart.js create mode 100644 Bot/node_modules/lodash/truncate.js create mode 100644 Bot/node_modules/lodash/unary.js create mode 100644 Bot/node_modules/lodash/unescape.js create mode 100644 Bot/node_modules/lodash/union.js create mode 100644 Bot/node_modules/lodash/unionBy.js create mode 100644 Bot/node_modules/lodash/unionWith.js create mode 100644 Bot/node_modules/lodash/uniq.js create mode 100644 Bot/node_modules/lodash/uniqBy.js create mode 100644 Bot/node_modules/lodash/uniqWith.js create mode 100644 Bot/node_modules/lodash/uniqueId.js create mode 100644 Bot/node_modules/lodash/unset.js create mode 100644 Bot/node_modules/lodash/unzip.js create mode 100644 Bot/node_modules/lodash/unzipWith.js create mode 100644 Bot/node_modules/lodash/update.js create mode 100644 Bot/node_modules/lodash/updateWith.js create mode 100644 Bot/node_modules/lodash/upperCase.js create mode 100644 Bot/node_modules/lodash/upperFirst.js create mode 100644 Bot/node_modules/lodash/util.js create mode 100644 Bot/node_modules/lodash/value.js create mode 100644 Bot/node_modules/lodash/valueOf.js create mode 100644 Bot/node_modules/lodash/values.js create mode 100644 Bot/node_modules/lodash/valuesIn.js create mode 100644 Bot/node_modules/lodash/without.js create mode 100644 Bot/node_modules/lodash/words.js create mode 100644 Bot/node_modules/lodash/wrap.js create mode 100644 Bot/node_modules/lodash/wrapperAt.js create mode 100644 Bot/node_modules/lodash/wrapperChain.js create mode 100644 Bot/node_modules/lodash/wrapperLodash.js create mode 100644 Bot/node_modules/lodash/wrapperReverse.js create mode 100644 Bot/node_modules/lodash/wrapperValue.js create mode 100644 Bot/node_modules/lodash/xor.js create mode 100644 Bot/node_modules/lodash/xorBy.js create mode 100644 Bot/node_modules/lodash/xorWith.js create mode 100644 Bot/node_modules/lodash/zip.js create mode 100644 Bot/node_modules/lodash/zipObject.js create mode 100644 Bot/node_modules/lodash/zipObjectDeep.js create mode 100644 Bot/node_modules/lodash/zipWith.js create mode 100644 Bot/node_modules/magic-bytes.js/.gitattributes create mode 100644 Bot/node_modules/magic-bytes.js/.github/workflows/build-and-test.yml create mode 100644 Bot/node_modules/magic-bytes.js/.github/workflows/static-webapp.yml create mode 100644 Bot/node_modules/magic-bytes.js/.prettierignore create mode 100644 Bot/node_modules/magic-bytes.js/LICENSE create mode 100644 Bot/node_modules/magic-bytes.js/README.md create mode 100644 Bot/node_modules/magic-bytes.js/commitlint.config.js create mode 100644 Bot/node_modules/magic-bytes.js/dist/index.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/index.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/dist/index.js create mode 100644 Bot/node_modules/magic-bytes.js/dist/index.spec.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/index.spec.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/pattern-tree.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/pattern-tree.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/pattern-tree.js create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/toHex.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/toHex.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/toHex.js create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/tree.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/tree.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/tree.js create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/tree.spec.d.ts create mode 100644 Bot/node_modules/magic-bytes.js/dist/model/tree.spec.d.ts.map create mode 100644 Bot/node_modules/magic-bytes.js/jest.config.js create mode 100644 Bot/node_modules/magic-bytes.js/package.json create mode 100644 Bot/node_modules/magic-bytes.js/tsconfig.json create mode 100644 Bot/node_modules/mime-db/HISTORY.md create mode 100644 Bot/node_modules/mime-db/LICENSE create mode 100644 Bot/node_modules/mime-db/README.md create mode 100644 Bot/node_modules/mime-db/db.json create mode 100644 Bot/node_modules/mime-db/index.js create mode 100644 Bot/node_modules/mime-db/package.json create mode 100644 Bot/node_modules/mime-types/HISTORY.md create mode 100644 Bot/node_modules/mime-types/LICENSE create mode 100644 Bot/node_modules/mime-types/README.md create mode 100644 Bot/node_modules/mime-types/index.js create mode 100644 Bot/node_modules/mime-types/package.json create mode 100644 Bot/node_modules/proxy-from-env/.eslintrc create mode 100644 Bot/node_modules/proxy-from-env/.travis.yml create mode 100644 Bot/node_modules/proxy-from-env/LICENSE create mode 100644 Bot/node_modules/proxy-from-env/README.md create mode 100644 Bot/node_modules/proxy-from-env/index.js create mode 100644 Bot/node_modules/proxy-from-env/package.json create mode 100644 Bot/node_modules/proxy-from-env/test.js create mode 100644 Bot/node_modules/ts-mixer/CHANGELOG.md create mode 100644 Bot/node_modules/ts-mixer/LICENSE create mode 100644 Bot/node_modules/ts-mixer/README.md create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/decorator.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/index.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/mixin-tracking.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/mixins.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/proxy.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/settings.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/types.js create mode 100644 Bot/node_modules/ts-mixer/dist/cjs/util.js create mode 100644 Bot/node_modules/ts-mixer/dist/esm/decorator.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/index.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/index.js create mode 100644 Bot/node_modules/ts-mixer/dist/esm/index.min.js create mode 100644 Bot/node_modules/ts-mixer/dist/esm/mixin-tracking.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/mixins.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/proxy.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/settings.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/types.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/esm/util.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/decorator.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/index.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/mixin-tracking.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/mixins.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/proxy.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/settings.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/types.d.ts create mode 100644 Bot/node_modules/ts-mixer/dist/types/util.d.ts create mode 100644 Bot/node_modules/ts-mixer/package.json create mode 100644 Bot/node_modules/tslib/CopyrightNotice.txt create mode 100644 Bot/node_modules/tslib/LICENSE.txt create mode 100644 Bot/node_modules/tslib/README.md create mode 100644 Bot/node_modules/tslib/SECURITY.md create mode 100644 Bot/node_modules/tslib/modules/index.d.ts create mode 100644 Bot/node_modules/tslib/modules/index.js create mode 100644 Bot/node_modules/tslib/modules/package.json create mode 100644 Bot/node_modules/tslib/package.json create mode 100644 Bot/node_modules/tslib/tslib.d.ts create mode 100644 Bot/node_modules/tslib/tslib.es6.html create mode 100644 Bot/node_modules/tslib/tslib.es6.js create mode 100644 Bot/node_modules/tslib/tslib.es6.mjs create mode 100644 Bot/node_modules/tslib/tslib.html create mode 100644 Bot/node_modules/tslib/tslib.js create mode 100644 Bot/node_modules/undici-types/README.md create mode 100644 Bot/node_modules/undici-types/agent.d.ts create mode 100644 Bot/node_modules/undici-types/api.d.ts create mode 100644 Bot/node_modules/undici-types/balanced-pool.d.ts create mode 100644 Bot/node_modules/undici-types/cache.d.ts create mode 100644 Bot/node_modules/undici-types/client.d.ts create mode 100644 Bot/node_modules/undici-types/connector.d.ts create mode 100644 Bot/node_modules/undici-types/content-type.d.ts create mode 100644 Bot/node_modules/undici-types/cookies.d.ts create mode 100644 Bot/node_modules/undici-types/diagnostics-channel.d.ts create mode 100644 Bot/node_modules/undici-types/dispatcher.d.ts create mode 100644 Bot/node_modules/undici-types/errors.d.ts create mode 100644 Bot/node_modules/undici-types/fetch.d.ts create mode 100644 Bot/node_modules/undici-types/file.d.ts create mode 100644 Bot/node_modules/undici-types/filereader.d.ts create mode 100644 Bot/node_modules/undici-types/formdata.d.ts create mode 100644 Bot/node_modules/undici-types/global-dispatcher.d.ts create mode 100644 Bot/node_modules/undici-types/global-origin.d.ts create mode 100644 Bot/node_modules/undici-types/handlers.d.ts create mode 100644 Bot/node_modules/undici-types/header.d.ts create mode 100644 Bot/node_modules/undici-types/index.d.ts create mode 100644 Bot/node_modules/undici-types/interceptors.d.ts create mode 100644 Bot/node_modules/undici-types/mock-agent.d.ts create mode 100644 Bot/node_modules/undici-types/mock-client.d.ts create mode 100644 Bot/node_modules/undici-types/mock-errors.d.ts create mode 100644 Bot/node_modules/undici-types/mock-interceptor.d.ts create mode 100644 Bot/node_modules/undici-types/mock-pool.d.ts create mode 100644 Bot/node_modules/undici-types/package.json create mode 100644 Bot/node_modules/undici-types/patch.d.ts create mode 100644 Bot/node_modules/undici-types/pool-stats.d.ts create mode 100644 Bot/node_modules/undici-types/pool.d.ts create mode 100644 Bot/node_modules/undici-types/proxy-agent.d.ts create mode 100644 Bot/node_modules/undici-types/readable.d.ts create mode 100644 Bot/node_modules/undici-types/webidl.d.ts create mode 100644 Bot/node_modules/undici-types/websocket.d.ts create mode 100644 Bot/node_modules/undici/LICENSE create mode 100644 Bot/node_modules/undici/README.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Agent.md create mode 100644 Bot/node_modules/undici/docs/docs/api/BalancedPool.md create mode 100644 Bot/node_modules/undici/docs/docs/api/CacheStorage.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Client.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Connector.md create mode 100644 Bot/node_modules/undici/docs/docs/api/ContentType.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Cookies.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Debug.md create mode 100644 Bot/node_modules/undici/docs/docs/api/DiagnosticsChannel.md create mode 100644 Bot/node_modules/undici/docs/docs/api/DispatchInterceptor.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Dispatcher.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Errors.md create mode 100644 Bot/node_modules/undici/docs/docs/api/EventSource.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Fetch.md create mode 100644 Bot/node_modules/undici/docs/docs/api/MockAgent.md create mode 100644 Bot/node_modules/undici/docs/docs/api/MockClient.md create mode 100644 Bot/node_modules/undici/docs/docs/api/MockErrors.md create mode 100644 Bot/node_modules/undici/docs/docs/api/MockPool.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Pool.md create mode 100644 Bot/node_modules/undici/docs/docs/api/PoolStats.md create mode 100644 Bot/node_modules/undici/docs/docs/api/ProxyAgent.md create mode 100644 Bot/node_modules/undici/docs/docs/api/RedirectHandler.md create mode 100644 Bot/node_modules/undici/docs/docs/api/RetryAgent.md create mode 100644 Bot/node_modules/undici/docs/docs/api/RetryHandler.md create mode 100644 Bot/node_modules/undici/docs/docs/api/Util.md create mode 100644 Bot/node_modules/undici/docs/docs/api/WebSocket.md create mode 100644 Bot/node_modules/undici/docs/docs/api/api-lifecycle.md create mode 100644 Bot/node_modules/undici/docs/docs/best-practices/client-certificate.md create mode 100644 Bot/node_modules/undici/docs/docs/best-practices/mocking-request.md create mode 100644 Bot/node_modules/undici/docs/docs/best-practices/proxy.md create mode 100644 Bot/node_modules/undici/docs/docs/best-practices/writing-tests.md create mode 100644 Bot/node_modules/undici/index-fetch.js create mode 100644 Bot/node_modules/undici/index.d.ts create mode 100644 Bot/node_modules/undici/index.js create mode 100644 Bot/node_modules/undici/lib/api/abort-signal.js create mode 100644 Bot/node_modules/undici/lib/api/api-connect.js create mode 100644 Bot/node_modules/undici/lib/api/api-pipeline.js create mode 100644 Bot/node_modules/undici/lib/api/api-request.js create mode 100644 Bot/node_modules/undici/lib/api/api-stream.js create mode 100644 Bot/node_modules/undici/lib/api/api-upgrade.js create mode 100644 Bot/node_modules/undici/lib/api/index.js create mode 100644 Bot/node_modules/undici/lib/api/readable.js create mode 100644 Bot/node_modules/undici/lib/api/util.js create mode 100644 Bot/node_modules/undici/lib/core/connect.js create mode 100644 Bot/node_modules/undici/lib/core/constants.js create mode 100644 Bot/node_modules/undici/lib/core/diagnostics.js create mode 100644 Bot/node_modules/undici/lib/core/errors.js create mode 100644 Bot/node_modules/undici/lib/core/request.js create mode 100644 Bot/node_modules/undici/lib/core/symbols.js create mode 100644 Bot/node_modules/undici/lib/core/tree.js create mode 100644 Bot/node_modules/undici/lib/core/util.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/agent.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/balanced-pool.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/client-h1.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/client-h2.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/client.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/dispatcher-base.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/dispatcher.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/fixed-queue.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/pool-base.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/pool-stats.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/pool.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/proxy-agent.js create mode 100644 Bot/node_modules/undici/lib/dispatcher/retry-agent.js create mode 100644 Bot/node_modules/undici/lib/global.js create mode 100644 Bot/node_modules/undici/lib/handler/decorator-handler.js create mode 100644 Bot/node_modules/undici/lib/handler/redirect-handler.js create mode 100644 Bot/node_modules/undici/lib/handler/retry-handler.js create mode 100644 Bot/node_modules/undici/lib/interceptor/redirect-interceptor.js create mode 100644 Bot/node_modules/undici/lib/interceptor/redirect.js create mode 100644 Bot/node_modules/undici/lib/interceptor/retry.js create mode 100644 Bot/node_modules/undici/lib/llhttp/constants.d.ts create mode 100644 Bot/node_modules/undici/lib/llhttp/constants.js create mode 100644 Bot/node_modules/undici/lib/llhttp/constants.js.map create mode 100644 Bot/node_modules/undici/lib/llhttp/llhttp-wasm.js create mode 100644 Bot/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js create mode 100644 Bot/node_modules/undici/lib/llhttp/utils.d.ts create mode 100644 Bot/node_modules/undici/lib/llhttp/utils.js create mode 100644 Bot/node_modules/undici/lib/llhttp/utils.js.map create mode 100644 Bot/node_modules/undici/lib/llhttp/wasm_build_env.txt create mode 100644 Bot/node_modules/undici/lib/mock/mock-agent.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-client.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-errors.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-interceptor.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-pool.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-symbols.js create mode 100644 Bot/node_modules/undici/lib/mock/mock-utils.js create mode 100644 Bot/node_modules/undici/lib/mock/pending-interceptors-formatter.js create mode 100644 Bot/node_modules/undici/lib/mock/pluralizer.js create mode 100644 Bot/node_modules/undici/lib/util/timers.js create mode 100644 Bot/node_modules/undici/lib/web/cache/cache.js create mode 100644 Bot/node_modules/undici/lib/web/cache/cachestorage.js create mode 100644 Bot/node_modules/undici/lib/web/cache/symbols.js create mode 100644 Bot/node_modules/undici/lib/web/cache/util.js create mode 100644 Bot/node_modules/undici/lib/web/cookies/constants.js create mode 100644 Bot/node_modules/undici/lib/web/cookies/index.js create mode 100644 Bot/node_modules/undici/lib/web/cookies/parse.js create mode 100644 Bot/node_modules/undici/lib/web/cookies/util.js create mode 100644 Bot/node_modules/undici/lib/web/eventsource/eventsource-stream.js create mode 100644 Bot/node_modules/undici/lib/web/eventsource/eventsource.js create mode 100644 Bot/node_modules/undici/lib/web/eventsource/util.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/LICENSE create mode 100644 Bot/node_modules/undici/lib/web/fetch/body.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/constants.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/data-url.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/dispatcher-weakref.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/file.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/formdata-parser.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/formdata.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/global.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/headers.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/index.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/request.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/response.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/symbols.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/util.js create mode 100644 Bot/node_modules/undici/lib/web/fetch/webidl.js create mode 100644 Bot/node_modules/undici/lib/web/fileapi/encoding.js create mode 100644 Bot/node_modules/undici/lib/web/fileapi/filereader.js create mode 100644 Bot/node_modules/undici/lib/web/fileapi/progressevent.js create mode 100644 Bot/node_modules/undici/lib/web/fileapi/symbols.js create mode 100644 Bot/node_modules/undici/lib/web/fileapi/util.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/connection.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/constants.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/events.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/frame.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/receiver.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/symbols.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/util.js create mode 100644 Bot/node_modules/undici/lib/web/websocket/websocket.js create mode 100644 Bot/node_modules/undici/package.json create mode 100644 Bot/node_modules/undici/scripts/strip-comments.js create mode 100644 Bot/node_modules/undici/types/README.md create mode 100644 Bot/node_modules/undici/types/agent.d.ts create mode 100644 Bot/node_modules/undici/types/api.d.ts create mode 100644 Bot/node_modules/undici/types/balanced-pool.d.ts create mode 100644 Bot/node_modules/undici/types/cache.d.ts create mode 100644 Bot/node_modules/undici/types/client.d.ts create mode 100644 Bot/node_modules/undici/types/connector.d.ts create mode 100644 Bot/node_modules/undici/types/content-type.d.ts create mode 100644 Bot/node_modules/undici/types/cookies.d.ts create mode 100644 Bot/node_modules/undici/types/diagnostics-channel.d.ts create mode 100644 Bot/node_modules/undici/types/dispatcher.d.ts create mode 100644 Bot/node_modules/undici/types/errors.d.ts create mode 100644 Bot/node_modules/undici/types/eventsource.d.ts create mode 100644 Bot/node_modules/undici/types/fetch.d.ts create mode 100644 Bot/node_modules/undici/types/file.d.ts create mode 100644 Bot/node_modules/undici/types/filereader.d.ts create mode 100644 Bot/node_modules/undici/types/formdata.d.ts create mode 100644 Bot/node_modules/undici/types/global-dispatcher.d.ts create mode 100644 Bot/node_modules/undici/types/global-origin.d.ts create mode 100644 Bot/node_modules/undici/types/handlers.d.ts create mode 100644 Bot/node_modules/undici/types/header.d.ts create mode 100644 Bot/node_modules/undici/types/index.d.ts create mode 100644 Bot/node_modules/undici/types/interceptors.d.ts create mode 100644 Bot/node_modules/undici/types/mock-agent.d.ts create mode 100644 Bot/node_modules/undici/types/mock-client.d.ts create mode 100644 Bot/node_modules/undici/types/mock-errors.d.ts create mode 100644 Bot/node_modules/undici/types/mock-interceptor.d.ts create mode 100644 Bot/node_modules/undici/types/mock-pool.d.ts create mode 100644 Bot/node_modules/undici/types/patch.d.ts create mode 100644 Bot/node_modules/undici/types/pool-stats.d.ts create mode 100644 Bot/node_modules/undici/types/pool.d.ts create mode 100644 Bot/node_modules/undici/types/proxy-agent.d.ts create mode 100644 Bot/node_modules/undici/types/readable.d.ts create mode 100644 Bot/node_modules/undici/types/retry-agent.d.ts create mode 100644 Bot/node_modules/undici/types/retry-handler.d.ts create mode 100644 Bot/node_modules/undici/types/util.d.ts create mode 100644 Bot/node_modules/undici/types/webidl.d.ts create mode 100644 Bot/node_modules/undici/types/websocket.d.ts create mode 100644 Bot/node_modules/ws/LICENSE create mode 100644 Bot/node_modules/ws/README.md create mode 100644 Bot/node_modules/ws/browser.js create mode 100644 Bot/node_modules/ws/index.js create mode 100644 Bot/node_modules/ws/lib/buffer-util.js create mode 100644 Bot/node_modules/ws/lib/constants.js create mode 100644 Bot/node_modules/ws/lib/event-target.js create mode 100644 Bot/node_modules/ws/lib/extension.js create mode 100644 Bot/node_modules/ws/lib/limiter.js create mode 100644 Bot/node_modules/ws/lib/permessage-deflate.js create mode 100644 Bot/node_modules/ws/lib/receiver.js create mode 100644 Bot/node_modules/ws/lib/sender.js create mode 100644 Bot/node_modules/ws/lib/stream.js create mode 100644 Bot/node_modules/ws/lib/subprotocol.js create mode 100644 Bot/node_modules/ws/lib/validation.js create mode 100644 Bot/node_modules/ws/lib/websocket-server.js create mode 100644 Bot/node_modules/ws/lib/websocket.js create mode 100644 Bot/node_modules/ws/package.json create mode 100644 Bot/node_modules/ws/wrapper.mjs create mode 100644 Bot/package-lock.json create mode 100644 Bot/package.json diff --git a/Bot/config.json b/Bot/config.json new file mode 100644 index 0000000..f554b24 --- /dev/null +++ b/Bot/config.json @@ -0,0 +1,7 @@ +{ + "token": "", + "guildID": "", + "channelID": "", + "clientID": "1241485556949450915", + "updatetime": "5" +} \ No newline at end of file diff --git a/Bot/index.js b/Bot/index.js new file mode 100644 index 0000000..64f3c23 --- /dev/null +++ b/Bot/index.js @@ -0,0 +1,134 @@ +const { Client, GatewayIntentBits, EmbedBuilder } = require('discord.js'); +const axios = require('axios'); +const config = require('./config.json'); + +const client = new Client({ + intents: [ + GatewayIntentBits.Guilds, + GatewayIntentBits.GuildMessages, + GatewayIntentBits.MessageContent + ] +}); + +let monitorMessages = { + Gaming: null, + Discord: null, + Web: null +}; + +client.once('ready', async () => { + console.log('Bot is online!'); + + const channel = await client.channels.fetch(config.channelID); +if (channel && channel.isTextBased()) { + await clearChannel(channel); +} else { + console.error(`Unable to find text channel with ID ${config.channelID}`); +} + // Call the function to update messages immediately + await updateMessages(); + // Set interval to update messages every 30 seconds + setInterval(updateMessages, config.updatetime * 1000); +}); + +async function updateMessages() { + try { + const guild = await client.guilds.fetch(config.guildID); + if (!guild) { + console.error(`Unable to find guild with ID ${config.guildID}`); + return; + } + + const channel = await guild.channels.fetch(config.channelID); + if (!channel || !channel.isTextBased()) { + console.error(`Unable to find text channel with ID ${config.channelID}`); + return; + } + + const response = await axios.get(''); + const monitors = response.data; + + const gamingMonitors = monitors.filter(monitor => [ + 'Lobby', 'Skyblock', 'Survival', 'Creative', 'KitPvP', 'Factions', 'Prison', 'Skywars' + ].includes(monitor.monitor_name)); + + const discordMonitors = monitors.filter(monitor => [ + 'Discord bot', 'Status bot' + ].includes(monitor.monitor_name)); + + const webMonitors = monitors.filter(monitor => [ + 'web1', 'web2', 'web3' + ].includes(monitor.monitor_name)); + + await sendMonitorsMessage(channel, 'Gaming', gamingMonitors); + await sendMonitorsMessage(channel, 'Discord', discordMonitors); + await sendMonitorsMessage(channel, 'Web', webMonitors); + + } catch (error) { + console.error('Error:', error); + } +} + +async function sendMonitorsMessage(channel, category, monitors) { + let description = monitors.map(monitor => { + let statusEmoji = ''; + switch (monitor.status) { + case 0: + statusEmoji = '🔴'; // Offline + break; + case 1: + statusEmoji = '🟢'; // Online + break; + case 2: + statusEmoji = '🟡'; // Warning + break; + case 3: + statusEmoji = '🔵'; // Maintenance + break; + default: + statusEmoji = '❓'; // Unknown + } + return `${statusEmoji} | ${monitor.monitor_name}`; + }).join('\n'); + + let embed = new EmbedBuilder() + .setTitle(`${category} Monitor`) + .setColor('#0099ff') + .setDescription(description) + .setFooter({ text: `Last updated: ${new Date().toLocaleString()}` }) + .setURL(''); + + try { + + if (monitorMessages[category]) { + const message = await channel.messages.fetch(monitorMessages[category]); + if (message) { + await message.edit({ embeds: [embed] }); + console.log(`${new Date().toLocaleString()} | Updated ${category} monitors message`); + } else { + const newMessage = await channel.send({ embeds: [embed] }); + monitorMessages[category] = newMessage.id; + console.log(`${new Date().toLocaleString()} | Sent new ${category} monitors message`); + } + } else { + const newMessage = await channel.send({ embeds: [embed] }); + monitorMessages[category] = newMessage.id; + console.log(`${new Date().toLocaleString()} | Sent ${category} monitors message`); + } + } catch (error) { + console.error(`Failed to send/update ${category} monitors message:`, error); + } +} + +async function clearChannel(channel) { + try { + const fetchedMessages = await channel.messages.fetch(); + await channel.bulkDelete(fetchedMessages); + console.log('Cleared channel'); + } catch (error) { + console.error('Error clearing channel:', error); + } +} +client.login(config.token).catch(error => { + console.error('Error logging in:', error); +}); \ No newline at end of file diff --git a/Bot/index_with_comments.js b/Bot/index_with_comments.js new file mode 100644 index 0000000..258046a --- /dev/null +++ b/Bot/index_with_comments.js @@ -0,0 +1,158 @@ +// Import required classes from discord.js and axios for making HTTP requests +const { Client, GatewayIntentBits, EmbedBuilder } = require('discord.js'); +const axios = require('axios'); +const config = require('./config.json'); + +// Create a new Discord client instance with specified intents +const client = new Client({ + intents: [ + GatewayIntentBits.Guilds, + GatewayIntentBits.GuildMessages, + GatewayIntentBits.MessageContent + ] +}); + +// Object to store the IDs of the monitor messages +let monitorMessages = { + Gaming: null, + Discord: null, + Web: null +}; + +// Event listener for when the bot is ready +client.once('ready', async () => { + console.log('Bot is online!'); + + // Fetch the channel using the channel ID from the config + const channel = await client.channels.fetch(config.channelID); + + if (channel && channel.isTextBased()) { + // Clear the channel if it's a text-based channel + await clearChannel(channel); + } else { + console.error(`Unable to find text channel with ID ${config.channelID}`); + } + + // Call the function to update messages immediately + await updateMessages(); + // Set interval to update messages every configured seconds + setInterval(updateMessages, config.updatetime * 1000); +}); + +// Function to update monitor messages +async function updateMessages() { + try { + // Fetch the guild using the guild ID from the config + const guild = await client.guilds.fetch(config.guildID); + if (!guild) { + console.error(`Unable to find guild with ID ${config.guildID}`); + return; + } + + // Fetch the channel using the channel ID from the config + const channel = await guild.channels.fetch(config.channelID); + if (!channel || !channel.isTextBased()) { + console.error(`Unable to find text channel with ID ${config.channelID}`); + return; + } + + // Make a GET request to the backend to fetch monitor data + const response = await axios.get(''); + const monitors = response.data; + + // Filter monitors into categories + const gamingMonitors = monitors.filter(monitor => [ + 'Lobby', 'Skyblock', 'Survival', 'Creative', 'KitPvP', 'Factions', 'Prison', 'Skywars' + ].includes(monitor.monitor_name)); + + const discordMonitors = monitors.filter(monitor => [ + 'Discord bot', 'Status bot' + ].includes(monitor.monitor_name)); + + const webMonitors = monitors.filter(monitor => [ + 'web1', 'web2', 'web3' + ].includes(monitor.monitor_name)); + + // Send or update monitor messages in the channel + await sendMonitorsMessage(channel, 'Gaming', gamingMonitors); + await sendMonitorsMessage(channel, 'Discord', discordMonitors); + await sendMonitorsMessage(channel, 'Web', webMonitors); + + } catch (error) { + console.error('Error:', error); + } +} + +// Function to send or update a monitor message in the channel +async function sendMonitorsMessage(channel, category, monitors) { + // Create the description for the embed message + let description = monitors.map(monitor => { + let statusEmoji = ''; + switch (monitor.status) { + case 0: + statusEmoji = '🔴'; // Offline + break; + case 1: + statusEmoji = '🟢'; // Online + break; + case 2: + statusEmoji = '🟡'; // Warning + break; + case 3: + statusEmoji = '🔵'; // Maintenance + break; + default: + statusEmoji = '❓'; // Unknown + } + return `${statusEmoji} | ${monitor.monitor_name}`; + }).join('\n'); + + // Create the embed message + let embed = new EmbedBuilder() + .setTitle(`${category} Monitor`) + .setColor('#0099ff') + .setDescription(description) + .setFooter({ text: `Last updated: ${new Date().toLocaleString()}` }) + .setURL(''); + + try { + // Check if there is an existing message to update or send a new one + if (monitorMessages[category]) { + const message = await channel.messages.fetch(monitorMessages[category]); + if (message) { + // Update the existing message + await message.edit({ embeds: [embed] }); + console.log(`${new Date().toLocaleString()} | Updated ${category} monitors message`); + } else { + // Send a new message if the existing one was not found + const newMessage = await channel.send({ embeds: [embed] }); + monitorMessages[category] = newMessage.id; + console.log(`${new Date().toLocaleString()} | Sent new ${category} monitors message`); + } + } else { + // Send a new message if there is no existing message ID + const newMessage = await channel.send({ embeds: [embed] }); + monitorMessages[category] = newMessage.id; + console.log(`${new Date().toLocaleString()} | Sent ${category} monitors message`); + } + } catch (error) { + console.error(`Failed to send/update ${category} monitors message:`, error); + } +} + +// Function to clear the messages in a channel +async function clearChannel(channel) { + try { + // Fetch all messages in the channel and bulk delete them + const fetchedMessages = await channel.messages.fetch(); + await channel.bulkDelete(fetchedMessages); + console.log('Cleared channel'); + } catch (error) { + console.error('Error clearing channel:', error); + } +} + +// Log in to Discord with the bot token from the config +client.login(config.token).catch(error => { + console.error('Error logging in:', error); +}); diff --git a/Bot/node_modules/.package-lock.json b/Bot/node_modules/.package-lock.json new file mode 100644 index 0000000..4c0387d --- /dev/null +++ b/Bot/node_modules/.package-lock.json @@ -0,0 +1,399 @@ +{ + "name": "statusbot", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "node_modules/@discordjs/builders": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/@discordjs/builders/-/builders-1.8.1.tgz", + "integrity": "sha512-GkF+HM01FHy+NSoTaUPR8z44otfQgJ1AIsRxclYGUZDyUbdZEFyD/5QVv2Y1Flx6M+B0bQLzg2M9CJv5lGTqpA==", + "license": "Apache-2.0", + "dependencies": { + "@discordjs/formatters": "^0.4.0", + "@discordjs/util": "^1.1.0", + "@sapphire/shapeshift": "^3.9.7", + "discord-api-types": "0.37.83", + "fast-deep-equal": "^3.1.3", + "ts-mixer": "^6.0.4", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/collection": { + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-1.5.3.tgz", + "integrity": "sha512-SVb428OMd3WO1paV3rm6tSjM4wC+Kecaa1EUGX7vc6/fddvw/6lg90z4QtCqm21zvVe92vMMDt9+DkIvjXImQQ==", + "license": "Apache-2.0", + "engines": { + "node": ">=16.11.0" + } + }, + "node_modules/@discordjs/formatters": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@discordjs/formatters/-/formatters-0.4.0.tgz", + "integrity": "sha512-fJ06TLC1NiruF35470q3Nr1bi95BdvKFAF+T5bNfZJ4bNdqZ3VZ+Ttg6SThqTxm6qumSG3choxLBHMC69WXNXQ==", + "license": "Apache-2.0", + "dependencies": { + "discord-api-types": "0.37.83" + }, + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/rest": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@discordjs/rest/-/rest-2.3.0.tgz", + "integrity": "sha512-C1kAJK8aSYRv3ZwMG8cvrrW4GN0g5eMdP8AuN8ODH5DyOCbHgJspze1my3xHOAgwLJdKUbWNVyAeJ9cEdduqIg==", + "license": "Apache-2.0", + "dependencies": { + "@discordjs/collection": "^2.1.0", + "@discordjs/util": "^1.1.0", + "@sapphire/async-queue": "^1.5.2", + "@sapphire/snowflake": "^3.5.3", + "@vladfrangu/async_event_emitter": "^2.2.4", + "discord-api-types": "0.37.83", + "magic-bytes.js": "^1.10.0", + "tslib": "^2.6.2", + "undici": "6.13.0" + }, + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/rest/node_modules/@discordjs/collection": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-2.1.0.tgz", + "integrity": "sha512-mLcTACtXUuVgutoznkh6hS3UFqYirDYAg5Dc1m8xn6OvPjetnUlf/xjtqnnc47OwWdaoCQnHmHh9KofhD6uRqw==", + "license": "Apache-2.0", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/util": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@discordjs/util/-/util-1.1.0.tgz", + "integrity": "sha512-IndcI5hzlNZ7GS96RV3Xw1R2kaDuXEp7tRIy/KlhidpN/BQ1qh1NZt3377dMLTa44xDUNKT7hnXkA/oUAzD/lg==", + "license": "Apache-2.0", + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/ws": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@discordjs/ws/-/ws-1.1.0.tgz", + "integrity": "sha512-O97DIeSvfNTn5wz5vaER6ciyUsr7nOqSEtsLoMhhIgeFkhnxLRqSr00/Fpq2/ppLgjDGLbQCDzIK7ilGoB/M7A==", + "license": "Apache-2.0", + "dependencies": { + "@discordjs/collection": "^2.1.0", + "@discordjs/rest": "^2.3.0", + "@discordjs/util": "^1.1.0", + "@sapphire/async-queue": "^1.5.2", + "@types/ws": "^8.5.10", + "@vladfrangu/async_event_emitter": "^2.2.4", + "discord-api-types": "0.37.83", + "tslib": "^2.6.2", + "ws": "^8.16.0" + }, + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@discordjs/ws/node_modules/@discordjs/collection": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@discordjs/collection/-/collection-2.1.0.tgz", + "integrity": "sha512-mLcTACtXUuVgutoznkh6hS3UFqYirDYAg5Dc1m8xn6OvPjetnUlf/xjtqnnc47OwWdaoCQnHmHh9KofhD6uRqw==", + "license": "Apache-2.0", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/@sapphire/async-queue": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/@sapphire/async-queue/-/async-queue-1.5.2.tgz", + "integrity": "sha512-7X7FFAA4DngXUl95+hYbUF19bp1LGiffjJtu7ygrZrbdCSsdDDBaSjB7Akw0ZbOu6k0xpXyljnJ6/RZUvLfRdg==", + "license": "MIT", + "engines": { + "node": ">=v14.0.0", + "npm": ">=7.0.0" + } + }, + "node_modules/@sapphire/shapeshift": { + "version": "3.9.7", + "resolved": "https://registry.npmjs.org/@sapphire/shapeshift/-/shapeshift-3.9.7.tgz", + "integrity": "sha512-4It2mxPSr4OGn4HSQWGmhFMsNFGfFVhWeRPCRwbH972Ek2pzfGRZtb0pJ4Ze6oIzcyh2jw7nUDa6qGlWofgd9g==", + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.3", + "lodash": "^4.17.21" + }, + "engines": { + "node": ">=v16" + } + }, + "node_modules/@sapphire/snowflake": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/@sapphire/snowflake/-/snowflake-3.5.3.tgz", + "integrity": "sha512-jjmJywLAFoWeBi1W7994zZyiNWPIiqRRNAmSERxyg93xRGzNYvGjlZ0gR6x0F4gPRi2+0O6S71kOZYyr3cxaIQ==", + "license": "MIT", + "engines": { + "node": ">=v14.0.0", + "npm": ">=7.0.0" + } + }, + "node_modules/@types/node": { + "version": "20.12.12", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.12.tgz", + "integrity": "sha512-eWLDGF/FOSPtAvEqeRAQ4C8LSA7M1I7i0ky1I8U7kD1J5ITyW3AsRhQrKVoWf5pFKZ2kILsEGJhsI9r93PYnOw==", + "license": "MIT", + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/@types/ws": { + "version": "8.5.10", + "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.10.tgz", + "integrity": "sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==", + "license": "MIT", + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@vladfrangu/async_event_emitter": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/@vladfrangu/async_event_emitter/-/async_event_emitter-2.2.4.tgz", + "integrity": "sha512-ButUPz9E9cXMLgvAW8aLAKKJJsPu1dY1/l/E8xzLFuysowXygs6GBcyunK9rnGC4zTsnIc2mQo71rGw9U+Ykug==", + "license": "MIT", + "engines": { + "node": ">=v14.0.0", + "npm": ">=7.0.0" + } + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "license": "MIT" + }, + "node_modules/axios": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.1.tgz", + "integrity": "sha512-+LV37nQcd1EpFalkXksWNBiA17NZ5m5/WspmHGmZmdx1qBOg/VNq/c4eRJiA9VQQHBOs+N0ZhhdU10h2TyNK7Q==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "license": "MIT", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/discord-api-types": { + "version": "0.37.83", + "resolved": "https://registry.npmjs.org/discord-api-types/-/discord-api-types-0.37.83.tgz", + "integrity": "sha512-urGGYeWtWNYMKnYlZnOnDHm8fVRffQs3U0SpE8RHeiuLKb/u92APS8HoQnPTFbnXmY1vVnXjXO4dOxcAn3J+DA==", + "license": "MIT" + }, + "node_modules/discord.js": { + "version": "14.15.2", + "resolved": "https://registry.npmjs.org/discord.js/-/discord.js-14.15.2.tgz", + "integrity": "sha512-wGD37YCaTUNprtpqMIRuNiswwsvSWXrHykBSm2SAosoTYut0VUDj9yo9t4iLtMKvuhI49zYkvKc2TNdzdvpJhg==", + "license": "Apache-2.0", + "dependencies": { + "@discordjs/builders": "^1.8.1", + "@discordjs/collection": "1.5.3", + "@discordjs/formatters": "^0.4.0", + "@discordjs/rest": "^2.3.0", + "@discordjs/util": "^1.1.0", + "@discordjs/ws": "^1.1.0", + "@sapphire/snowflake": "3.5.3", + "discord-api-types": "0.37.83", + "fast-deep-equal": "3.1.3", + "lodash.snakecase": "4.1.1", + "tslib": "2.6.2", + "undici": "6.13.0" + }, + "engines": { + "node": ">=16.11.0" + }, + "funding": { + "url": "https://github.com/discordjs/discord.js?sponsor" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "license": "MIT" + }, + "node_modules/follow-redirects": { + "version": "1.15.6", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", + "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "license": "MIT", + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "license": "MIT", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "license": "MIT" + }, + "node_modules/lodash.snakecase": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz", + "integrity": "sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==", + "license": "MIT" + }, + "node_modules/magic-bytes.js": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/magic-bytes.js/-/magic-bytes.js-1.10.0.tgz", + "integrity": "sha512-/k20Lg2q8LE5xiaaSkMXk4sfvI+9EGEykFS4b0CHHGWqDYU0bGUFSwchNOMA56D7TCs9GwVTkqe9als1/ns8UQ==", + "license": "MIT" + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "license": "MIT" + }, + "node_modules/ts-mixer": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/ts-mixer/-/ts-mixer-6.0.4.tgz", + "integrity": "sha512-ufKpbmrugz5Aou4wcr5Wc1UUFWOLhq+Fm6qa6P0w0K5Qw2yhaUoiWszhCVuNQyNwrlGiscHOmqYoAox1PtvgjA==", + "license": "MIT" + }, + "node_modules/tslib": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", + "license": "0BSD" + }, + "node_modules/undici": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/undici/-/undici-6.13.0.tgz", + "integrity": "sha512-Q2rtqmZWrbP8nePMq7mOJIN98M0fYvSgV89vwl/BQRT4mDOeY2GXZngfGpcBBhtky3woM7G24wZV3Q304Bv6cw==", + "license": "MIT", + "engines": { + "node": ">=18.0" + } + }, + "node_modules/undici-types": { + "version": "5.26.5", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", + "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", + "license": "MIT" + }, + "node_modules/ws": { + "version": "8.17.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.0.tgz", + "integrity": "sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow==", + "license": "MIT", + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": ">=5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + } + } +} diff --git a/Bot/node_modules/.register-scheme-CCeiTIjy/build/Release/register-protocol-handler.node b/Bot/node_modules/.register-scheme-CCeiTIjy/build/Release/register-protocol-handler.node new file mode 100644 index 0000000000000000000000000000000000000000..c98dcdc950d5b11a5c81fab5fdf91fb3e6968ee0 GIT binary patch literal 133632 zcmdqKdwf*Y)%ZP=WXKQ*XHW)%ii{F88ZVJ}2?lhAOyrDAGzchFQ7jsxT_cgdhNDl zH0}9+*pE8aXNPWH79wlygmjao@9BPIzBi8FHrvntN-QvK&+|Tm_n<#7 zDQ8>RY}>|40u>ME_4c>&#m`=7WmJ9ikZ%tv~SVPx8F%d!KG~;`JBA71n9t@*JhhK@b&+XkRJKC zNH4@=(cok<1Mz(HjN>#fmsi4DO=n-sImc~nW zly;d9RoHBqDq07EDoVlgP-FQzY6M=?zOU6D%3CMX$~@@=8s&e&ID^1ty4hnZ!G)6Z9 zeR`zzG`+Y*kHiV~jnf`1qqMnij4HanM!VDT27PX?%(Z=?Ew4O|F$}qC?@QUjc>w$@ z<^H&*(dJ%or4XYo5{GC*kLH=;MDaap{tuXk%M1Bj9%)1Iy zQHA`u(2c(_oI8Mge_1${LH_dng8aCJ@vPPT7|)D`dB+F^YLCL`#UOI);UwTb3JEMN zHTNH9vn4gnRk>AjRlTE)%+*F-!AL@cRj28to6R+(>vijeSbaD6uD@Y!o7s5@v~9Mk z=S%WT|9NN5zS^4M2bqnfpXjk!g&v4PkKSImAm#q!K1II`*C@0>(kdxbSRGk5DlZJT znI*YCOXu>CEAf&HtHH>gzwiadp&>4r=D}HdQ||lI8OM>)TXuWlywGR`0;nnXZ_|mR zNepzvnWm|lm4Q@zYT21X!ux|vVmRIFD(m&>tOz{R#q2g_jEa1e6*@KYkv(*B#^PTkH_W}Zjd}L>=fOcN{}WzjE%`SSS7ODD zk+|E_aUVaY@;M}KPCBmI%D0y!)1Qv}(#rRi#FeDubSqz%#GROq3tDk6NSrK%nei5W z7wBja-r&nB9|zG8VJz)!}fl+0Ve`;03D~ zPl~c2+zlIB#RP3O|M-o?WM2S2k!C+{+jcl%ADy>d2u980-BRo9xbU_^^rF3To8oOf zY2Map@wVoa+e7U-EI^MwUMR8_8MOL8s77nBhi6mnB`Sv|Odz7-x2sm>rdz4~U$yc- zfMkY{YowK>Z%R9_I@dN-<9X! zKj!yUtY8fLLWc77Jrt95%U`%aExs&TQJ+hXRV>gu>>@hJ5)f&D+L<^3!_=cpF5UP% z7+pM%IZ+af^6%VWtb)i_nGPN)qZ_XUqtlC0?){%Da=2DEX0jRw3royjer3_aZxqIb z53ty2D_&Qnf`$5FRH3a{tKyHc>iv_1#4mURjp?3X`7rGP1PhyP5puH-cwqm#y5?;W z-hLuT3mToW8Zh~3YP4b=ZR7<5c{ROAOt;#4|3F*!9<k6G$4@}OS5Bo=Sp&q%*14J14cbrRx>xPf+IulO|qF})# zBCxrGR4UVCU{sUIeQ);wee`?yQo>w0>LPziU-DZsv17;O^WikZ*!ld;V zR?Dmf1*+$@_ZI3ltLJ4Y_bt74n|5_vrF)W^!iP{=k@U`^$5>}H7tQNnX_Lf-f}Zz~ ziDY`Ll$Kjl;f6M|x9l+V49IJLC^YxetGbU1hDtfdn;)bR)gW7gpm8v0>^UHrq4rH)p1+GQNzGckYXZyL^V~1nu=-h3%NN$s* z7x1fUX%%%>i@@dLgSLp6R{5-2V4~q?yp7?<%=}ElgdC6FvTIb!y8ByJASAdjS zhBrec-m=nAF)(ZbL-w18!DuVpp-QFP_ep_Rn1Oj6jvP1tktZ0q!5L)ig;2HC+mPds zvV~UbWyCF7oo7y$QDu_PR5Uw#T5{W~441D3f)iCxgSkn7L?q{wxdT4WkC)VeTD zt#oefCyH8=%z8x*!VaKQ?-$yg{z9*iqzq<2q*rSwecH$&x)BpP6T&@RYO7l>beNIG zF1kRb_Ic`gwmkd)1Tx$gIhKvbtjyM<2Ratv3OYXay)+$Hk`2yLW%RCvrrr4^3nh73B}Let zsX<1RqsGd|q%jMF(VJ`e-^l-!{^-rCct4YJKVU)03mW$pRwo*1jM^t6beUhEfKWtH z)ni_$ra-58iK30!uKs!1_wSIzk7Qo{T7jEwQm>O)=n@L|H{RSQ^x*QB-Q25I^PZIZ z_es00%J|yXjEoJ^|4=wb#wF&S`Fj!XZvvyjG$iDesiF%Y^8u>xX|5qb<93LL&Xfcq z-?)N^i{2VtyPqA_&2j#3<9~NB29O$UakrB_&7K;NY4f$hg^$Y0LdwQQDAB# zE91$#^k$i&{4Ea{Z|jjwnqJ**mS#IcR=kU&(UMP)AaHd?ExqqoOPP73{!7p zbFKbiiHpQf(<41SdQ|UAj?f#rLb>KI$dk+}jaS7kwKGcbfblmeI(dQ=4L^%O)6HgY zoAhJRq(E#oquMcO=eitLDLdDWft_ois(q_DN!32LTY)iVHzTT{m-xz61vh4SW+N9* zx$DsxAz9vQF^C>>))&^azfKMH|8|I9ltE~L$H28sh8JojoF3-(%03YtW#8Ou$(9WB zdJ%e!*|1eM=Vu|H#SbT?qly5P=3G?=Gcjmbl%du!q%CbE;HnCQAB-VSF!p$%Oz41d ztv6sS)&s`-!W(?o$zJWmiNYO5tLNm;M7Yb7u=-Q7PDZ&w41yipXqE^%YW8inBsQTz z^I5f=dz}asdZvi*7nf}A3J?or=jYLlTMGh4FDoJvVX%C|(vwBXmtkd@o1{m7;F9U) zA8)g@=Uiw@d?uKCMbR8or79_*7SOR)0lkuGR(>(Yxv;DREyf20?;>gDFr)Ad-+ z83MVyQ`e^U>9J{ceTt&b^YxexeRgUOya1qNp1$@p-u%^?qv4r~N`J^_Ft+ftK;*-o zK=jf+m@(9mFBJJXgBdh>li7%_qC$u+MjxeZ zOT|(UG<=Fs1H~-<66_nd^wa=Qen1Vz|r%#=tAM7iO;q;k?yVvB{&Q>5+|~ zaHpVfi`2S3Aqt>03Qvc{>*d=(A#=Rq+bCQEq7Fmh&fGK#Eje%@6a7ObIw%~~kHSAo z9#EJC2BXVe)|9^iLE=?~H5xJwR%?1sCfi`_>BjW*G~Z2QEbLt(`wC-|ITM&kC(D63 zREnW=f*N3Wus=Gk7`j5`^*12uF8NrHSgoEXos*$;!Kac4uacEeX!To2tuo#fq#An_ zUMC%nS7grr&+z)ek$Am_osS~TZKUY2W#DxWc%3#FuUAVRqYu2Mg3`}V#=v(S^t|^Y8H7#h`LnaqgMi@ijLba)%_N&=VJpAg zE4qVvYoDq%7DRgj28vQwzzau_eJLXzo0`(6ARjMZazgXfw%l5HxK`glW7(5O$Ivma zY@rRVz4ZTVtd4ry&+?N*Ek)(4V?_jKZ zCT0vt?JS9x9F$a2rQ^pc9r;L_!^_N*EF^kGyqqIaW0@X%RFc#fB5%sxVu&qERI6wJ z09`A?N-6Yw*G>f ziBScWyeu`+0I=^EMtdz_s;rDcW4g4^o+=Z|xleLimADT)2`FpWtbzmPfy-6NWmlw! zBITYvP_276@i5W=)K<{ZRCSxbZthHIEkx zfgx^`Aa0b2xFKp`X4~(3?6w4rg+&JonZdIPT?2ED3CA9ZUA%`UbDyW$aSwBn z@I(pUX@$?0@O&$LhJ>%S!lz1jx)nY}!k1X#lO$Yfg^!o;X;yf&gio--$4FRd{$h?1 z63({b^CY|<;-d{iB%HLuSrUH73Lkoh@J=gyP{JKnc%Ot{w8EcD_|I1OQwcw9g)fuv ze^}wSC2SB*bB3B4ZCpJl0V(DA=l;!ZLzmpr;;Pw?qBd-A(_6Y+iTARFK_)6#Qz(_T zqZzwJeX_|Mda;=MLdQz@M#8eR?*YM>(Gaaup&{ngtjC+pAILND3Oxn}qg#aBJ4ux0 zMe-OeO7pyCnJJVlYBP^V{z^K`B*KukInt`L+B9SpLv;YPf?c6)6D~r>%N%;%NB-mOQiA-1`at#V0SzST7@A|g2G{t5v0QO43v*1NpS-edL42PZa4e{mqR$(tiN^WRN zbw(ZLTQqk+^iA3r*^G_t0zhv(enQ%GrHoEa&w6%1Hw`r@{LTF$2 z32#Q;x10IoHrkR;S&ev~l$9%4XVLo3@dTsZf@n44qdU`TVYVN=N*UI$Bdkqw-$Wah z=a$A3pV9+X*hrs!X(eih=SP8Y^woK=LM+LU#VG6^L>k?&CDuu;{;$M>HDi~^-K$Xe z4kU@nygzA+gZ8OXk(51r0YE2`CZf-)=3hwD8}>m}X1h!k?9Nujp%IxpDfh}_L0~H6 zh@`T^-hQxW52`VQnC!5pn>;i&$Ib|pBu8cPrrcG4u-cFuQu?N(%5r|4=*`x9MFA@U z$N)X7jZ(nqL-scIGD*S?^I8^6BnQ+|LLmJ_!1&*g_@Onk`{!tBSIXUnw+*v1<^C&y zlslw8JJ$`(vB|vhT#JeR8HrO|7^C%C(J!Rjj}ymS&Rr|CxP?tr{`dY4m2@!#B2bm- zQO691OjapGkvP-O@h%zY{zVcUb^QKK`C_6G{xc~Zjs{|++78EZLNb;ej%YfhwwL;C zahY9pQnDilyFYG4(3DNZ8~KlH6~Mt9PbQMBe|{(vNx_xJ(881qUu1n5h!j4vRsfig zu*F$6r@L8{?&b@c>ZVgPLq@0S=L)Jfe;@^v;23q>D*d9LMd^MXkoFmlDNlzX?tGd2_T$W4W1Kt;@ug{~UggA8Md2$mx2$VX9Wmjat||4xCsPL%BH zy*CJ*d1qcVP}@B!`8lbr6t!Jkl*IF(v6TDPbbXTs>RTZ7%^Rq%UFutSczqX9EY%T7 zW!?K1Rpa%_vm&v_Qk?hGC{83G;uFXX&Ac9En=CdQ-KmYtGA|TSH0H2@B|Vxgd(!mE zawA&$n4?e8t#ZJ4O9deaalkkN_9I7y{ibMxVvfzK;J0D_`lnK-g8ke70rvSvg}q#9 zn)=;Is3t!RBhunb>?L)8H+x9^3@Q{AMbyqjCyV(iS@yNrL;33p6d`Uk@9h(=q^3Kn zEhf7~-?|{)V}2wg6mviEEO1oB3#ty$(WuW;m8jv)#X@35JZh!ietB41r)0)NV$KCMnN|!(Ir&6Qtn#5jJSTT zgm1UPu_}-CJxjhTJrqO2=<(>Kgi9-3dTEQUb~@risE_BPbf79-^S3a=euj&hbY0i? zZ{u@?e1d_wZE7);HplXRDU&fZVFb0P?-<{SYC1{x9wE$Fd|YH6_qp%}XQBC_;3MK> zV}-ed(bXJR~=Yi4_G$jGXw)Q4a)1vY_T@~8zb1M4#u@A`OH3LRta zn5sT<%}Cz~Fw~N=sF?IkeWAo7!r}u@r9TdQn)V=5K3sWbVVMzmjT>rG<1|TD?xb z^VN6gY_MD^#+bJR0g=uWra?y?8KAQ!Uh*k#K7Y)s-7%M^U11yvcP*%}nFo2OwFc3x zrMc=Fo2_P&5v=wv6nOpeQvp3dF5DlJX!mlylZ39`TrUYkm;Y09VC9iw**w~7nOX(?-c_oh#w@3OvB;_7H zl;}vCQ!jsKQNo(3YBe~l>~U6E*AZp6F&alJn_e$jhXnW_-$+?}%q(G=nWa~?ae%$J z@VxBOp7I+lm8Ea`jZMC~-aA4!-|nm1JMHE>!hU0i(OcT(Ltk7utW$f+SNHj?cibF^ z<`h;A+elw?i~|gildb>oaJ3%E@7RFEFroL7lr|+k#BK`}O_?_&%N9C$%0hV^?|2pu ziAbMkX`zl%#gejg?dg`qqx^aY_`<`UQUIvXb05&2{KSLMC;o+@pn zcE2H#cTT2mZQc7r7w1(DYoY80igY+iX^0H6Kbl`cP+PZWlool!ia3FY7e$_ojvZyC zov`>Wa-6t$G2rdn^p^KL`mk-H(C~-^={cqCqPFnWhU3Ha&`YPY!|@scnF~?JPC~wY zZJtnBq|?*kc!^IafrNF0nr*i1ZT|7y{_<`d-UL!%&*YwPekA`Fqq74Ta<8Qa2!YUjZTv%xnkYy}Qu*ba3 z5@$M}p#mk}v{MM)B=bk?8)*VXdp}!QvXw-gsKO9pbh4WY8XuYS7{V&!7H5@lA@={W zs^TyARp!+AjHSBP@OQ>Qz?3K*Zh5H|X@VMzLwa_~@PCyPEbrA;{Ej?)IOQYqOFkm^ ze&w=h^*^$L!*K#6dAKyMB#^y6V7!*vhAQ{I`$Kj2+2$|)eovU~#FQ66fh}|r`1}JQ z^FQ{gm21R0AwJ#Mf<2sQBlwlea{3EoZw8RL5F!Z})7XM;FlK#))oF|0sImpJ|0b*l z@2P1;67ZzleVhwL4O zf2Y+&;e&ig7Z)%08*_7fk@r0ze`V>8N_f$EK4YVv-DUVU<>=*oi^dXwDfKNLMG@B| z|0Y*BkI-;J!$VGAs1B~Gm2p3keP@kC`i@oDOxQAI&c&FS=B52Qp#n=MRExYD zG(Kl99l`)&7nbVRBU@8?s-t#tnJv6uk6mFmm7r^MOX`V1gXQ>YXui|jA!3cu=4-#y zX%9r%y^GFk%$dj}xIAO3&T5~EG;PUFX|;@(DJg0hrl3Xp(g5aB$cZPT`IZROk@2?n z3L?p<_D4d)$~31og2-aB^MA$T`0*Il`q0>YS*{SwV5lBR0E2eTVP1M!VZO|gxuAFs zd;POfj4B!s{k*m>+ZlGyov`B-oA+mSi@MO1VY`)u5?Qfit&pVD&BmUk%paSYopSfW z1f@d@g}sP|qWXrktdMg5UDCi1nm^jpX}Y8{tP+gnCz;MDd2tVGZofQxhxL(bIv~o! z<=G#@5&@VIhto3hNMid1T#2ji3g?-30>*6R(Vt|=@K+B+i6P;ZMwH4F((5Lv88 zS3yp=%J6y45`;$jvX**rw^j}c> z^Tt4=&!s)^Iqj$kXm_;KX!GKMy1rVzm%0+SN%TPZeU72qL}~XQ+DLma8{KFNJ%6`1 zSlm(t&udBKhNc9|^Y3^Wmiyp5ifX6ZwbSvytZS)NU%pj*J{w4N@rv_*8~=N1c=U$< z7KrpLx1i*Nj@8CV0o*{?%e1&C5dM;MEi`1RHqvkJrE_g!&(VtQTJZqhB0zD`c+1hYE>{9^{D-mO`wM`!Gf z&NxsLo$*cMj8vO^e;J+eHPY9N{Sv|Zi|CB6B&dz^Lt4=ppGRjLB>y4OT=KsrTJ3DC z&da2$Z;985Pp_K;?GaIuwPjXefu9ND!j)M_DCx8YyJlskKt`V~-zbTyWLq0^-?0T5 zs=PHce$ehRszlCm-L+_lUamWrI59%=gbQ+-8Z4FvS zjr`xdgivuH6)Kg9H$v%`jr^5F>P9yw8vc_Vm#_e~7mn{KNZrDFHkmhCz|uTN_H}YL zOeTUu)nUqhPx_W#Q_-!f?PO%iM1ZHlqN!a;iIn?Ij9y0mSYnMn^HUM#BO6nA6w=#U zEO;3B=NkE6vDGt2(;n)$Tv_a5m(`hJw#Y{QJEYNI$&N03oB0`F2qX5kbyO@vRz?7Q zTO0-Qjr`}xOV2h-O?2e3QvrZ0{B<-#nVJvNh^BEF%l|Dv%s4WA)UgNvk-k)D0^@Sk z7Mk5@F1P9%(cxH2gw)3_Dp&chr+52`zZm%!NLkQ5+msz0mQjQ-Hr@#_p%YaR<3&z+GsmZYnQw4$4CiZ~8;D2Yz{fn=_a{g>$8R2&Z z?Zjks2I%wZt3-ihe2#?k#jmgbHh)1g7L2(sU6)G1RW$8E_PfG9`sdp;Ee5CexZc zjJ9nnjXcUu&5`sWQ7PxmA$^FH%fKB3Qi_pvY8GYvjoz$*`d72}RaH}Zc&65Lh3a$l zWllaDb!Qs1mAfrnf4XY*xq51jf}VrMJx`~R+UmSUCrQ#?u;N*I9IlmlUrg2RoR!tf z)_*9$<+JR)ZF>3k#Un0{4bKXccWEnptTHPjQ%150$<|i9kLU?kws~x}C8H%^E3hri z-{-h{BkWjfxCv_7aOlpg^-tb^=j~ZNk^#(X53Gj>f<{*$^6t1mB;g4ZcLj>KS7o>K zXLyi(u7pF&SV7!2t$NwumJg)Kb`0l(7-z*=>{}~=0-|_OeaUStawE*J%qgB@X z=W*-(RFAyBSstym-jA%Z-am_5?r1_ExA$x~wA{9#Z)sc2N-*$keC+{Wdjwy51Ydjp9enLc<7-bE zUwhK{+Vg*pujh}7ulx3V8($LVu`tq)FNr%6UlMm1zV6#I7+>-=fG_zPj4zgBg)-p| z1N0`O2+LanWv}W`l--2Bhxw8v^X2xeUNY1|G1>zU^Ry^igR)(NDO)lu`GH!G)lAdw zywXMB8V`@}ijjXP|7W;(d`ArbHyD$`6TR*==-U}K#^y2NvG&n?$>_wt?1tO+vUyBwxPEKReV9iBZ z&PZ(}M?71qirX@x+@0F#_T;F;#s^8wrJX)hfzn*Tkv)1{LXbfGLhbaxJV~gQ1g|CI zRTJrz$P$V4kgbFmjz9QEx-{4Dk>NiHM3Kw1qO=H^6FPo?9+do-AZyM@kpX*^4Cus7 zI1exMVWf&6I3Pb9ZBOno4g_OUo_kJ~q*qhoQD>NJ%>zb#$~-2^wlYxOuGJ^$19E}Z z@Bx7;oQdnV6EMPTVjthXO|pr6Gb~X4w$|`7Qj)h-887YcoFPI2K5f2cp<4FQUy67j z5=Qu{l>0QkB7Ikf&+^AAa@AoB_pcp@C!dunxnneoxGJ4;&mAat5}x+7H(T2KV7;na zk8H>Zlz*JKg*l0=Lh3*MIw%zpW+*ZW_G+N8p;h5*fk+D5h|a)+52>yu^Qseu91tyV`@}=n+SU%}P>_zDv{`w<@6SPgin;rEnd03c@Wnkt3X6evm(-aK zU;Bj;?5zDLL>SB8O)=IoW^K%|!GhE-kbFP_2C#-_3O_su&>0HQAUID799Bbt6SLqv zEN~8pf&6edmkxrngAGnv&Qu~MTV5JbwLoGJG~ z+L1&v`Xk_2+i!ZR1fU~iS0B#CvHW5IObw3X35d)Ta~DVzEb2D%a%n1-bp?Bv-)Kkv zN`pV4A3Vc?$va(#NMQqi1M@@nshPsO6l)^D6(l!`dsJSYAKP*HH{fqrXu~V9{l7 zGf$S%>6WLP{kAf!DO;MQgUjp}+I^S`1<5~fivGf(xw4Y3$duXZp|^0p=5pMQNfORD zBzd`cu9%pj9K6CEvQah{dUOP#Mir8C#+~Ns3uTNoR5C8}Z7XclJp*+-lZ9fmGb^e- z+NTw;Lr>dE2aQ&caW}SCYOAw++UjF{G4CspzA=?C-4mPoN~JcfGj^FLkZKL2+KBcU zE!wn=#Vuh+WkXkZld>O1ru?!^+I<$Av+(ieZ?F<}*hb5+wK8~eB4W83JL&1W5=t}? zCp!WO%lHnWbI1YJ&H({+oO#UvsHGWD$r%FY1Mz!OI?ktLVxtBw3L3RolW~mV+ITg{l;b4 zZ+g+puyHN?6SJcf-<<|AwfJyB`P|qoTOWsM$9gK36Di)Z#%)%VkO}j}QtG6~Q*@)YnE{e87c$^lfh|Q@5X6;3<^!tWV?LAi zqx95`+rcSxT@78~!WA^!Oa8!h0GMBljT8u$x|dLWp_L>)stn0XVEg!sgl3#YFTs)a|Z1scQe zH7{ZwR2lpIoTQq>zV)WUDgMTr3NMkl;t_*DkveVVi+q?B&XbffK!hEbM#_{e5LY*j zl|gTvGN6iFnFt&RxVce~y#NxNBXvb9Yl)LHXOH-GYXkhXiP)=t|3%+s(5f(8AG@5U3e+x7|@{gGs!oLzP)s*1#{zJ*1_Un}f&kfJOp)z5N z<=d8Mrmt9rZaAI7rhOf1rP!Ir=#&29q`vS_z3v+ufh9xr^505eX%6}o&UZQ_u^x4j+^V2?6~2ikc_e>;DMwz$8Y zH|WMkG_~a)S^q{;FFZ<9-#_>0P2EKNzi#U0N~6;kNo0j4^0bFe_eBm24UP9j`tn0# zBk$(;nmywkl<0To_>68p>lEBD zw^{c7oYE5$+6qO&EoPP;^TG#nd{xn@dccVLjLXUzx|XwMz8SitbVtmW@WAbr`MeB>GgurC zZ11a#POX-dtc+df$TqUF|F7FvMH{{SZDhNmTa66sAY#h`lrM5HB?h&&%JS}epH=mX2e6Cr8~mpmS-P*mn$ z0mGirpOdH>Hg#W)Hz&LoaB=c13p*qsD`1GCjS6ODNuA&bSdCEQQ~=bHf=I+>boDlW zBbmH*3bo+W@{vV9$PLInhxv+s$EECoh+}Vthnt&D6|{A8s>)@QidC%yGo7y)=dz$DgHXG0FRyMv;w#jZaI;1TX+b} zI4fEzqlfS>PF91QxYIt<6j?w^7t+vWX`gmXmGBj8_>=y!fH|twpTR<_Px?UtBII#Y zoL=P4!&h)vM}mtcY^l11WQ?qpXO>p~ccT8=LpOr4^DoD_>5qCPBP1Q)u=c#HoP1A zLqYQ8;nP&|ReX|+TE%8QH30Ax4oFXoCoUp2a@S;A_>Zmj{?kD4YA;g#sI!XgPI{$_=xfr(BYAeg}_ zyFIMo!Ih;)eFe>+odYByMA@Rg$%&_U0|~LomiQ@;bcqFnO3-dwa;MsbCpVKfU%tOj zKsuVdiF?){PEDLfa3#_?PnI)-OBG^?h( zJ$#EgbeXI&7chFs*&V(z7p3XHpsBK{!%9Ba2$UEtEvCa)-x12y)+KVI(@WOLK)?f% zF7s(fB3Td#l(^Oj^4Y4Gvi0M{&|Nf*#U>X@oDF_!@A2BS2Az;GvqT+aD=AIYAcmi3 zw6>Tz{@9%!sbZph4Ute@Y}#3pUXnb)SHCNi+l>5aOMYUsZZ{=)C;}{gK>;JBt(iX6 zxAq;8sMfRyoAfobgf)Sq8ttGjoD82BkNIBly~OU`CK(X6DrsE~(|W9k!uOWcly3NS*K&jjC zmHA#4N@3%5qQz@XUyW~kd(Hmt6XKDc1Ce-s)K``~iSxaYyQba}8d@5cz_jpi=7(?z zg&{q5*Br-OKK1$Ay=Y`dHPg5Wo6=lI;H!}mUo#^Q6{qsB?Jz-N|mErmUfv%>^Y5! z5~j~H_Rz7Bd+^3WL(WkUW4dl`Wo^;cRIo^y)0ju?;o~w{2W845ljLr)Pd*D};PetN z(yWYIll{!Vg!IXIr3j|-TcV>lKst#`K*anOck#MZrZ4wJW|}iSTq+tYmd&X zmQh~7Dp)OET&&`^;OF-c)TsnfT{$ijlg8T@wxdub=_DeZWTzf_R#(6NoUwVp2t<0IicgsHqP;W7KCYoa%i%Ys zPd2y6op2%|7pv!qJhPdWA3k7phzs;>ofz;&9g3V?_-ay+POKqn6y% zK5drWY(xr71~VD5(izYpHtf59Vr{uCbQb#~c4+K}n9t0a>1@c>;%-Re!B~JRC|Z=1FYB~9Mm3Q$O)^yKmKV9JFCyyP&7095 zX!XC49M-_~E6LK%%pNqGf%!5z0rX`3O|IpFSkwvjbCZ|(B12P2zm5Z5&|t%ef~-BL zP3@f?JMn^`(Pn=3CRR!#SGRLjO>WS>(8a5E8KraV7bf$A<@-3}s-=?IemmN3j{`2st z(T%ZxeiYl>CKT6t>DU*aLCW2^iBy>@;##T-C343p`{j|SffhVM3kUULP_i2#D%bd@ z-tt+tUcOP+rhOv||M8+lp&=LxH|zqY9HU5aGtU0-hw0V4ebmKObjK$8#vK%&n>m(-90vml~ zCBY<4RspB-DlOj_{-UldX0yeOdt9Nr>&hM`7`m;l?1%EcuC9#y@laJ=*(374xUP)N zbv$%VUD=Q2?Wrq!K8yFry0RB|8@s~Zb-=PEFIWd0Tk@QB4e}~l*Cel#*VW7G_;q#i zI(FRy@*2J_A}_}}ndi}&E_K8gh?sL} z#Y=jy)L5(gUKIK*BZ842BUc*3%qNt-R`%GcWIxT} zA9SRC0}UH?!-?p09=3|DKN5FCp>M;Tl(h0~D2Ym2^_`t*b4$uyEX|GO=lmD`fWtY^ zhJ+K#AHkP7mOUa($>z#{@Uh6zKd^FM#>@Of7IXYet*9F$>J7ENS2!j6h<3*c>XX&l z)y|8iU)yH(uz8Yu0!rg`2ZSs|7p(B$hes7)w|1ouf>s;5;Ys1k)Oqq9w2w(NWvzA8 z%^5D$=j)U8?9TMzw!(qKZDS&9W&B1gaYfdOzRsphX-^W+W0eK%l|>9pWlu0x^*6pf zgiY>b>mkhgR@uu{MBQpvfc~-BALx?WB&r?u@lLi z@g8Hhc^rCjXggG-+->KPW~_XPXUj)UE`1M=Ou4_moi-Sqav|>T2m(Pipu(&c(?4*M z9#=GdWo(Q@a^{gY=3zp#fj4Ix8U_uZE*lvK&Y4h{cWfDCP~NZFEr+3KCRuPIk9+z>U* zWKSq(@=(qjraGE(lY1rlzlj!ORBj-8k~A)m$|+Pw5=!G7w@r1V;!RrZf$KtF)*d(| zTvFc}E|6OD%C6w{1Co=Qva06 zLqn5523C9es(RX#tG(Q5hA$oHW~yT_CZyx3jzkR%BMqIy#R5HX3Q^MdoIvDMo3#AM z^^p;gb=>mVxvt+=Tcj%a8yDo%OnK+xDQvr8yn+3_LB7t>Ti(sC(*BGv-ohd0KzYlO z69d^@3M=LVsF>9fU~WE6NUCkn3YwNN)m6*fs;5qEqv7xyd(jlu&x8&z!7vk+j5hac zeB3ZPT41{0gS@^>W>X5Un|f7(8oOa=)w2x}3k9Rb7vcog*(g?eLae z9L6B=1v6CFqxX54xn8ArfO7fPMVIiZ8NiquH16~ItZl0?8_N*)W|7qp>7xM(yxi`ThHmbMmH8rv?BUTyrI!(pj(rX3AnNGgS=yDn z6;8pqmHU*2*tn2++{@$~qZ?Ia=3~GXai3K4A;QL?B;1$m`1oKApL7vxXUvNn(4tQ& z3x65SU#ws%Xi@hae3-Kbfe5HDoCk#q(wf*jximRrJ5x(XX-c0oWdaBdJe6I#f;#LaW18JnJD-egty$P>E>&^#SNf;%{fx`NsEOg za^KB9<5k=wd`+X1g|!E#Ab;8suUlYsLT)2Hz9Z^>S#YI?eye zk&&fmdLVj9AkyJ9N79F2_CJ%qmwx-zz?SfRL0 zgdj1%t7X!B`W;K|gtL|p7SdSXc4Lwi!*-|nD*+i>&W-~v2Un1qo6^+`$Y`SfRswQ< z(-RDt!~8GkkfG(6h4SaO(rTgx8i;}4rH-cQ*zx_fCLT4 z)tq1CaGyAyl$I;;<65V_b8Dcq8wr~mG3jvMH`;?DxsZ*UeaRCv=tokIB-K%41c7Y) zF+-mPqv*Tb}J=IxN+DYEP&Mxv+m2ZW2qhWqloxwyv zH<=8{r}RiFC9Wx3&ArDcSbwr$A>#(c28vyc09&$5i1WrrGTbz;l?_SI_<^u z>FX~PZjvks>4NfI-xV6oAz582WM)pdd>}RE{(X;v`fH%7$+bx!TVr9~#_}=PNWx!yD*egvX~EL8+a(vcgoVY`j1t6UzdgZ5})z0Twl73YZ%7` zV$-tFLmIi-ngTJdSw@&BpPS4rP$jr}&uCx!O$vegRjgxQoyG61#428^!5V`8Hd73B zRr7~K;Vx)d*Sg5OZXU{X-;1JO^ELMp=7@f+Z+|<=rj*ujW0u%U%HPyhtYPSZdeP!x z+L|_Baa)2F5=-rFE%KlWyrHf534yiW0|e2F^T<}*nz%<2edXQSiY1bIFr8`vi6^eJ zl6Pw>u9oD5v`h+H$t{T~k}QSAORTw9rFJjQ2lQFeiNshbRKw;;8nS}hzL2u=C}7pz zqRiH7Kg^_mNgu8BMLjWni7L}G5Vv`44b-V(Hx9(E&g5J@5cgCj?x}&ehu2m!k5uW0 z`eU^fA<$^$UbM`rTU#LqLSp)*S8xRPVEHDi#10GHcLKZW!K3dKuz&>Y|XeZH53 zAbqb0Mf#16ej{#?9-?1A>22~AZ%VLv7oz&R7FleC-qBV>2sK;8*Ddrz#;u84B~pl5 z;bb0PF&+9))VZm+GZB#V8jGy772f`I=)(tnKzL^k#BI*R6%52RXW~R+w_q>&btbM? z=s?xCXl1iSTR?oHKbAScm}PRe4vN2iQ2g%(#a}98Y|$BzRt`!zv%kcmd#yUP6$L5| zI_qAvAQP7(5G*?DUUX$9_EV^(*`l-VMUykJ-NZs?u^Fe<6t^lWI~lwdZ%n!~bhg;3 z5WP8>9qCHplPt8h6CZ8}EjINDXbpmc);2ifRt^pC_^^?SOp+mPhmf07S6h5N(|5jkkR-gP`SHqUd{t z?^;0Qgf(iIPADtn^_73N#EZkJIZ;)03VD$5$`H)^>lp0h%`X!%HK;?=qj|=LBr%zrecGA?q)elQ$v7IzOe4$I`gS zzU2T|1AoAa&~z@*syMJIyXo;QfrhrwR-`xmggDzEC9@^Y8K>k0S?vo*($;X}FxMH> zlxKxU0E4T+TC;#-5C4NCj;9v4V36kgNGZx}4yXIsG?wRuic|4G_O?jhS&Kf8`96vC zja)jUSv*JD>RS9l^RnJY4vg?=m&V(ChQB38$%~@aS7JXZ-Zii;*`EwWvi$0Plzur- zSYfox{FNlc#=cLS$PPJrY>o#>c`0D!QkDMQU|Qz6a}b>8`r#_{FbesBZ+mG0DImDfZqFx31{Xjc@d*B?=u_Wz6e zdrnmKPecB92{Ft0nW5(OX*i?*Z8(ovaIAhrr5`c}PZ}gC9|Q99YDGluU` zvbm2?8M@Et3^L}wqjZG=59@G#-Ez{5%I@e&;TaOrqv{k)>@qwR_=?TO-q-k&^n*`= ztt^ecsG4Xoj=VPlXqk z;zpWWXypHpT;lj(HjxD$vuB+gT2N;JO%21ek^gkSn=PjOQ~{ z!SFFgeudRouc~Zo5>Mx?<|g!ZWFI9BHuj5F`~~bv*zSc9k8kG^L4}QhBUqi8gLqzX#&>&Z!uI#tmoX+CFutme-qyQqQj14wTH%~PeB-^TscwNmLMKxJ^B zIA0omG~6GXY5WMQ@q=;yV?=BtfA6xxaQ`8oXgr6n)3|?)2o??+-$70qzg|_A#{Cr> zVpd z)tt%hr|pb>#LSgkpwBB<)2UF|>YKr@?LkKa5IBhS zcR_{X^eCSAJ(CJ2dM1=nGYfco(K|WKYXy;M{UQwILdAb^s+UDF|Mee(GqL9LEtDM!(YM5e@vE6?{AJUH;$f)JL< zF~79_%;H0XZP?YNpK$f4`dvVNzM0?1C<9l@9(@i0Z`m36$cmYwh_9OH=?M>SBrEX? zD>0wnAYBJ}b<2j!hB|x-ve!B2F}b(Y`mHasu2Kf1lVuzzdS{Z+dq%1VpP`I4oR6%D zX0Ihe{p71|N#Z4GN!(~j{FM}KHHS$#foqCV8dO}VOm==F;NfAno2WjKFYX z128#Tw~k$#oS|Vjixl;kx1A}iz|O~1)b#mi3d?&JUF!jH2X$D3{JMa78Q$6KZ8~gcP+ek*kWBQfbJ06m`p~yV7>UyF-Gc9gq|jf9;{oK=AF0a~_BvLYg7E9)9ttUeqY1T{V;PwECYC6k!)* zbokQ*nn+F#j%)T%jGzCJ)2I7)SDo-?aC~=Qd$Ov0XO%Yfjnb~^v79;FL>d|a2pD6! z_~(J*ZTj|uf%2VNLnVNaz^gfP7$}Cl^z`W2t%2AmZ;*Z1*bRF>>ssFu4s!v=E`H*K z3n#)u1CbVfVsm5oeSlXd^J;vPhK3|E3lmwG-%P|ElSZM~)E;U-tWz|SwrKUz)pVy? zr1|}wdQQr{t0@J*|BFtALv%*E;sImKvWHw%2I8;v&w|aF_Jv zL)DuR(i^S*LPj#vqfZj2%eXQqR{KLP)%I^;6EhX#t90AfqSL<36^Je_kmHbY|ilwZYmn{RWR z+ZVh46t)~+G3gTTu-x&(*6T!ZDE7z}^E`b#Kc&^GHPiu*%1mBCV+(UYmz(YD3)vEp zb*K9E6l{IM^K_!)M9WW-mdL3|WhXT8`M|2dMB|#D(nN@_bvLWRo6H?g0Yto2t|hkV zp~7v%*Y35)-*wcsR5y};VRphxQuA3-prPw7r?TbJ)TVlsS&!XjKhN%aDTTPffgjVi zwuGEM+<@Sx^4Gh(QD2#$otB1?c1c?y3_$@YQ{ANaUOB_Uv={ z{hnCZE)IlEZOM@`Vdrony$@JOxJ|akO8D7v+5?XeQHdY8E?zVIY5YvU{pSGG*VGB_ z1oTd`#+NNhvq?*`YqHyYjYCpf12`YGe8jDjk@(klZK=VpfLs zb=;rOTMn}2Y6a*e+-w}1T7te@zqPdhsS0lq?(ztuH$QOGy=Uvq!*)Hra7x~;r=?W( zb_$}rIIJMH_PBmq>*Iq8=G|MYH{YTzL8+;+s^iGp(Ms*3RBa2@J1ZL(+L;XUd$V+f^r=?SVJtK{{^f;|N6tUi#%g|QPd1Zkk*hDPB`8)Vu^1W${ju3uTqeM;X$8x- z1+=NHSfe`4V_1_hVftCM?k)7<7Wq2Ua2r06s~Nr86D@K>3``X# zO_uf7xhzJ{-s+E4+RY2SYQb`}=h~8-AFnT51sHtw{Y)LT>p+UJCgN5(iSOlrGH2GL z4)Q)mUVhr*gQQ*27Ksnl`H8A+ zOV2h}A`&Ru2Ue3m@GCNi%twH?lxTQVBXk-+N&lLcEcq?}ol4cdq#93~o>#aHonE>l za`9Q(Pg?ctT@7#Ek2?!q6Z|%N?c^+5c%M*3>@vG~(sQhr7lY4T;oSDzv*gN7GM~^i zRSpHFTCJ6KVB$I(^R(3#nz#sL>{f7)&BgnB?RxfZz4$96CVnIh);#JQkp7z4&Dnoh zntv_GicRNOL@ES#sML*1owa2pp{xDIrJUe2?RVw+_II~e*w6BD2It-rn#VOHXZZG; zEe9QPFl1czHrvcBh}e(mJ<^v)1|eUSA*(+__HC{E$l$kCl_T)HuB2rnSnVlX@xqW4ec{#kQJ-b9V z-oim3yBj~^W&cBN54mNCiw5y#XCv3fUYf&^i;MSntE$5}oZr4q)(vUKEq_o*u&&Wyx}?!86wN%aToe$(=E-@11xRB2 zf{W-?4&xQ~qz{A06qV5oi0yl*#V8I6Q(z7V7vUykIeOtWKlRBx4i$3IZd`E*xJ7z; z)5Z*=fGH?W;Y-m0ScMR5Aa-JzpR58-2v;P3*JQ;eoUn<+kBJ9O{#0kA@9TRnEw^&s zH^pDxd*ARTaRK9u!v4kzT-+_Lq#*Z0lwUGeNZtxB@z~8jqBBXNk+SmAwgJ|&wZD*J zL9sOd!IFLi|9O=C=3oW^jfg~R;qhoZsNeTZH^u~@QTfws`uI00wO4uru)d-yrg!1#EeVSTt1SEQ2Am;mP=GB*|=4~^dtBzdQan9wh71RLT$ z1b*Ks+nQRFMN@1@FSG_#!qdS?m)!fSuBquA^!suz$lF2W4OuR@DI>I< zu&fLmM+@c0d@piA?h;4k#5a@KzUP>!>6L0<9QWY&$rdn1zibJKvgjft;!54FHFT1c z`ArW-1{+)RaEThvy)-y$ou#9OkUuA_*l|}LKM*WOjXF7M1)j&_|JJRafNcHl*P_Ws zKDtDXS<21Qj`nO@^5y{gs(S9}wKxt@f%1dwOH*4heD7qB7@_{i=XUO~X35~@vK;IQ ztreUdhrzIRl^@i88u!O?5EXU>vvG{tbOl+=f4*a}c+sRX?>Ix15U&Fyb6;(bN2IjK zd-ll2EFV91wQv0Mg)+pE1ZOMD$rVZDX!ZY8G4{}Pa+v10NaA>{eq1JPx1=4ghrBXb zp5+6!CsP5(xL1i;MGP7|FS~5y=AHgVbo(+1m7#PJandjB! zKa?&nrv68B0F5(5?WcHJ|$^63s7y#==f1jvGx+HnMnSTAtKC#6WCEWj2 z;ZM=OiNrP!d5yyhxBWldy?cCA)!Fzv$;^aE5_V96K?Ft;G#bHZyaWey24-N7OcX6B zC@L1E)Y{5RW&kT_!X(OMJC$0ky=ZG&da7^ht+fbvAt6A*MMyveL?wWi9kv%hn_CH-?c=Tyo0F^*Q`oFF;f z(y*wQVI?l9n$EU9amfTO>;yReyul7ITQpck%3Vx;c$uIo^DW_^!|{tz6RnQ5Gl6m& zLWZjqez&E>)@>choRig@1+O5ceOTc_U~q;|*UvMezq7>*tiPRR@(>}Bd8ugTw%o~l z4B>?7!6-+>2U{*$C#KEj=v31Ew7W{y!*xQ~5*cppuB4IS%&>N3rF$f_e zw*`)}LHtMJfwq$Rtc8KL3ZO48C<^!h{!bE9N}B%dcrEh&Z|$!*zZ{hP*|d$E8RAnF zH;Or4<6)SsGjSjp(F}*QlhMaP9udmyp4H)<71bRNQ`efn&WajiBYaU`p4QsbY~#zdhQL7EF?Mmc))^MtevF zKI_8R5oh##xzDzSs3cCO-&vwC&v5?)^Bj>tvH^ExHTw!BIk`rx!eb|#THR2dWHtN_ zM6~fxSxlKP(UI~U$Ru}Es;QZ4?uI=v-=M^QWY}3gBunS%K}v6;bg*D=Vq~5)#K`qR z9wI%>v6P|5ioG_<)*N%V9FAGrRZEoA8+o~1w|rZ$i#f-1WR^+D=5_Y8d^Um>MJMXRZ!CB@VX zomYjkG#}+bC#DO%fII2G`OxOr?p)SWWZI85EF4RT*A&7_^)TM)cwM?rFqrA_LhE;a zM7W5>3E0Q!@Ms#0HxT>wG>5~Fg{NVn9_`CHi>$Or_B(chtP_yZ8-><un z;#Sr6Yx2#uk5${pC2}t{-QU)nkQUf@a(lG8yVUd-L=8K}sWpFImu^Xe124 zjQ1IUE&MSGJL*(f#QE`d%pTP>291o;^Tc^Z0uRe3j=% zfA+WR0GfoKrkzx{jQw$X5?~^G=Ajpa1r#A=3pLZq1-M4W5b><$HK^8aOM)O5& z4y8lYn4kzN7ZrND#Ov8<~Aoq7QMO59#rV+hl(cpE!x~>8G(iRJuuz zSGHCfSz+U|P;&L?iV-CU1WH@E*PRo`S29;XjA?2;(duFfDT0$QSZKw8WZPA7*M%YB zq}MP6K}!8H`V#gR=vwu7Aw+)A2jXMCyJkvDr2jrs>pg0PXkXA<2t9w!shhG*g^&49gy31Th6~adMFgN11BvwG+#3(E}QA%P< z2UWIy94@^qy%A5|FWAJ1MRNv{cUa&vR^pk{%nhr>AJb3kfGPJX`28~_vx7UTX8F# z2mve0m?bdA>n5?ztH`PzHV>5sGibm5N=7#A@Q{H6{|47*o`1oJp>ui?6pv^fe`=b= z(zDS#YrK5VAgzhMAE?jtS0BDS%F$6{Fnnu`6jU1GKPXz{jppZ6*l|6j`>V|h%9G?A zIwv=jD(r=fSx#SlvtEjPc>Yr&9gWX_`XDw&^IuTQKQ~J&`+v%%AzZW<8qmUgAM&&S zAH9x$g=k{~!{_GWmsi22;AFLG5Tn7%&2yk;z`FmpWUwcy)%ROoNf4XF#HXYK1C`>t z@&yP?Yh8n_J_6}=EyxkLYejdR`)dKlHf7IpdiTD6fqKC>+%XmcRSC(=t}MN{Sa1T! zP|i&0BAZz;z7#BlKKVFGxcMzA2u9@#=2fIKN=8CZSH=IVk&I6i zFBIIaStTgmomz2j{0&UtE<2@8`h+S0mf<8;t)H-8&V@IY=< zDkfms+b{te`2!cG3m3+0oZVA6fJM|{8N%76`HG5@S8^#<7IKkwDW)p&OgDz=Ic43*LE5p&`ei zPvQ=u`{%dBzrEurU?KvLsbmz}4aSRle1iW-oaE0WNf?h9XNJQJFO~sB*yLYoPi$Xq zw7?D>Jyz1wGH+|Rd2PO`@Qez`fIaKeFVkpme+ReS^_|)nNn{P$GSfT=VdCXfFi3hO z7!Q4{0u(>R>3cZQa)=WD$~99!Vyq(VQ(9q45|a|VLX$1?{a=;L`F z&+}BCrxKrvq?sfsO+VY?=n~Yv8P++llS?z`f;sw8aOO8}cFL1p{=Z~a(HVzSdvYt? z{iM_Ee+a23?Yu?W8UFvKX;>;Ru?9%99MY`6{eosWyPD;pS$O{gF#h*Ou7s0VW(+5> z{^`_&JDZScxW3t^)7`p5J^;q7J*m$YD8&N)aNR*KCc&B+Cy0){Q;*rfFVtSqXKa@( zB3NjC@CU?fL);QeFm~)j^wehe!Mg}Z0GN^mQ&CJ<1+intqkWp)J3Ev8B;zG`dhFQO zQCL85wAtO5dTUI|?L;<;?+Q)K-0D0>kF~lxz3~uX1}xeCnv5IN4QVDTTkH{;HG1N{ zTs=O<3JJXYF^m|)o?-T2o`b-o)?;4|BB2b#Zan7Tao_mF4p{b$uj*#fiIYF8h zW@~i$W(6eF#Kc)MPmJh*AZH^QKYXnr^o+S&O z8W_mcn?JS5m5iKCu0-&x$d%25D|#j8Clta3+8+5nUp>L|)#jwde4K)jhP=yy&Q_vK zP9s$$%OY*U^Lp*%=}I+Kxq)ypKng4%6@Hofz$gGcv^%olPrt`sQ;?Ihv%^R>B%l zP=%1fc-|LRb5i`}B-!@7tjFp2ZYoIs5yL&4it5zC5(I0BEfevq;)i}M{jqLWA??kJ z5oNO`{oW>#BC_-jj9eiby}@>uozmsL^z)C`&`&H+$RV9Q#Hua+&G85APtoQ>QWXuc zOCBada>`*0lvIXxO9(hcRm>-`*jfZHRZ>0j*&hJ0Xjo6=RbNL9@w_+*)OV58m&m(` zBXRV&d!8i5^X}kcKDt?OIq!$uhmD56XW+)kqH!sI*SK#b(LU(B1a-Mq@9Sc z3x-P(G5py#2*Uy^A(-B6zv+W}`EVS0WRs&z!48<8$~JC?Sbh=w8b}I0DYESj)@Mu)1eiHAz#Ez@fa*UgnU$a}qWIJd*^)u5f(pFd^G|{C7fz z;h?R=X zMrQoJbh%pHqvR5Tdv?W?;?S4_@`oFfscwI#hVd+AfUGV#-lM4yuC@MVQA=W)IC zt>~AcXhF1y-^G|SmYv}H>g;UYxmquMBl?wbwX3FMF=!kahVn4tiFM>fPQ{eVE#W-| z1HWhg25Moh>wZFRSc2V#-1Ok)r`)7gC?YXi@t z#lgh*41dj0Svjjt_t*D8hv?4^TvQlvzLm-|yItsR#Tn6+7&s!HIUX+kD*7BSq=7Y` ztG=Ea``i`jANxEnlIJ}hrJDoR{MGK}fPcyj-5ju3Zs_KKUvLvHeLpp_dgA(AHJ;-V zBTBWG1E(LJ9w*%Qb(sRr&pY}FCNj)f?5kKAnO!PC={ZqJwlyk3l}_H8q-7>4-w7Z5 zwYYnoz&zX>DmVLGJGW$i(K+-`gS>7NXgs{7|XiZA@;a02Fx9}t~lgG=H z6&=3K_fv&BZb%vEbj-GC4|6P8Fuh*J*4^WFF$2HNe#qpZ%htZ;$R%Lx98aR=O)q$g z4{ol1`Cq_&KaqrIxnoDpi(XK^*($9$@~gK&FHg;pXWr+Cg#I;0{vp>7u-0QvMc%d9 zi>NcUo7g8qrbByd`j>q}qK44Y$snh_940*bHox}EmF3A)wP$v(c4?~GhFRrQYn`2{ zlB=q+FjZyWRF%E#DkE9i@&i410)J9YJOymyIvp1Ln8~rN=bvWc6H%{ZG%WPX4>w`rrx3!Ecu=56U?! zyJ##j$#KR*Cp>3z$gffGzd>1EHbJXahBzUwyba}PeT&XfHr}lm2MZ0STflE+hlD__ z^sdrs#lXT)XTlwCcQwW0LyKn;2{Jc=2li&#_U`>X)=Y1n7PqTJxz(-NJti3V3!9Ru^YZ* zJ0764M0CT=oEWECW+9erNW#|gU@Sufzz_pr-DJSSk-}-_@dUGR7uXu^5ljtge z(9$6U{!{ZeI2fLW%Qp`|_ zp#U0#3!Pocf^MY@q?B}fRCA(Ij@xd|ZFV^eq?`{$j(2i7mv<{?O{|L!0~wE)awYQ0 zD1enIQE&rAs8x_oo<^eiOSOyWIt%YJ+97A*JwQ43%%riMvL@(6+E36v3vcH$6f9@q zZRAFL9TNq)QU$Vdhk3a)6>H2*Y6#R>cn_zF*E)-bEL8|Vy4TS;=jp+C`@AdT0NuDp zRnkFqKajgb!3-|T5EVPjjba7}aIX_9v!_T203^e{g$KAJ6aaRnUArp9n z+puF@cf%KZFC+m_CrGyu05Mv`K%GxP$gD;0m#=%@kABFX$c2#J2&N`YhxORKhaJK( zsr=azI&qv-9fQ}yIZn=~dKdRXPP#~~Bc15f1#h*KaU9e-iQhU}EwQSg%ydECovHY( zY1<6-?MZS&goeL(Uv1C^jJvWc#_at9pe^f>U#;bBYJbJDpTcMCc!fMElk4yF=X=_`@7gh#R?qX?ZJ85ujGMY0oq3#M$&d}4HKwaJ4BC#hAJ;h{Msr4|LGr*_3K1jleM(Dz2!a8O6B$p8128OmV zdVsZo?@u+KU6J1Vo9liK*Ycc>0xx*cLDd0vFNu-ofSc@I5+nP{4MRP0fZX)p=Ia{) zP;7B=HPt(U1a{1^!y0}0t{R@pBne@kdogk^Lq!xT-=}Zchyz51-9b1OtyY8s#BDi+ zZXU~-GZNnS-Kxt%Mi7kcn$BgR*d5tq$c}!`d}}4d%qLO5=JNBHt9fqrCH!|Lt3pI#(etzIgDn6MX+klZX?YEfNUnWj#mcraUvc+t$2 zBEs}S&$s?0HD)KScA7n@&#rmtUxA~t6DzoF1Rz|emlr%e8P8md!C;}VPk2nsXTZh0 zpOeg}7YrvK-hwLY{O(z!5~Mi9o*%_|a>yh1b*@b(%`Nr_oTqM%Mp(7Tj@XaTSg1?n zMnmr-$9UusPyK46vDk_J-hHsKA=*=0zAI;zE14;$wT;fNCPFRiGoNJ}{yuFc*$3H= z=7$Wl_(C_BT^g|TcfSTo;4ig`6E+tEK}@5bV&6)1~=mb!&b>_vZIf&CgC^Nr!LnE4pz56b{WW zv9yt+dem|y1?jRzjTZxrNwU}R*m%T?GLfLd_OPspJfcib*z1`2J5a@X2E%~iv{zmsWWdVEJ+~vb?@^GZ*zSy`v`A{3Hw=ud8XT>qB?tQUoeU95qW|^$6 zoyasqT$&e_x>~gSr`1pMi6`6C$@YCKW z$T``<3*e9%s5m7_r9t4P&3u6Ki{4r;X zw5J+&n*^7hLIi!g;l%6X{FrEObFhM~ahPo8KqqZ947)F#IUL<`sB=jSLkcxbT$RYJ zzI<2R$I{&%E0vAnWwyYfrbA?E=2AOKkG5b-9G2`~V^xgck zWKaA<+|OUL0eLSf4ENp&0p{3!!fq&QlT)QndFIvX(_ZEnxyJ4XwqW8lz!r;9$>BE7 zS8uQfiZy$blITU@1HWa1+>uF6=oOzLtaOjZe^i9Q`D$~6Vy*^;!I5le0u7V*gO}th zv*WZR+(nX^Q6c~7hRVq7$TO7!o{8}^i*srk*zsK`e;@p^~xU;dFw>a^m7_N)6eOVvY)$S=wp|qFcjsm!cfV=G#3@ zDlLVh7%eLtH7@}QYJzt0gr@ry(h^H$BVg+T4EH0f#&s>SQVf!<^!fIQ-cLX%7O}{E zLeMplvy{l78{6!cTX-pZYeGJ-5Q-oJ0&;7UIToWT7SXQy#GaHnG)6|kkLQu@eTRUi z*t%S*%h`;Z%%NhtUDKFY7=oIo++9|)cQz}SVYNsUZ z6dx(i*(vwhDLN^O?UWzdDKkjmA`2@SSm$b{##5+Mssc8|!i{)dLuV*+7f-_)!Rf@f3T{RI zn~1vEiYCU*G-s$6Mk_g4N^i8E%D|1p#AD_-c{B_kkLC)Q0fwQ={Xgt`5r>(7Q8UAs z$~}emvkUl@{UmwQdPS=8pcyRniK5epO$;wzJEdP zN7(mb>|mCu`%YOP@V$ljQQf3|Q}x7MOtARPQ}uXs21ZviSxsNRkjYWL8ioa-;NGAT zzl%j&qS9gh9T*v}3HsoF58oHeHsms=$t(g^Ct}_);K@GOSr@fLzK7Sk81>J&P*3_^gL&p{ z3{@#DkuEW@?{0Q(*uX~qH1mPw0vQn+MtU_n-g}RHY<@-NC;7%=79=8v_2zlAM2fyi z$&G2P;DQ|}403TPt>k-7(MnX)L}E@ND)Wob;)z*|hAoMuGz{{`?W-9sm9V~SSSEZM z$F#7_2OTM!G~u}_J$m^Y=I|-fFyLzdUjz6i?&vhzRB^2g_j8r96IHyHPoIYPLQFG4 z)ga*L4CRYBhcykkh^^h2Jj6lkM8WZGdJVY7^cgPjQ>n5}@d`K&yXKsM-I+(lg{?WN zn5nUC0v_k|I6Bl-Wt}z}Fsq#B(_MY&(T&U57NCOU?eJI_ycxR z<7-e)q8%BI7j4Guu{DjXz8LX1wlNls!oxS3J@w=p)BQOOgp^q-0VbvwwJ_|NOC9fW zpVKluo})XDN{TG}THUQ65_Z3#_!WBFF;VLE4;jZf@~_nDAkDlJLu@;^i&92FKiDDM zrBvs(o2NQGFJ!#;f7VH3E1HQ1hN~e+Mt&{bi^*sZw4cD%&cpn*o=vT5-E3ph@xyWb zwt%y zeExJ{prhxKaR2w_-9nD3aBO2UB4aFi)KH&YeWWaM5P{gG^<$I88P?ghi*3*9E6XBf zu@ghB(^C$%k}!yb=owbdMGXk7PL=Q;IGU}mca9hy`SL`=LZ`p_$_t}e{^S^!#kmwJ z%E0LAc@-ELe1)ZXh>!wea`_Uo+FrkXGGe-HV#dpIV#ldxHMjpMv;6Pbit+0?nxWIb`<1wyMac)_`a+BQ-AF1jOf|MWM!Ze zK%?x655oYKDdStdf#ERSeJP@;xx5d9vj1%=%7&D7uX%|DiAIHpj1b z`LxGY$A@*?DOIlkU7;PEm-SW9yETFv<%Us4;Fm76C5<0>g3hg>972_R?9mVHM^DG{ z=sZlm=#ErdWG5Sl4^vG-lkPHqLS3RliO+Un($9=;u3HfV2THeb_LZ^2U%Dd@f1+6IkA!&3q2`xSjq#STe#>4zf7*!` zyye3{PD`qQSTb{VL1OH2V?D7xA8>6kbIjD6@=t?_nVieBc(z*TXpt{w;g_vE$BJg^)a4fP%;EMh0@WS?;jp73Ek1 z?py(5Wtb2!-sah->x#e%dW6KA8e`?>o5Ie9N^kR=^Qcn5#_(y+H;SC7ahE5Qv!3O2 zcCQfQQ@S$jY$E4uT+JciC@hdOy%jLt!;|uAk#5Z3YiOoR8{|OrlDNqw1%;ihqZ6)j zu!1Hu?)69`Q3T?}?f0T19=(}i=J@k?;AgIYcjqjnfviA^FQ5r|S5}P*7;jMlYD&9; zFkT7NL75kE)VcrJK@;m+>~c(=~lO3QzA%* zmOMod;PfI3DK^qV2b3X#_;aXr&^PgWN-8XLBJsE4d=?|<#Xj3M@VD$wZQHtjJw+08zeg4+wl2%ZI} zVugonMsp=Pp=_4s#5H-E-l%k${}!`FkUB=)oVxNu7=|g2IWO^vx`}!6Uo& zW^TItLZstmdeJraOb34sXy>=YZ(f|JVIZnw?I+}zSG<2b zMUC;BpJrSMXH9qkvf6dny!;5MQ&Y<4%hUPjQk}Q?Q>jK=x|LNmz-43lb zm+}}OD0AK7QNwH1TdnROd4ta80B#{40{;rg$P>k)P=f*_MiC2r&mcd?s*1V6PJiha z#zq}7P`XoljZy-*%O83(;!2`}DQ_q}Jc_^woY<^ASR;j&A7q00wa3>4oCku=eHdj` z&H0f(F*g}ZT%TmFM0AOuUfPh*lgzsw0V7_pj*fo7q_ekg{QtPOf{PucLNj7tU#iv0-tXVxh==$8iX%NGwL6Yz zuQjDd9VnL`_MY%-kF4>>)+ZTj8EEZ+IvWLEzZ7`OF!)Qq)DsE8NaIBL=El$6#!kI) zPbStN=9PCK@c3vDlh{|kaZ7u=c7S9HBz}+)G**Qg+cN|4KMN9bkzrIU{3LE(5gvv@ zWmLo7Chb9S3&rABzBaGI5wfF{1b<>o($Cx4|AFuXj8;N#D|{PcgdelY*LPpH;{cYj-gZ+>1|wh2NX}1~6ui0!Xi4 z@}B{5>FwVJh>im+9I0MJmi|{g7{qdQ$~W47Z>s&T+Xgu6rXd|a3-^s?$6$uayaGW& zz)%2YefKSW14fi(cj0!LeP|adoJ7Ic!O3K!>4XH0H(L1120^QB0oeYfXHx{z4kk() zE0M^;$rj@3y%(3)PFgOvD#v$!;Vl&QU3 zyR3{)I6uk1E@qyt+1eT{xit?I)C{Fcg!tM;cfY1F5_rZFFmGgKS_bf?DuR zU_r%q+6&E2SQ-_6^nj)>K`OeWNa;R;5rK%M-{Ge@H#2 zij~bvz}SvT>L0L70lUC?6eujV;u|VJuYh;GR=1Zq-bL;HElx-i%pXB2(m0X46`Z&p zCMh+QtJq|w(9vJtEQcnF%7ZF(Ch>xS$z*A`IBd^ZhELb(Mtu!wlUdEgPq?a`4W%uS z`NV89Y8SLH31ynE5fFQuBZQg!AaWZB1s(c7K`2?Ei_%kP-gi!&J5udN2vw~c@5^?l zb|n;u3RP`^#A3E_)y&p#!ljRi^9%&lJoRpj?o^ZX5%S08KUJm0?%>V{J{5=yuaYtU zsg60Ss5EV`etig|E%(d;$>gD3Kms1lCT|r+D>N)1{eBn%vrMR)x6N3|sWUj<11OXw^gY&upl#}#RlI1>s~ zB3JE3+QNy&-=J%xbP~0V(f1U*=J1igtEzV=tPI#D=OOFYshXf-lci+uA??B6N>grL z+)2U?1mHngk|UR==vU=pqUm-Kua&oTA?o!vgQ(9w*@>v@?v`#wpAyP-PMUIk0CS$kDcidqsO2ZLHIaTl?g1hIOX{wiYi&or?r zpbcHb3I}u1EOrsA|AAPkydCYN{|92V=G%xBEVI)lR%sGt6D%QJ&Q^Kbomi>5P9j#5 zP9j#gRzM>mR;sT5npmk~PbOBnO{|1i>qg~5wZ}=*DofF-H8y7!{f@y`RBAPpDNUs& z-^Ad*@Y~M8f8)pY;HOB`-vqBF6bG1)JNrSRa9LCHj&&rU)!io)N@gg#t`vpRYPZ6- zL#6yiZM99NB6q6ku!3}jK}+POi&Xtb3=$$WP)&uizA+VqgYEbM#RgXn(G6&+5gI%7FD4tr~B0BDOCf8)4 zOt>XOaVS3{DNXTe6?<|L(X*2}>E4E@9Is5|xD;b@`ZuU+hDx_ae4~+y)f3K27WmGl ze!+v)8y?E-FHKt6E-Vsm$yk_$#$XZfpBkU*s!Pu8DFW~0{c|#%n{=a2w&^+)5hJ^1 zT^n^+cb-tj(>W9sfMfQ*dW!T%M3ypp(j600{=*i>y5D%AQE9%bJAGOgeMkCrnHrE@ zodW_L|BnC{m!Iwcf0j6g(v*O~5&{3&;8$lg5!G%@pmc}gb^V9h8}~ZvS2na~CUWyL z*9OjO^e1MPAjrkt3hs2z|a5Y@5S@`LHe8T^h@KSwT?HL zh{>Jz*sMHOJ~7~Fy@^S`9uryE)!T2N4P;m?9ss%Ki}L+okidFfoo)0@)u(N9Gv_== z0s0Yq#HMnq+9tNMWvc0FvhgLwJ5hv$-9$H~Y?*C)Bx*+GWLJKUYDN|oNCVK%XPZ}0;=Y<`eO7=P z2=?Nbv&NnA(fOhbxJmiU#g3f7GUL8q3dNKeWR0p@J9n5j?TG@5TDZAKr9p)1 z$2?EPYRkp!!L?Fb5@@N2wfn47%_}=UH>aQ+rY6AJX`kEO*4ndNr;@}~ht2QNrL^-) zla< z+@6FJSKh@OCNS#@EL&K0$F@?I%oaJh_cFMF6c#8i6`!a@I?cM2KL4t3Ag7*qQ8h?3 z?a-W!V(^Ja-is4xq*Q=T{WH;^zWYRH(OtUrPCQqE6OfpKR>pqRxgKJ)oonVl27(H( z33z%wTTH=d8CTRa=xPXvDI-ki>GEXanjYqTe+LPTorXK_e1?IdJ>GruF2z0W_&J1G z96n-aB-0vfE@Fg3ao0|^%Tae?Zm!kGaKDRWBG%xGySH#7dbP%7OjCzhO^L`d>-A}E z%=sl0gY{%=cY1UYu)7*q3na?hi{BI5E0ynO|1RIpRlaZZTNxCf!Udydc?VogBdYF1 zNQ&FZD9Vzcj~vt8c!KDEBO0jl;K9J*iVO)`IPY*tGIFIEDV5oi5j}^EQs2^TksR#A z`+rN=KZ&(c$iPS$dMwPx*xL0qpCP<}jnw9S+{QfObJ&d-$l@py!HyY*eUZ$C0`odM zuX$(Z=hoHq;399{Lrm1F^OzGrt@`Yf=R}{i0=0vIR(ik&FVI?IooV(+6*Z`{D02j2 zD5XzTGbF8vv#+)#0%G;?>>wZnf!@?14yv`q`J|w2R>6@vgyftdTFwG<^&`?p6l@N2 zH=DJN3W$|xHb1Il2enI&9nI7h6qBZ-BhsZ*)HptMeW|!YU0*FO;~I{?T3jO6#7~nP z@_r)hJR;6u=wOKctqrQB0@2Kc@DeIr9Xf=m!lVoxYhUd_vFxt&9-n>3xWvW7&<5+A zTOoYcmpZR z`_y|?;^I;ki)6u1RrU9sO8_XuJ7Mo;D7*x#OKH@MRKd1Me_w<=3FEuy^?k=xt9(AB$JizR*-?rG}d4Ey7u>E0fS3=R{7 zs&tb!$cM=4yS{%fWF)6A(!F2I9uRWAkH11y0sVm9s6zjCtpM}B577ZT-v@$oaAN9w z`Ecr`g8%2CQrM&uv$2>UgFO^KQ5o*vEvsn-?ZV<9GB9kc57VgcXprtbB+3mr+0@wA z0R|^^?^nbWDE&bBow<Az!#Qwdlh!%Z)>Sn{~&wyX~Emm&d}#HTR)aeMgFSt&$|y{WPu z?+9_#4I9TLUcbV5)MIK6pnQ`#0sbi5*NunNJd=noKOfF_HLGMI+Rg_}Owmpr!4s6J zu#HWVurBAzeB{sONFVbO7^ieB>ucGR24o6Mff+-#38}$H2kSiSLv}>oluzA(g}tr! z(J9$?4SFfdOSF|E#dRVXbp{rm z%0@XFSD*J9vv5K`R3YQXci?86q&D*xKTB~(9g|5BUI-bHdwXt*)S&s1-7s3~!ybf` zRddz^Tpkt=mh{7(dHd=!twGunA~o%GYD*eo?LD+5;XWSiuLQ7eT*#fjp72o7_pCuo zj7AlpgPXOnU2<%PbIb192`*1`5VI^;pB=;|V!N0rAP*9d53B&>u~n1kdxOs8R7ziHcVi@VxYwL2qxOM!(Ld?V zHOcnrTGjRpYpPr_t;uq6TGz?NWsQ@I+X~1f%Ni+{9@eFD$+j+#%PCfgTzXn($tA}+ zLoT`2X>!T4a^=#?a?3>{aG`&h24S48MH=nHcC^}ZwhP*;twc1BW(5C|}SNb^p0j&chHujnbs|GajI?}by?%($!&$?l4XsOOApH{ zmu%}|xtwARl}k_SY`NrEgXEHH70M;g>MfUEoCU>2b#wD{&1$1_>tual-d>zuKM8I( zUHb{Ysj1)0hHe-VJ%ju{PHV^ZC;FyLj7~r({*V~rqzPP_pslBV>2UPp=izq_zhV3? z;WvWcXnt4myO!T1ez)?Q&hN+kBK$V;dyn5I{EqSK`IW=bm)~H1!}wj!Zw$Zd_}#+q zPJXlbE#UVvez{Di)A*gi?<{^L{4U^kDZi2Y0{q7DyN=&vepC7VfZtE}Mft(lcQBNS znN?@Z`cnRLP{cmwfp{lNqp_mH%1srkypLsbhlxU~>_k0g#Uvr@cr@sV?Z*oYp!6gZ2GsF;9>pnD@^s5wj7iNZFlGjCcXfZQi`c%7!A zYs6HPgOterd$I@Ow-=Y#jg{TIZ6Qjt&C_V4wD6~7k}bavFtDPCf?u>~+;H}a@fJ}8 zMGsy=FE-hd0W-RaTBoT{E11L+p^DZA>h?yiGlDavL^y5ybF_y=Rs3&CMof+!7_3Ba zhS(!{%mI|EBDmC<09a{v;Cpl@+gLvUYw5JD^{$(9$#>b+sxvBWyINp|*jV&_owl{- zvBZD3ZSAao*V=h@Yh@2-Ry8T}+6yIr1+2Ax7EV?HV-o;C!~t|!#P1-jL|%AI*K2mi zqEk;Yx4oIw9Gh@Be#~&M?lQv-lCG?7v&HJRsZ5#-78_u(0Tw6j$XC)DOgL|D5+HU$ z(0Z&}`F}BwClIqdmF9gqWj9#oFcpPYk)VG}$noZ1CQxH-aRZ=|gh`a@gR3M-3{!Bs zBB26Kk%SjW;HgYJ2cMSw(gNeTl z`TLiF!di4tk2Ycp6H~GW(uFVUXa2FSlb);)L6K|%B@4WQ7(wS{oyB}6f!*$optuiq zG=0)J5pjORB=T<4fH;v)&FdXxvHAi1vm6R@|xqO&6Nriq9e6pB@J z?isqrp2EXmJ6n8*5H`bo8_|l?7C(5pKJ7pylL@*RuOvQm@N@BJ%b>9KD}zQyrPIWQ zZfDr|C>;Os^P$GC0p`UGR~fat+WTZWt}+7qO8DmGWWi+s3%r&V$Af<{^RE>kG9O_! z1M!<5_ZvInH~*IHrEzU8+GIfHi%q(Hz5eR(*6d8Ii<^VS=Yi6_mDAp;^tNgbi@78Yq6CTE5-x4I zhO*IYa4_FGHbkT90~uEk(a`($JWf#h^u7Xlg~AYCS#0QE2#PR#hkTiEe}QP6=q>G1 zwf*&&g;VxlA>W!(emH*f3ZU1Flj;i5i6tgB`(sILFhz0wDE8wxKLm`!=I5ILCh}ag zLUcyVUBkwYpVy}mc=J$)@U@)hDj`rxw_c^a{!)eXDRFg%9Cd&l@xvc5 z$+y;nYQ)VOTs{9`M~6WMcoX$X!0ET&;?d6wqw+66O%qb29EimlIB_3x88*6jlQcuk z-82|1l-Xj2mM~9=ysp)5R@GL%Eb}QW{gsuF#%jrexjx|wnfO}mpU4#u;heFv^yZy@ z=S~oob5X+Dg8h^V2N&oW4WTc5*`FAlr;3_RJ%J$pAz`~fw0X&bv%5-^?=Z{{XJ`wa z;}$$iHU%)x^ii_JI1=n{=LM_a$Hv6JcDUGB2wo#(8A?!1B3ZnMBT~KVvgFFEjEDBv zXtWVvj#?N1ji#;SY>9d8#?8O=JGWWkAVwN>o9`P1ZhX#Gz7oUe*oRk!IPT`^#F?K` zjib`}p1G-XcZ4BNher*PetilmNC}lZJGrG{nf1BTG`2hKaBu@@a)aH@ldfe zTEH?JBLWEqEZu_{@o=_Y zL_ov`L)RP4kB!aFT*i{mfz<@YXv)MLNG>`+xgrG=#5=badnkZKPESEaoPY!>PKc%i zmI8n1{|%t{jptZqp=}fSSaLf=B@N3Z z@=4A=Tqa8++Q=JUgxs0HEhJ|hN6OQnepG#c0Gd*La!Q$#gCI5pO4lR{?gf}+Ep$eT zec;|3Yzj-8l)e zt|2lI&gdlnHO@f^<1ajIy97EeG;jH-(vO(4x!Nq2ipc`cROKD;7}K)qN2+e6t|2bw zf;^?a2`7phLPp>#$EbsWcDSZ7u(^NvkfJuRWOpW`QyJJ4q>dPo6JNs9b|E2D zW=P6N0*TTf^GB48{;gJ3(U&Hef53H>DwHiH`)vr)Z;^_^epMQugc^^-aE*ZB%Iz4X zy&gF-9E0Bx8FNk{TIHcu^sUbWf+H0kId90%s3t~bnyZlja*z0+-Te7(d#9Wuv^3!! zMZs4YE^}1Hl*1KT0-1`#e0!dd+l6T0aqa&#K3xtKiuLqvS%+)2>*RI9ouN{5;a(>0 zyUGY3Aui(>eClNRlpU3dAzLFiCpKbEkfA*|jPkBd6kkSbTEnvBeXYeHHAJL)(+~B~ zUdBBzxX(NbX{7dY<-Y0oHCzfsiAUd5Gp4^HC}t+FZPLQ~zR5Mb=0sKUakPjQYoJ2w z#bm)c0jdIuBNg*e(9rhC zMJQn+{W!oYde6xPJb9E|*J~%I{TV|U>zR|&{^tm3k15E&VIfTe+w`;GMqp;(^jhP= zZOH;xg+PqOqhL8w5>kzux5+}-%0d`q$>N7?E;(-Jmiajp{c^OwdF`A|tUO!Y3bWI( z5}v`RY&V-Qaqjph5A^M(o~dCL&89EnuDR#^$1?~-uCH!h_$w)Nv>J`_-P$ZdYxF{fPoq*r;pCQ z0{NVyx1;J(`G7UVQ%%iWiyhc7$eMy{lEXWpws2M-0ZL}P@1b`p@j}KYr)afxD!1m2 zh+rKnCBh1!gChE54KN1^)tJIjAu&64tgvRtFl^fpzqWkeX|PyDY+sOrZhxlz>wRBG zhKM8~N7?1Phs=Vl^?ekcR$KjM47i9hFeZL}W37l@PcfIMY?j-6mK%66Xm8rDni;j- zJdaLN%<1$7NTf5^ZQ#9eiaDNF#yFR`2)hSeEvd4)mYEVh1Vk|VYYgcBMWiQKweZ9SS1jK_-dnS`f3gA32kuOP7jNc&aTucb6ygJ2vFh^Q#buSMY zv~sM1+m*vdmXTHd-7nIBqQXa0REQQ}^A^<801NSl96)1hF&uN|LKe zMU?Y>u~o${kBQ z9i;Osne2IN3nG*<$z96Vw(M)tbnSj5vayj5_hRNSE!Z(n*GjhWYeylm<>KkOb|2b? zV*{?_8&b{b+JvD_b$`LoV^8u;ZJqs1>lfNbUrg6-_;k8S#;MXSSqAx2!ds5QKi{J7k&>HX$@^Q_(S6wH+b3mKCjvv~i zl6K%RAg0nM<&Cr7lcw^t$h#Ztcar~Ip4U^(&?frLbKbr7^)vd{LFM_bMy#DK{fnxs z&q{I*iQ73o;>%V1-r`5CcLQ?Ja#9n<5#8(~_@H2}`e2H?T3si#(nOkZ3)SZjnWvhP zKlD+qr0=5%`zdfO_ifzEZ#Tcaqz&=e%^o^QT|3`xPURy{e!;s>NJ}SuNb_l6{w1&S zOj!*6jsf=fQ<`|+P8v$Kk`1Zy>Dc6r{NCrCbgGdb@4Gt12sNsrrxYwx*ZjQ{Suj9~ z2c76s)mtdWjt=$GNwDUtj{U4((-%bt(u%xaV!RzN+?#l3p4SUB*VFnhdHXB-?LXyh zuDm_3%f3YSx_`)PCXUxVUT!w(Iqo^!2r4y9U(~IQn)tKo!UfuTjr=)<}V)RX(f^m}P*pwk#?7WxUL=Uyv zpV@Eo5N}DY0YSO$s`?^h^{zM9N?k3hx9=G8FnK9$$XNMi!HX&EUfp38JSO?~TX_kt zAo0P!@%Y7*b*mbyz;21lDPMjuxpDQe`~lk~@3H)$f8e@m_x@)FEKS`Ey@neA)~-?? zQQ0Q*(6+2))$U!(Hc&v`tG}^7{*vpe-E05ag~PL0+4#86%GK7Sw|KS8-JtSLTDkg2 z=QuB-;(`{HKE>TCS8G!1>SMR8BYjA#sxg14Y1h1e^%s-YQfJ$$-5t*i`4fq9GjzGU zwI;W%-Z6PM*UjpF%jCVQcTDzEabU$wLOpbb;d~DJxet>3DQ@551R4-5soKkR(T-&NPU%a|wM?t-ObEIVD>b9dppOY6yK}H`u zhr*BOFnW@gMIP|+N}6H*hJ~P8x%Tw!v~QB!hkvDV7f9~APR@-zj(aVyBj<4Qg4_sx zZskUiI_lU%6Us6sZR$VL z;p37=)@4$q7F=iLFLQwZ)+x(GhJ&a6I=^k2VYD^w&8Cn>vxmP3FW8lhyWK>W%wgdt z?G#C9ccz|ts;A7Lr2mQ@Sxx!$>fy{{+f1Lpy8gI)38DSrXb4ezC|tmSA_5KZi)=@d)ITQK}#en zpuN1&>g!+Ts0Kp4{L6qLQHr_pjOn-nSiv$G2CMfn z0lw99nG6Lc4=-=@A8f!Na5iKQTlHie17ZtwG1Myn6sJMesaue;LVS3J1z>vxz z*~ziF(R8uL?6H)_sAASk2j)0TOX>3A`^qq2dX6$S%AcNt!UcfvWm_lQwU<}c?79+x z{g8&F!$CL*#zK1z-lu7U#QFy@9F2Pmk-phq2%fc>!JiqUqk|+xXks0s&!yt?!{PwPny^-iG$5C;Ty-67pmTqDBD4 zOZdP7Dk7&AL+lo`^9WH_evLpFEff`S^0lpu%5AB>y{+Q7FwrUF%POfL}rSwn8DoF0_zSoWk%fWcsfpleA&AO&h~=@rggeDt-#9G-s?gzb{pIMH6ILe zW;@NhX|lLI8!gZ^r$4qU9|eW~b(!pbsWLlQw1(>2jCHhSh!7O2l-L5xgqEmAf#+n9 zv{z)lOU?{`5$%+G>VPMsO*$s0wJ9ZtUr+lh~YeUll{ z>>FpafSj6@6I<`IvTD{#f9134kr|)SwaBFhn|zTALDem6H?51-xc7caGLyp>+p~h? zS4mc2P7Rv^uhr9j`Fma(>ls=`7DST~^{av4q5F{9?=pwTsM3G?ZN?B8P#_?0JBJW_ zEc&m;u4a#PC1&{|{c9{Wa5=GK-#Tu#Es`$u2g!3v!Z}6udd4b=I5-}zuC|!M@N?(( zq2h(yE*FX(*P(58*m*X#zIOiTCVwVv3&(w}<_u<<%uSE^9H;C-BYOZaCyA6IN`Tm^ z@tyI`a1u$=VX^Tz5Zg1zIC8KtJJJW)+&!9FE6iW;ZEVjW>jo93(pP%~3lwenN2gTv zH0P>U$E*>)gUuP7ut0LpD$Vv}nWEmEuspoWBz!6Fa;i?_A)mO^z?hi+D#vk^)JNXu zR^=`8$QzG(^SL6<p_yEqOp0+J zVSrd}s1;LeRVVgJTyMVHnD_(9UZ!d<;V+v`^D8!5)|tj8QwKdo2;@^eG2=YiU!%SI zTm(a#a^ZqYUMg+}2;!i{MO0KcXKhH!C9)lQPK&57vel<>0w@1dGM9XD;lj1veclOZ zbwba8xN3ilyAV<4JCtIfs0Dbru#?EeKkfYTwOR)D!Mi;=;xZChqUbZs@!sPOM{(AO ztRRdl#qHpc%Qh}bUX-u=ktDe7TWrAn%lb>Z6}W(wEFKl;K2|XWW-z3tR1j@0DpYiag1oW=LeJ{4Tr8j7&ZC%g_Ox(cure(`Gt zcD=zRk;Dy_+_V@14}d!-RHS&W_=V0jA7=!#k~Lb1Jws>6+@$~6-(myv#D;ITfe9dB z74G9C8<i=bBzu|rrlz?Z+t6hm<%s5|iwoGWA+-djZCwh?-||t+L!8adkFAJp z^YYdqYtqHVM5U(hb3l;1QdneqaguXfn z#<5VL@|wf4!Ji$+elYGolV8b${yt4=ZuscKoR2}^9dzqNbeJGQSs*dm$(6~UciNv7 zdlL{eUQTy>$$}RkIeOgf=PLn)_E-}m8&hE_l`R|AVMElrBgf}(TE;z+T^J|9{rDs( z^9-6Xv(T2+$EI#W@prh=XfY1JGU;g2#nvis54I@Df=a$Mwn41!Ocrb(02B^qMQ`Qp zYTj}hhbq6HDql35H23z!WV#(;v|k-30b|y^fEMG*M_;@`4gzzNA9+9 zH@oKnT^riMpYznd8sd-=Ez3-`DKK|4Z8DO@08ot%{Zp`1aMa^-JvufIsgU&$D-KxO zU%q(-I^Kr(wJwxE`SJ1D_9d6?R=$LS4(6|TnD;T=l|fQwD(M$?Ql{GS*|~mhC%H&+ zrE>kuPRb@JJC(G^PRfUL^K&8%?!hknP;0rLy;A;#eyUHuIEDRk>P7ZRFM6_TPQ7rQ z^diUEkV?-aozkVOMl&~+m_efXF(i5&WG%SE3@Sxm><(~T?bd@ zcRpkuT`ST}YNjZxM)ipX|a=cpUc3Hv$II^BL|? zrYQM)2%12JI>*Pe1f2fydOS<08z#6I8Hjj*4e=_E(iO>84qa=cAmKkjC36bRpWG-b zkSv8(j(MAUkX2MsqO@+w9Ep{#u`RaeO0!b#gp7$+$X*W%m8E!UkNOUlK4ve;v=35P zVXQyYRSVI0rRZ4BCgy!v^~jOCsUb4tV52YMG53p3_pCMU5=j(YS8Ue`^IZ~U zV{RctTA|KkGH^(P{g*ze?%ZnAWsm5jen)N^m(v8Pl9qKmNrG)J9FteLp9*26y|!-Y zkbCY^R0a=<2$&m_$?JGUcm>$BLMZ)6)bvovF9&HuHrRPV0HhAmnxDXK@qSOqzyl$l-0kJ2Cg`rkL+{fhyuUUg0m`E&l|S-$%4U! z+^|9ah{TPO7qsnbQ2n}$+o)SkP3kGNxqbD`atv|z6*JW~j*OND z8%O<1%j5>5A`b(SEO^r{8UJLx-y7#1#AYuLxlZ_E&W(PWcOnX%P`;U1Oaw&^7d814 zp`_7Rw7#g>*@#jMol@u!v{}|3^stBa6VJhDL}=2Buz%SY)v@VEseM3f)*z|E^;UC9 zor|URG|C@4Jk34uZ750Nk{xfINQRx@kRYf(wzQV)d9(GPv1lK6621VZzTpUGeSJa+ zy)dY~JSmGxgT{o5awU4xK*OIK@V3tCXxreZ%Rya0t3oMNz zdJZuyb#AJg-782CM2+@X2G%&o9bxBQ zuBPk*Vt4Fw7}vwu1zU`)_{6g2;0pp*Tz-~@<9BfMbdZ%XdM^987syj)ZU?A}+?Or8 z!SUk;o8r&tBQvGL&BP8FS5*Gr?7azeP1pPXe{N(>$c-c<5p~Tmgdin`oRh(jkPtCN zDVZ(_8Ls4pP%4I2ND-=N6`^QQq)LUV#vE#hsWnw&DAB6k#1!-YdG>zx&CRWT`uVTl zcdhS#t^aRx^1iSA?D_1o@4091b58Dyh&E5d_P?&xD;HMmT0VtuTxFI)1#3+7uEEIj zYsZ{}J_vmlmZJP&8w@XNc?zGPMYh895S&oL(b))A_Y`)5_mO?)2E}3Bz==Hu4npNX zD7fF#>4P;`R0s^~pNAB}OI=>O&1a$E!4$=r$?zpqf}Of{X^UjMz~EHM?I|)XcF)&H7osc1ss| z7H3x1%&xj-(~UJ-4ylyigjGav-%NSfTrXH(VC9N6fm$@c9>Z$Fewt$4=Du70+RYVG zFaHj@A*_`PhqakHSd`}v_o@Vj<-Qjx7Ur>AZurS?czjR~7-Zn#zHmD$8)f(iGppDg zUU|+3m`KO)?q^|u3AL?tJiPmv^g3*SDHa0^etj98>30J>>ptKGyZ{y&sN4@)7mD2k z-;K&{$uEa1&~VdGvEC^+u-X3dMo&s%g5~eOe~KdBfw`@&s!UBNloa~v48BjCcRN5g zAJa9|J=2;kS~v*Hkf0QJ9ubin1g99s;VsSOa0*@HRhaNS+bb8oNH4?VUaP`$j|DxJ zEMXm!9xm4g+D61jTEd`T>r7~TNqEyUVetq1=DNbD8KQ=&gV;XqsjB6qcYvpks9=)F z5MHY!yc1+|Y{cE)p1(4^Q@FIgD`d z?1FO{^~S)}Rml(mGq!LaN)S9j2YfSOg(Sp<^9#7veMoI=X_NHZoC%v%Wt-mQ@qQb< z>zKTGs&1Cfa3}a{xEs0z{4(#uFS9VX1W2L3qaJ#n%V(AdrO~ z-ZKWbGe8O>;Cv0<+R@Y57G9N}i}$VdbXI2uz(;rd=ng+LXYJR(GoUk1hRrI2rxCDB z^stnj$8P{;c$C4h%==)r`C}HMam#hI4|OUDbvg!TnXA^t#O86-w{NcP4UZsmuIKR(}2*mH-ckfnO!YQhWx2C)deDatP z=1xR-9vGhIMS*=G4cPhc)*?8S#wV?7V3|R;r*LuucN69gNrZ2KnDUtxJSAT^=ZBP7 zj84a9_`?{+Z=6H_L70U%8s|p%!{(bkEn3pU*GMnO1Fk+qfUTGJ4FC9ylrne|Fnpes zJ_!56=pEfHMBCx`aRRq!{i)Cru|6h03Yqc3bj) zc#m^CVpq~K@?T86fwY+PJgI@S&V8Ov6H=KpnlzPkHt8zT9i%0smr3uFz93cqMd_1v zBkfE24rw~+JkqtK$4P%8y+v9{`hwKn!1M7UZAaRJG>SBlR8N{snn${dbQ9@5(o>{m zq`#9sCbg*G`MZ*~AnidqlvGEWO}dzL9cdA13F&##8>Ej(EvP@ZleQ-HC+$r-lynSf z7OCi0`D!T}OD1uI{SBiHN`JiWk9JiSAtLsG}5rcFxKXtUzAI(<@FDkV_$58>lt6Ev~O z$!YPiJaE>@H>WGg0Vkz3oOFtZKhc$!Ba7I)Tvh+zpC4GWJ=FbpdN_EZ(-7l;kIvi7 z?oSL;gUp2z!!#sw(Po@T3@f*o%QA~Un;5S|qsue1=bLdMu_#{=vB*OPfxHVu?TN#W_L7WwHdn;i~RvNXtI7N z()T77>9;kr`k;J}JkjW|ty(e}bR#%()YL5&ILv=?!zyX7(&I`*JgT5ph$BUq%dJpGDk^IN!`(LfnSzRm38F_sE*<6-eBK!Y2}Y6E7!jOoq77+)L+H;Wi_Op`h~|?(kPO52TwcVDxBhY+RDaKVwqT82#uDlo8~^xTBGE`t;6z zkbk;1L!X`$uNUz$Q)82p#-?f$n1`@pMKr0}NfceuBxsYhdaV=y9zMkK5}cRJt+2XNJ{DfX+UsE25k%K z-Aa<)2OS05RM=WTq^a|8smw-!yuXp0_y` zp*nwK>ZWF+ofrR~Qo(eR()F3p5(!Bey5!h+ZHhKkuStp3iF#@iHUCl+-tN`ms@qCa zU8I<5`+qD_OnjPd@;@~i);lvnuSwVHGt*PqZi?v@D#b(%9vsF>0d~G$jlH5Kzd2#- z|Ds>>9ikN|#iXUACTXw_Wh7y*h^cNQex#W0R4kvleZ;#pLd2xRrpAudCj48YnumL1 zqhfy5?fSQtt8V=o;Y9nJwXC(vGe@L?2O_5tHNQu|JIKGl75ZjU7wh)g&$VchrJ}mGfk5w8c4pHzprCRVZr^IlmPwT2Vt zelBhViD|eu`H6E;^Z0_Xe5Ud6w*D7>`xqmYVT=V6opY46K@}!3)he&x{wD@nSRn*o=2r z)J%V;89P!z#qnrIjNcF9TR|(elM+}Pz;klb(tE-8e`I=Eyf!04lBy=wyk6LIQcVv0 zfwP{}m+V5N)!d#yT14T_lTvY{*%YsI4iE2`!*%v5uEnI0yEu#VKl+BVNJpr!3qE01 z?vKpM=|}8n=8xkv-pYpK5^mUzsMrT!c@`Vja8e(~7i?QRCb7-251^tSDqf#N8}=n( z!*nq&DqhdPbaDC}{qXm7UE0vUF>L7nHf+d2#396ypcp5L{0ET^1I6@*!-jb$!-nak zz@~vs2b&jc>9Ap0vth%s&LEu$ivF`;!*piDhVh}FvLj{{@fuJp*E-lRpD$sbHwG>^1^R7DM3L|jZ-LRw0Ck+h7ooYX)njpp@HlWIu)Nh3*PNV7<@Npnc^NSBl5 zlNOK`k`|E`la`Q{l3pY&CzWETe54|M4Y4n2AZa9NB54+B9_c#LuSknXOG&Fp)v-L^ zL7Ayi1k3^rhV#^6aBXIAVy4tPJxLlAtCzr*5IY%`*Q9a9T>{}U&=bO@@=tt6LA-Qk z0EGA~9$Fxs%ygo@v8hsTZJZPln=S?E(m^LneIft8naNU6=2&TvRwoUB3r79ZCQ3cE z@hoA81J_0-W4v_s0em5Td?F~Mk%Z#|q@l&YkPeg<{4>X9X3!5NNK>y(iPPeEfezA7 zLxMa^y)i!{2SrFyBy8v+BHAY;w4cnw27eP6CxQ>O6^vv_po8ES2Ns#fO90~O^7z%v)5(A|cnF>z{(h`z6b&x z3pxnm;aEKYzO}Jl{h=Kug7yS|+_OCWOqMF9!}Cdp*q9HmJ9tyR`1_4Jo_`X{3w?P0 zZ1=MOyd2f>d3iFS9e9V}<loDMeDSnQCf9;`7 z6X5S;llq_!{%Z^0W*7$lX^cJ?l7|kJLZxm{#uWIQ0sn;4!d~%_hCusrmruvB&~?N@ z3y6h&MJ%+?%wB9}FEz85nc2ho_m+}U$4LEy`b(*Be1m!qfoKCt)kJObSm_6t7*`WbiQp}+Y^{n+_M zwS6!ge`YS8=OeC91QKVHmXi7=@Nn6r;yOk#v83hpK+q$6zVTp0P#4#ZeSPSJ&01_!;+le;# zxB6omID)6bsAn2ql<42%PllW^{un5iNTIsb{w+SQVLFsT#KqE!-2c5jvREtdK7=Xo zoU2oKbN-m0_%-GOW!J;FodNBb4tetuB|vQ^y`fBRP7mY8LmJqUdKdwHAT?|kK2DDT z3tq#+K91j}HTP6?U9p>Kr7Q?%em${f2@@b4?6GOE&*I>3)*H$xy6k_Go@tG-%-EVW zkAmubf<0{_guttwrq>&>gyJ`?$Q$*|?S;NNINsAB4qmzRftJHIdebPtd$QO+BF~!j z;=kiCzo2w&@1$gHkS-}BsQ;iacHK`6{&+tACdJ=~=wFL8JR~AkH;Bz)u`8EGf1K{p z_J>QtgVVx8!g@k*_Ioi%r;AKWPKuulS4-(f{9tW*N>VCYZxo@`C#K=)(*JeT0vb45 zsQJ%Z68~!YznMZ|Z~do#v*8!B`M;XsXTWc5@lPfFcmGUNm?>5Nvw+{&|II%UU-SR_ zevmz5=B(Ktd^jg(?!4TO<}X;7w`lRlOFmh;Z2703t@wQ9s@3^x)_$>W{e~|KHg4Md z)t0T>3cud|&5oVl?kd{7=exb%@B5*6|AB*t4j(yMa_snzCr+L^U3%v1x$_r(`uXCe z%U7=ca_!f$>o;!R`tA0e^1HwPaqrLje;Fz&A3S{Y_(|2%XU|{2W9ucAMJ-D!Ya3fT zdk4qbb)3}BbzNND>eYAm@ND4K@U2Fg#!Z?wYu=)zcdOQI+WNF>@7tkcC%?Blck%Dq ztvk$FDS@$ZuwY@#*u z_doT$OFwVBnq8}neYAV?59>xAtY{Sv^C938cE0qpI&^l;7u~ z-kFoSzkVIxNdA50XguMOq+6-44xSw6xOYs)MqS(0vgq|r^QyBGhW0&h@G_h*sTZ~@ zunpP1X{u-A1%apLJ#aX6Xm(47Kc*gB(tJx;U5Fj%`OD?Ot55t8JN)YA%_EOG_OyC5 zw%*<|QQLMsZ#92m%o4m14VTy*=Y3ay-GXgHH?Hnu-FbVzcgsd!&9>k4$`E*IK|yJ@ z=lG^@p(VjTyyMcN!)9Fw?t3e?$;L|o>K@;xKlp8t-fehs?F|j@C0}Z-K6e{ZQ-AQ* zh}Z$CNv+>=_qq{j*~age_V-&x#(z5D*oJy{`!4WqXInolHOw>B16w<=V~fBomXYai zJ-u*dNvrQpju^AFUH7$DrajYsHR#%;6>BwxgP#6yWOMT+{UUB!N;7;8K7Ux+Br4L| zY1e~Fmtiih!B?lf+x4eUJ%(3#`7f4!a{cDR-ILZ&iG8)J?zmXE+J4Kq;ry`&hiV!v z>6Y8sZiQ`)UzcPxxu?oSsS3RH;wZ zD~Ebc&RhpGW7oIu?va@@^W%ET$?@HG%)K^em2K}{5s8i)uDo3IakF1t?j`!R?78F9 z`$03lJ$T$Ax?*7BrM1l`PMbfWKlGr4=eK9QQ|Yv2*b?WR+0vMutu&|49{zb+in87- zV%N!Qx|Np$g6i$+f4p?Ua+g~_=XDDla6{SrG;LBui`(1m*=co$A)D>aMmui!u|@3A zIkUXR?SD8Yb7FbVwx|2#2d%QQJtkZ4$uBQCeP>AVv+LV?s{Sf`U(+n3dHR_dPm6AC zwQ{owjO#vSz`N^CbqcyMASK1Aab>5WzYTTS-+bB6e|XRSW9hj`-NWA6>eHx?#(&Gw zGpC--yK?ec{|}23hpc%wY5UwBb(>A-H4RSvgS=Yyt)Dt*46^=iAN<`LjUNcSY5(Wt;6^ZB@Oup>5x!Pkwl-mDi!8o6cUiIPqxbGmb+p zf1J1S=w}5#_G|7w(NNnir{IZR-Kg6O=g{A_EQlYjzVqX<@}!?z$mzFse7GrZM3b(a zKF_q7(r?k-K0cG4rhaxO(4pR;s>P0K!{|!q0T%vBHhc6jOeeb1vi%q*(q(JQ=G*JBYL zUrC1>-6#&9ye9it_cK0U->qtrGU~Ir{_kD%n0zXI;*qS?yMLS9zt)mlZ0L}rHFwXC zOir72YsH;Q-Jh;Wi<>miFZW3K@HW??uk|<`{knG(x2eMlhG*VsF=*_h`tiGN|1sMB z<;|q7<(=Nnw7xdl*Lo<4me7C+ucqy5Z+Wa=;h&GLU+%wV zVa64^Tc6(_Ft+w;w~asT-1)f9QvZxa2g3e1v8>JLPZWQr$KNc{xOT}p^K0;#{nwhv zZo_`vHgEKAk0#|Fzw^b2sP?r22HXk8xiv}s%fl$UUhiHH-m$fv-#1^ReQ{Dro#MUY z$)x@LN=wd;EvqWnI=1_*^*gPoPMEGV~;Cazx|@!cGt*F^EY?>J=kyQ zvW>s~s(N+q!P#t!$@yI%b=8W`BP+ICJ=%6lfPa^WBN?S*Q+~HDSTV4wveu!s*Q4^g zHC6w-G2?@tdoI;IUCVurZbi4NQRPwFf9wCezD@fL5&N$HyxD%hpK%|(cW?Kp#(`tb zOS9b8+|ImtqOw){*)y>Cx9U$yc>d_zgn)_pciX#88x#JpQ@e_y2McODxg;$K&nR$e z5fkX5>S3QV;Y4Gf^YvM^4#ggf+jQ~roNK># zDvC`sEcyPk6E5Q}?4R$$I*i(-yz`VJt6J52Xs?7lIK5&0q%WH8TQ_sW+7s>5)o)Ml zxpH5T%YlOa9m9`p>9lI^o>yN@?ASQGUB{Cy@{UEXbe%7a{O*HguE8%oPxP+(#sBu% zIW|f4&sccAs@N%S-Msr?+I?HEef&!_aMOXn8J8wiwGH_B`h?}}?_98pADI4&N5Qt< z@3j8u)K!btuYT!$YJM}9mRrs?-R1F}<)Jnwtaly%uBT ztG~Fha(nEJtMRS(TDDlS;({)AY4e*0c4s=cHg4OnQOr1(qP5-6&dr!s5%cTM$B(r6 zHOacmoT6rbT7Nv|kJK=av@7#J&YYE)@Il0;7&>i+W%S3 zg-_dtT=Kk=y|!Jz5j)?$`^qIbcHkk;D|D*L>n!=HwUMqyCO1k3(C2 zKdi;nc9(NA^YgO1yL@}aColAL%KMhLntd9{@)Un8U{}_H^B_w*No84EQd!lNRPaC; z3+uNe3!CPWg{_ZN%l2)lmYposvJaIk?V}`1hj%4Q$0W(hF;lXtJyWu(lP6g@t(L5v zwo2COeUi2FY01X9OtPt4DcQJKscc=`Rkm(ED%*M?D!Y2aRd)4tDm(WamA!ku%HCtQ z%HH#w%D%yUl|utN3kR>}77h(@9Kj1YN zFK46%v^fJ9;o z;w<7?#5u&4#A2S&ig-EMt%(bW*#n&*&mv-5vX>Cs5sUQ}4#XG9?nqotT${LxxDK&x zF5e$c#O}muVsBz+VW)Z0y2N7s)I~6bcO{0~|Fdyybt8@@u1B0m>`t6T>_MDE>`AaYNz~;1%>Lx~3vM-xX9ClW^yXAuu2&LJK~yqx$Q;sRnVaS`!& z;u7Ly;)}#Hh|7spbOKUEY)LHEMc5GAF68ZDN9;~)FTxW$68jUYi9?B9h@**Ji4%$I z5oZy566X*%B+e&pOI%3Yow$TpCca1>`QD%97t?W z97*g*97F6$tRwDDoI^aGcsVg#IAyMY*pj%2*oL@-*pB!ju|07)u_JL6u_v+ZB3}RQ z#O}l@I>GZMwj}l^wjmBBwj+)vwkJ*`b|lUs_9V_B?oOOftfCXfLSj4OVq$yZQesEq zGGb3+195j^+r_lM>4egq*pAqn*q+#**poPvxI1wSu}Z`DmyXzuIGfm>I8VeU&KL2U z@%V)zK5?;#Ph2YE6PJnj-aNiR#3z?*&;k~o(NBzFT(rt@P)!oTrBK8xV==^iOYmNklPKyPAn~<`uF5^wct?B z8o}Y5eFaBy4kWgm$~ltQlQ@Q$uVR#7-N#rK5Z5lD6YIx9X=PnJtTI7|>#Ml(GfiA= zfezQvE8LVPfF;DxE&Y^@!MCd|=h9 z_&tUF204lcXZ^w)r8`H!7iscjOVZX)t(eMDJ!Tg4p>@RHZV0PaKwgC2P%ulp0t{KGrC-TRB z?gOP0zc;bJBa8OKevkQy`eFa~fzaajEFK3~KUyXZp{Fo@2mXcw>5bz9wp(?-!Q;dS zVu^ZTI3MUmLA2kpSi4m76xQz5jK`O0cs$O0pqGkz@l}Mqjr$FcJFJH&cM7X#gt4Bu z^3Jqh@cVEhjO~cWDXyax{Tz>1WN}>Jaf>YS$Kx0Gi+MZX@od_E;#j?_%Z10eX*uzD zH)TBTYciI*IzEmArkuj|f3+RQ2UB~7S$a5L;C>P96wm6}2YM8DIF6X^M?RiZr^v?@ z>~X_c1U|lCioAzSfcjv|1k;}3s~D^IYYN*>{f+I+$D=T5Amz`;lMv(a!qx;IhZ*}J&nMDo=lMj?-o&lqPq(iLV>=8r)(7j4KB8yvat$}ydHfLLI3n6ve6M1B z+!Hn9i&2E1XJUJZ@mI8;7;kxgeU0_x`3*MqBOX4;xLb~6H8z4^cNDViBA)2h%XTP5}zdwB;H6INxYjlhWHS%j`%8ZHnEr|$Rj>M z_I%`r`)*qeAUu|M%1;!xtl#L>h%h!cr_BF-W%CC(uh=gZ59i^*OSsq>MD{bp zCB(lFUnKsSxSaSnaTW1SV%rV8J@ym36Q3vcCSFJEPrQXVl=xTTXyT8F6N$@+vxvVV z&LKWUyqx$taRKoa;v(W}#3jU+h%XW!Ax@;@u_YUUPrPQkzM@G5c9h2$zDQsJ+V8rr#taQvTq|U zCl==i#gt!dvR9FP0C66r=S>Xns$%ng|=>_WN$`%k?i~`8myNgUO@H& z3g3pfitH)Gwi|hUW)b^Seb`D@@N*~ohh+CAdw0QPpG{m!`S}w2lYJ#|C^5f!2kUT% zGs&JvJcL-ROQ}noMfRn{ImCmBmlH1|7VB7ChzrO*pID;$bS5q$`}@RIIlO&biA%^n zRK%al?QX;u$v%v@oOn5L74b*JwwrkT)x_?^1;S40*CX~Odo;0{?DdKL$iG5+@Q*B+erKoLEEoc@XE2eFSj~*_#kACwl^M0r5WKBI1L@CB%iq z7m16A%ZYy^t|C54>`nQ565DR(^&d$ruIt|Q ze@2``{4Q}hh3`bXoa|GG#X6Nh;sUbIBUaDj_3`zvAVaN-Wl0X^7p)9!DHX@!ul$CVLFAf$V<7{$yW8 z97+5haSnxVNt{UbB;qXMG!dS-7V&c88^i^~dBjD;YlusTw-a9^-b7qZ+?%+HSVzpS z&*Gi%-0|PLv647{;v5H8c}?vJH0vRLZ)<6GN^la*?g$=7vnqne)9i`hWVqUIntn1| zi8E!q=3&Zda23LoCz#psYN@FmuXdWUxY{l9pKMZJyz0rX3dWmU59B`lZ!*|L3OFz2 z1Em+~^LZFCTZi*9c>MwIm*vKAQ?7mv3BR6(e@*T96oi^Az6Zti;1rs5;`2dcjaMJ|b(>hYO3WSSIAeJ^ zi`hzXT`1nTpSd0HXE%+XWGo-Ik2CIP&Z%bU>x})9+r=!L$Pe!#H%-5~pY!ljjQx;b zm%-jH!sB%qyxZQC<6)oGWOIAX`1n)-)A0ORGU&tetKQ$7#~Sw^=R{+_;hX~Z{+p(k zYTSR^E@mG^`Z|;L#QN}O;Z*0ZGxl2^AFqy^rk`nMpJ1 z^7%tC>x}cxIA14bTlqXRwzue?{5orO{}C+4A{=?^s#3}`}WB#V$G5zZCfY0Yumxs?ci&YKy96#*uamM!I zELJ;6@O{T;gv5v;SRC%$rUiugDW zDpp&F`DJ`^i?H)~1d#$>*T?T9k%E{fF}35oiK!i1RFp`}D^xSir{hygM1JDB*uzSOyHizq$E*ZFPI| zC-#^!&i{*5D!85lYhT@e_<8`bdIjy+U&QJcTqlD2Bhxs3@bv;ZM z$1>1m3BzkjhQu(vCRdr+ZH?yF;>4JIR7MN`z+c|vRMXdB#?{G5b$)B%_TGATF2`L{{;Fka$Dn~G;o+mGx9}}9#y8#&Buq?Ws_l%c z!w+HZf|o5LCww^m5XW^_uT^2{8{#kP|J4iT#Ony zVDu7HX^_oQ)Y5}nmZ2KfMSY5@dHU!xRNcX4pQGkm`>#SRJp9vY#;QH}sG93@)}R(! z3|Y%`Y~wFb^PK-=nyo5Yhg{}Ab3LkhcfSp&fwNq{L@i!^m1*g-FA5lM8n+R(bffPk zR44~i>9akXk@M!i{}rnGLeLh}{0Wv@QFRGNm={ncu4F49x8{XZ)wD6ZYyO1TK?X&lqMak)&@cfMij+xsf#9Lob3zU-^E zOiOnRW@=bHm1%bBI;Mr16HN2IeZUm<<3Wt4SrE*%G>K{U<2$7!RuxlCJ+Bgsm**VFwD?gx)3O6|m`am3Gll-gG(W$RsjhB4HvSf-bY+^o zeI!%q`gEp|PuDWlJwME}@J=~X!}kuyF~98h+cAx4HIQlkz6_>1c_~vvK@n5UtIJG% z<(FKO8vTgz1E&Wu)n&&sH6(w)w6N!woNbOVE&ld*roICmPhh;rpMAK74PYAhrH-j@ z#UjovzhRmkcAlv^`VmuUP`#5FKc-t3u63fBN~g1!>ZX3mG{4>+rll({Gc`CrXX=~L z;1tG(K=GrO4@I$mO$KeLKyWSK)L%YR}6roNVKn5yS?V;X4HmuXqnaHfWviA;69vzTV* z&ta;rT*}n9`v#_l_jWRk+;NC$%&l|W?s$`Fahpn}>JZf#%s((n&2@MqroPebm`Vcz zn3e{FGtF-{f~l_7IHr-8vzP{MoWnFmx0Gpq`}Is=d|+C<^Z?UB`3zITwO^U)Cf#Qm zWBZb6{vwC7Se{51Po}#0-b~d}7pA`Bdoe9NHHfLyCXVxT9n-**?=y{Yna@-cwSsB> z+>K1jcJJbP<1o`g%kxYl8{J@9+|j^Pqr76O>*>hOw+e$jnU;0+W~y%8nQ4vlF(@~4 z3pLxD?6uz>aK3iCPDxH*2Mjy=etGRrP6Z^T#C7la;9S5kx%2wp-+36|@Wb^Ui6Msq zoYxKz#k7h-*T8@Cm*#a z*3JE*IAGvWn2Bkpmg}URyf2M#leg`xrEB%!uK_7vbpB@dFtt43ck8|-{aoZNd)KVG z98yni{ri(0Uyf-g|MlXDf7$lO0XYWUk->K#1blP6o1I;{rTpc)E$=MUHI(n{o-k?E zuZ`pwYx^&MXlX0+a@3PYj2fqY+{Ie%7dN%SWn5jkTU_?3?XsPGZHe36Grq2Jhx~xAbISOlL6nhlG|=Rw70EA8@Z?UmuaQ-p9ZYzQfpXD zpqm`iV9Ju*Gmi568>hC^ZmBPC9KHH*M2@pOv(!4~kaK;x%CyhwzNzfuI61UD<7q%@^by;=C*G2m_lK(Q0c40`1XE*B0Kit~-!@c3P-&@I@-|LXNVUveE#5&z>XnH$&@K;k_bnyYV4X z^tG*g{l~nWO><=V@zS>*IJMDmG8d{aMzq9->w$iD|kIm$@g90vSuD>l0t(+S>J*u1R^!fSMFNXTd zmw)!2+0M~dF8j6Tl2Vt7fDOZcuM@9sE<69+(J8B43;A@F+Vhh9XTS$1`@P>++f;76 zB|9u@gq56-`t^CA_Kju7M_n&%In+gdkv$=9c71O-HthP*xPiY1@c!39&Y8HTO+=3_ z@{EAHW$VjZ%i9{)GaM;wEsq)Ti$3=)UwO&k@9w2(;LU$02BhciFa)%^5$n)smLhN4 zYjbFsXH~$aT|asyd&~02_D#YZ;=SdOZP)I1b9f!l+s^AwufcE2AEa1U`QGj>cTK)z z`1RA~@{GcTUw?3-vs_Z}mXy-RPi}Os-l`m>i#(_GBFD(^~!5sdHP|;`hHk^`G5XzHO^ndF(`YIr7~1J*^~v z`TDq+76%r!k$-LTZHr&0w3d&h&MX-)(OotqI{g+fppks@lgXLKW1a-`8JK-VEO$?mJ`THJB(Ovh1Yxo?c^>KMNEm*X4!G&?v%kvr?V zj3ox z;Xd@!U&hZ~JiL{h+p^v0h%2?_LvLHRu2^3Y;Mb#Vjv=_WJgU#*FIU`eE#HdiJ8OEs z7IM4EAvc0+w~|!@Tx>Nh!{rgDf2!9mtFIh7=JMo`kv-+cCnJ78zcF0idtqu^z_eDf z%ci|gM}Do5f0=kXUNfSD9NKczgWI!O$xH6OewYxh$WHH+Pu;Vxw_LQL|I4J$yUUx` zjh?lBTpRh!pH7nxo(Pf41_T}oFK#8TyqGzqUq+x@w_e#H%bpG7C84JdXb%UppC-FI?76EO<4du({l@uc!Ti zQ$h0T6@m7nPX@`l$QC6-JNJ@fns~o`@%=9H+1-J@d+RroEB~7O-d_s><-5bKc1=4P zArE`#_~plz;j-g~^{0NC)mPp#>~L+}PrkDK_vLkykM)$@n%?}_qiuj3Jae>5)nc@|DaPQ~Pb{FWcXVf90FhUv7W@(mw0!LGog+ zikWQ^edMX@uH;nMbdw*a@AvV08YutM^%zZABl!1PG1$CNO)q|})P1Jfew){d#e!Z{NAJE;itnkuu{rTd z`9rm5O7_-Q%Gh0o%^eoKQf@^qTkolVrRaZC9qTsim6G9kb@HNauavi#11(d*|5wVq z536qe^xI42c*Fdws^c$}D>HUajM@59nK%8drj?6dDt>K?27f#0rLsLeGyAKNFO`Pp zgW&&5#dE}qFWR-wS2Y^-)&e ztb3sZ&wKt(i`*BA*U<^^|Aq2lSnV@QqF*S6s)MS93i#)@>$1+2kZ+-Gy$?bGGAbHwz#p?dP zn>V!2l>rUPcg*PjTsdWZv2SRX=gOt*~{xPS0!)?!$eevUB{#yP_8GhY&;O&{uloZd>4XTu9O5b^jHbKLl zDW2^HuQwnR2O<`jZ9so+>_xFEG{qu$UpH?YKmx?J-x2u$M?!NO?=c<%$ui-@M zhbm>$gYizgzp7F`pR0OY{Arcaw{WxJw-2k7-HVI&w$xWC?jOd&|0>1RI_rQmpi22= z-}WiXdQ>U->t?F@wgx+MRf@HHOt#9pN(r2pk7O*%QTX>gOq0E>9HQ42O|r7EhG=F_raV zDjzFHyM&B?a{aLqTQZ}?hBJ?q`pNt2CGUT%1bBX7ANKWQB`tn^bUUbY1tH;UzBW|43O8{!84#2M?95R_(tm`|Y6;-uCLgkc$tM)NRe@6dix4Twl217y0{# z%7`DL@_*X)Q0c3hxMljsDG!w~F~j{%r94zV zJN@YBk1-FG;}ehGxHRaY^88YqwyO6-CF1^O-jz4ck}3Yp)<00z54Kki0Pa(|%Yo$*z9)PA7ESR86yqI#etwqNu8?8lW#zca7a^#7w$ zS(e?exOrKnk{{`#vcCY@c1FbWW0i_?mvCaTtzO4jqnGj=tqRBjIm z&7SO5saz@^>)6MkQmLy^!T(A{*J%GV%O@2|c+vD85ARhd`XZ(KUpFe0@B6kJ`{-hY z(s0JwE!L+il;LGwFPa>#P+I-jJFxF}70S&$m1C!VU7;*}&og%Smlet?=Q0n~stV=v zwI5{Bw=1r#iKUuSe^h0?5#-~2jCh2mWDHvF$pzAFB6Zf@HOrIYWwccPnC zC@n(2^ziirJ98CEwpz9Cxec)4mD=#ipsa2F&9grr8I-)wZ;yX;&!9NR%p78U%b+an zy|6%Y#h`Rs_4d%7XAMgC%X66?Y9|}FV%_m zGd38Mm|5F4Tv=&Q2HUB+DxVmX8`{ioHh*MLW~+m38_x#*y{Ogd_YBIBCw=T&WEhm^ zbtiwmbDTkWv9aQ8M4UnSFf%>>{&0h0>G$)KWdjY$;e>i8!om!S+A;|KL%2ROcOCIJ zD4wGl?Ofz*Q0}&x^diCApx9bk%m~yNlrB>Sc5dbl;h8fi+3=ugOIrh8#{ef3=B?Al zcJKwC5V+$A@5LGdcN&Scs~D2cUnn7@2l39(C^CKy70lPe<&gd@ zn>R)JTcH0rkEy45dCXJHrt;;HE*I*|>y?_8plzqk64SRZE5YAOn3+00HEmL=Mw=B6 zZ_a}E&r-s1u?d=3d`~dGtXh+-O&zOeOGn`C-}v@%eOj6(IW2Xpu^6ebx}?!#wffQU z24ekaZF+iI`e=AhkeL3IdZACZZvDlZ-;Lp8Qxo9T^V-;SifL9377tzu4R06LLqB0} z#*T}P7t6NbeL|3LQpRXw`A6%tsR>X-DjBoK!`qkj+R?o1qcinm{CPa`XQh2Z_;l?U zZMrr!9vh9y&jf?Abm6tmX_I(FvJXa|pp3q;6JrOlH#9>JuhFjQ+ObI)@LqLz_k}(! zJ}o&E>YohnCo81=5lEU(YVKb~{>^D#dI%hC;qcC=D3}{hl{6CiYuGxaG?+ohH{akJ zbnyLLX|UD+=bLejmR1@GM>Nid<6CiXRnJHkQ-b3g)6>8mbhx&{GzDJIo)8+>CgIz^ z^l;Z5rjLCl17^x`jaxFLlm_|Z`mmAAitn_-cZ-P?#5^6-8Rl8};cWRk&QmUcZOLhs zv}89wu!PMK{9R#dR;rSk?Wt+24gQHR!RZe+e=}Phu>HSrJY^ok+ulMdIH8iVVf!bC zmSPiosmW)IgJ}qdVB*e)FdzM)k)9^T-Tx4Ru2%rD43=kI66fI#|4$Q~YnNlgl@jeAUxc!4eOQ4B8 z(&RHn!8C+3&6lMs44|etWMlmyoh-AoOoFqz6q(pd;q#l?AJYte}fH)dB z2CB@$n1;vp_lGdTMZ@QRDg%bWG(}68mILz<&K*Bw!#^_@HK^yHiVN?}eCP7y&>cs@ zTvsfpzY$}FbQ?J&Lz|v4GC4ML(&Ujn)8aEzw5j@xk*V-f`1thLG5V2%^zc5&jJP!Y zNc;jCosyQ2nXJtiDMmq`jQB)tigsjNW>Rv(NID0ow(4k*^hxBSWIJ6#9F?sE6gPB- zVe1nzI2^vyq?jfushwV%rEiwPzRF@c!gFWAF8rFo8|U)DuM8T4`@xFPK-kyF@ES{f zY%{hL9=`YCJrm&P>l;4?zD)9gZIMHw1~-ci34)JOK~2AR(66wDUlWxL!!MG>EdxJXEyCkQMq^w<&2Z5eu&SmXOHT?hE%RWOo^4G(77ixV;Q6SK z2fVmb9}8Uo#+?_~9*mo@C5~|3!Rx^NCZ;9pQ*cDbu^OLgNnxif9mjw;cE{m7ZAD*l}RVBC?>_kc0@taE0fVNA( z9oeiS`ke>AX4QV3(60*oimLtm(68_|#Kk)ExSi3jv|J?>gOXnt^vk=el9r>NmY2i( zcj_m+@31^0!OtDTa6gu3BKVo~F_vf9J(aY_${3F2$yV#wW1ehRz{`#;q*6=^8FmGZ zXPRnei_;9?SIqoay;=V)bbxSmAzmE4qZBG<>jJE!gaa+47Z7K3RL>yRGa@ad7)&EQ zBR#&EFT1@i2K=(IjkzDI8wB}}PGzZ*EQ4V@wYHF~qbz)xb_7NLI7#woY%RH{+$0-= zRaq^aMWn91O3H&28{0zp5?rMixG^sh%3TKgoB8>9G2R7!Rpm{KU;3LroZg#+^JwcJy_Mi2z2(*-E}mBqHgPx^^8||L|?> z0{!Koy;LW`PO=(oE9Etnq}{Mt{>1x2O}3UK2rEHY$tHV03&{rhvkD%>>zrOY#xc@?_dC6fRMrC8wI$RW z)5N}b%bKw__#L8r&|b~Z7UuDwUzn!j(auh4m~d3p(C>(uHE8sJ1&1v}II z06(8`cC(e-pv-OwHj&UTS@BV1LHJ&7ouAVpVyc$9k-Fr_Lh>p zpRHscWv#=w(Bq^l5bhalyC`lce6HIL`UP6I+9nqy8&ukTDKU}!F>ap$-d!fIYC-=B&Wp=I=k8`2_DXGEa#;_xIY-Sj!;fi zl}# zM@P3Z-k#Xkp-uguze8X5XoKzV40VKk0R7Fh{V^YZtS8%lw$SF#zp!tqtzqo1BdPsr zOX|grWxVVTPdJ(nm)1B_@o zn;7dzRYOOqq22+;2Yaa@v|B@Hw}u@(4E4+0idmV(@#AhUxhFVE?y&FOVc)w)xf<%0 zLA@MQk^>%3%ntsLhC8I;-jUniRIYd72DY)ViE^=HE4aGP?#Ys*1F&H$Fs)}V)r0*} z5Bhk$bmKQs4C|}*(54-&eN}cAlHFp9NT%r)k#EZP?hHwK3Y*CHO<|JY*qIL7e+u(8 z*suRfm{wr#ViHDWqk`iO_LD1&3GiJb`n1?ryK*GyFW6k5U$A}eisMKf=tH$3tfS<* z7}}ckV`u2cYUsyK(2wg#9^0WGGk;(R?*ZXGAiT$7Hv>Oj>p@?3gTCx4d7Z63UU?h{ z3;Waq_NfQ#Q;&3UOw^IwARRYI$8E85nR!253OC|zfz3yh)eFW0eSJ7?O!89ImE6i; zAF{GR`p~~Tpl^6U-|&cne7s=%z%p%jGq{vFmpT>K);Y#FMDjAjxCi-rLH=G*)n)eZ zb&wkQO^_O?#z<-dj2NZ%#k?2uF+fub&WGCANS^wklBeGg7%QSAalVpm0cBxr3T+AX zb%px6ro))h6pzum__;=k#$z3iyL1a*XR~8o>^HY>;M4)O-l8o$U~IwmPp_+Uj!{Rl z@+3Tj@;rd@7>wo7*}VCfo$-|#=4ed?FVJTF&oDbJ&YsH zwvw}-GoDMpGE2K+8=W=#euOGZLk>WnItb_NRK5@3^GXwb(=qUEu_T>x}CI{l0ce_`6#K2m}1a~ z;0{>bpolY*`AX&^5pc~aYP!N2u!|9@hRVWhx4KzDoRuz{eXP2__ntFtQqo6#cHLce zz0dRS@0~N}o_o%FKJJ-&&Q0|_x8T>zGfI5}4He>_T_p1`x2@z1#+Wl1W8lhS--4xQ zU9pIH_rkjK)qLvl{8eW^Iwx<>oiRFdxNvXa7NKnO=cxJB^N2H7&0l$bp8qpv^sM2z z=AQDa>F+7jk?oIWGrwM^&dKB3;n@MZ?@aF*?!w%+LOGvTs_J``EvM&}lRuw250aj} z;U~=F(02>vvc`jxa|J#Bn!`Pb`x1TSf=%b<3qJYwtIU~xda~awSTswWWxH3Mk()VM zM14t{b<8Aht~tte>>lN8`zT}f$CRVGTiI8CTn)aa)ZCwO&oFtN{Mj~lmYQ2PL(Qda z&82NEIG_1WM5pNy|5@$-T-u>So%0-iTYA<_Q~bX9&3>XyMBF`3rLAkDfbxjx~oA-`&X=nn5$KFk__D>FW7v{-aa-?t;r?e&SLW z+MLsl6M52FuynRsSRE`{xcZYt3vKrn>DFq>%kR1cD;R64KU1`5_5PwowoewFyzA&V zK8dr4|0k02A zOs~%SD7mxd$>%ZOolBk9&r)YHPE0oz+~c&Vr%<7eq+r%OuLv%*tA%a&k@?d?=0Xcs z7JFw~?PNCXg!vJ3qe4EvQfgBNkmOUS{ege#^jt{Kwe@dXYd*ys*Fhh5teh9HEt;nm zaerCF{bkYW3)G^M_c8D6N%Qr>wSKvbI-nkWTuW%p&8ZYC-#iDi=wInfaYfAC_X}Y|~ zS8{l#$nT&HuIc&qtMbLvsZPk`&5dPshPguBqGzA40&XUB3(F8APj3g7BFkY|YU z%t@X_$@4XNcJ{j*^88JX&zSQ@%;zJ9Zy28UPdeVEhF2MGGHf#JGK?5LVR*>!HAB0( z-o=J)!)n9Z4DT`=G%S?u#YK}>7To%XbAq(7dL zcI)2VJDT~8QF1ajdukior!JhT@hRuD?G5+~S9)Q}H#~#)w=~s~-jAk)PhN$+T3@LZ zUo_S3_SbC>wBVzbw!P|AeGdP1ctexF5ZvHzRcft1$E>}+q2r0?PP>vk?__z}n{k=0!^$PY3o^{KpaAK8*TD2CtPpsp}Vvw>rNFk0{8rr^Rg|b$Pr1R+2 zB5PNHeB8rQ6B`sH3jbf9bqx%TbwB0Vy@%(jlft?PlXacb9d+_O$0oxT!$SP-pX=}K zCj1!B>g8BwJ{KFxGkiH7G@s*!!-j_p^M+@?rsH31c$Hy|VUuB(;Uk8R8;%$rHhj(S zxS```CVj(q8(w30vtf(jy@nCPXAHk@c+~LchQ|%(FNj+*R~mf7^A|GN|7AQLb2bBCMjlg}o+i-j?Q_ewJ)DpV7!b z$-bMdO7+jUcGb!gr)_9x^k2_lxxQnodSk|Q?Tu{>YxlPKtDCnr)cGswYg^Q{>o;A$ zzG~IVWp#~=zI8>L{I^zEJ7BK$@0GJ|u|i}lBS6LF(`J7g_7)lKx2p1WTgtr~3+I1t z=BBpBirPS1dyBuKxk=Vm)r%5V)!cl0dtigP<*jdOYvE5p{G)ucrJ<#*y|(eDraKy% z7-@%R-PEM-fpsUg!%zxt5B%Po#idXC^&_*Y{Vls2*!$xzI7Zz!V`HoN(A=_tjXmVc z+v0D(MzmY^Bjw ziz5OX*$1^%?URtnHBZeR5pQWXt?y7T$tUm5>Sno~q)fi+XKt!(Xr;1u7Pb+!k_SrE z$o4sZ-3GSL)mu4Hw@La{?7lL4l*+}klRlT(s3Lz$MGFPkS=+eTZ)Pe_&ZzR&?(x4V zyx6wRnqHjx#qE=PaLRY(O?8_C4NaEM)!?k^#@6yi@~PCLVv{|qfvLyj6PeSWz9^qI zwD|q%ahss3VMj|XO=(EVBNbgTm9;*HqtAv;MZGNQodpRbz(mwp%q?fDC%X) zZr)AvrL0Zyn1)Ug9C1j!KCBz8W78XO*-pDWJExL7EgzSKT6Ell*qG<!fr{kXE~ z!Bo_Q`;J&^dFA@4iEg@ z`<>72I`r#buZ+CB^dbJ}ZDH;ycYB$0E_a$-OlTIqH=$OXf-RhfWZzC9o})qUpVhO6 zsm~7zVRGJYI!0{M?-wqd_dor8As+?0?bGKsc)Rw8W4C7L=IQqr7t%Q$eP;i3u1H^} z;&c%Sw>kOe_iz+Br`G3x)g>fdX?y>>551Frx_@=Pou@ticbDt8&0Xz|o&2`HwZ7rD z+Z%T`H3vSxjk$f#9UXf=s8c9kTd{8ahWA!(yyn`f>#o1Sd*i0f)i-U~TJt`=SMImH z%v&zrbS*-M>7tyrSvcQvMg46u{1$H}@|MozVn%1M=k@NrcVA=z<1cF?9MjzQh1_wm zJa=_kOcMV<@8Mpj{`yV-?)#Mv@)&;Uw~SwI;{O%#zY{qc`D68?$av(I)2Dw|*gE6J zSxVh__|FbI)%L@;9e(pe?tRaXy_EZRrB>Xfb9P>nzCZnn8@ePuV(x3cx9R)Nf0iFM z$3c^Bok{n1m=sifZInEZWvPvH~wSuu6~vFz&dExe1g zy;gomdRp7+JRU3Zbn#BS1N0l>S?S5UP1||5X}f;6sc_14>GBR-!%qE>yAW;KeCm{@ zMw~7^>zTQ{97S2Kx=g=^m3W8dH_hko82-@kpA26&{I%g+bKZQzOAMDAzQ^#rhMNty z8{Teshv7#I|HANdhL0JZtf}9VW63)I|qM>#;~327yeTu zwg=vbtaD*uAMxbScz_M@n^B1r$fN`ViWF!KVCq23D3h>3)%aJ zJ$YZR>;wK1dvS}uXS4WK?8~u*2hcif;kQiq^8VdV5LR~ydrSxyeh}rbg`FsmE&Qkn7v5*WC-2>rJ-tsYR?5M?SmC$P z<=Da>pf%W&_uZbmM5$}oUt3SO(2KgTh1<}6Y#;nG8kBRP?6tM_;!fIgD|>HuqcP$L zKaO6-7CwZIV++H`@dMf+q|YiR_BHST@?ekhTlFN?RgM z6uP)U1hIwhlYOt)+u%c}c+93AhNB|R6-M0ngzzZ*GLkfhVD$>6785Q!fL3Ea39sOG z>cN(^>^qU9BkRax#+J3~%U0=d54;;y5x)yYk<_*DNn?+}uGKuxA@eZ_Dq~=7(`M=;Xz{y{|!m{6Y!z;PDBaEY&X0KN&Ff(fsPX{yx60|7sDzf{uKI*Eo?D%8@%7xK^QW& z@T_viv=_J*^q?|qFU+lF9Kg;)dj;(i+X2r-RoG5=5%OYhgMW@B4|l?+k>vRx{E-PC zhlzE%eJ0`0ki^f!^VVy-7;Z3jCHydwbb>I1YPi-QTvA2dVY}d->*&ka9q?;N;t#_! zuGh95UTD4cbJ&W{uNP&erW;Ac?~I|Tn0^>9N(%16voj2;L?ZxnRBtB_`S8bsU5Z?oTjHI29!w0r% z`w+aNhW2xqvcn7Cr)}YbC`$MczfftX2!7+*No1@A!;ryHK#%6Lk+1Kx?GEW*3nXk&zT!KY9S_6R(Jq>hflUm2U1npGK+ za1Z=*^f2-7gb(gv?8DvAC~Ub>AT=vNb=ALmvqwSiQ|D^Llf9*_9=BQ5}(`$(@5eA4;ouI z_ipO_Mal&?qE758_y8)y-Va|#+pv$p10SItv7dxT(Q&RNe4&f6i0~I-#Xb7E>)<`e zsxP?hqq>a=XM9YD&lDo*kHXpAI-m34GGn`8Es}KV;HQn<1JC$4W#hWVa4m{ruY>!L zaKWd!&thK) zYd=F7vFqRm|5CTlJKD}F>-==X_Rr&U(&>O*kLWnU zZy+Dx!%%%e`%_qnEI+`{8G8sGGq$iHq~mnLH^Q`M(wTsF_v-w2!TV#3Z-fWo`~+V<+%Ixn!i(W^j}nf3 zNcb3i6I=Ky68{M8k84|a;IHr}ah`W$HlSs}LUif!955mRIQeVUoe(^iR!F~dsIjY-_ z9hM`RYpsJ{`7Y<=hy&+8ugBrZd$VQFw)z42BaUz*>c*~u!GFew*uwcg(RnC=mm?{= z@b6I%adOc4iuRB2!${(E!X>Y2pSWNLdV=^u=TB)j*a3LiYkIzSISeB?ck;e$*{{9) z=lqWN2b;y~uvcSy;U%wYA1;P}gQ^K1g+2eqeFZxNS5N3UiE!gDC@(< zP+U;gbQCmBb@sx{LUQOCiY_9C;In!_=z~j;r6pA6M6H&PGbuX8e4eb**Z=RexjJU z4Cm%9u&L7dv{~#lTwlUiLRq}0&A64EP z?dG?zP~IsOTPW{^iY=6PHRlmuDDOjdVGHGbyUSnDly_bvzEIw+6I&?nWr;16_nyQS z%6mUz3*{Xfv4!$JjMzeX=S6Ixyw4)GP~HI%TPXYM#TLr@4Pp!BT>!C#vUgr=;dW!o z9`{aTGot;!JU+RWcg4|{(Z|q!6h)7tF7yQIL8E9G1yKkMqE0l1CLb@Y=RUN7`5d|d zJ%a{N2szQ$&^>4mQs`62hsscnbK{jvxzGdXBd8tKqU+GR&=U0hjjVZ~1L!dnLl2-2 zp$2plT6wKf??7)u=O7z;{ThB(qaUEB(I1XeJ;3-!5bB)z4P!b1?rFmL(*cSqQS!Gd zKE&{I>aphPj@^w;vz7SD(iO|xrB43DSF`-duq#V%s@|})tkl`s#@?%1{=S+2%F@05 z*3zr5I&03F+SXS8?j4PLog~oIdSz*QOVhipKVMVZx^#EL&X(rZ=3Q+|cQ)^ScWvwL zWqVeXI@!V1u*=`twncAT)>k7br*lnPOM7dZY(+AuUHltTTXnH@9%r`tceb-vYOncB zNQ?gi?OerQ=WS`&!w#xj{jDdyoc#6r4o;P~6RP}s{EhrgH~zh{w6=9))1Kzr{Vk== z_J;DEvibDN(p|NUt^QKy@)PN-S$_JftXV!KPivN+C>*D+SzhoPA5N`|={|e7S5R*q zk*=lRt?v!=cJu~&dwN5?!@VQDqrGFjx!&>K zeD6fBiaMgss5|P3dZWH*AlexXMnloT=x}s2nv3S6D&~keWA2zI=8gGcfmmlO7z@P) zW5co0ST2^2skkHVjJxBWxHs;L2jZRaU_2Bbj1R|0{!gi1P+&ZIl(NqUpMWFXm@3?@U#!Q^mqG?`20ld8|r=j?O$dHTG4 zzP>&y44en-Ev-`(%&_xAhx1O1)-!TwPHVE=IcXn(Fh->*_Q z&ddE5jD$zSV_|)*8m?B)^*Xp>ce00TCb{Ym*B#-?XPZo2p6qQuV1osw35z>P`hyJ*iMCnHo$DrG`@@ zsnOI}Dwi5hCyC9I+q?#=hG8um9b|WnUah%6Y}n`pfz&`)m5^`#bu(`+M-u5WX41FBAQCJmSI|m3X2aFLdL9B&8prEcKa=On0UylgtcdMlxfW@ytZVo-N6`vSr!I zY)!U4+mY?g_GFXUq3lR@EIXc^$l3==23!MW1C;|c1N8$P1Kk5X1IdA*fsui+f$@O} zeq+n(VKM#29x4gBLS>=KP)(>l)Dh|q^@Nh4q0mTZEHoaP2-(9Wc(4rb)!?}fyw(#= zhKIrR!WuyiVcF+fV@Z1nRaEu-}5wZ7{^t$MSmAy6e!H(W;dSJ45 zh#ojb@0;kgM@yovXj!x}S`)30c0{|QJ<()zC^`}yi;hPpqV`xx%oQt(RmN&!^|6jv zcdRFtj19#`Vq>xK*hI`8FNwS2W%0^*O}swd5$}%o#FO!%_(*&#J|3Tl+Y==TSE4LY znW#zBCpr?{iJn9uNN%mBSI zNRJ$(H;&R1r5`%zgKqktm%bOE-v#M&gY>si`dXfT=Ae(c>0jQAFB8agW`dbeW-v3H z8O`J}`Hadsvd*kK>&bevzHA`dnGI$`*}?2^b~KyI=Cf+RG2k3<4|oQ=1HOU4K<7Yk zAT%&IFg!3ikQ>NLdkit(2P)(UIYaJ{C*%$JLV-|cC>RQb21CQ4(NHdw52>&t?4(C~ z=*>QQawokw6dnu@Gp^;rd3v)W;*7W>o`{z|9pJ7IjD#YjJIs9obTGE|B%OU_jHZ>0 zr}cf4$1uqNf5VD@ee{A6dVrnQUt>m$A+F+NoGxReu4Jq}IevCqsfJFBpNi4J%Q&25 Rto&U@NxA+Xj^D)t{{b1GWUBxG literal 0 HcmV?d00001 diff --git a/Bot/node_modules/@discordjs/builders/LICENSE b/Bot/node_modules/@discordjs/builders/LICENSE new file mode 100644 index 0000000..cbe9c65 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/builders/README.md b/Bot/node_modules/@discordjs/builders/README.md new file mode 100644 index 0000000..dc88b7f --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/builders/dist/index.d.mts b/Bot/node_modules/@discordjs/builders/dist/index.d.mts new file mode 100644 index 0000000..d129ca5 --- /dev/null +++ b/Bot/node_modules/@discordjs/builders/dist/index.d.mts @@ -0,0 +1,1971 @@ +import * as _sapphire_shapeshift from '@sapphire/shapeshift'; +import { APIEmbedField, APIEmbedAuthor, APIEmbedFooter, APIEmbedImage, APIEmbed, APISelectMenuOption, APIMessageComponentEmoji, ButtonStyle, ChannelType, APIActionRowComponent, APIActionRowComponentTypes, APIBaseComponent, ComponentType, APIButtonComponent, APISelectMenuComponent, APIChannelSelectComponent, Snowflake, APIMentionableSelectComponent, APISelectMenuDefaultValue, SelectMenuDefaultValueType, APIRoleSelectComponent, APIStringSelectComponent, APIUserSelectComponent, APITextInputComponent, TextInputStyle, APIMessageActionRowComponent, APIModalActionRowComponent, APIModalComponent, APIMessageComponent, APIModalInteractionResponseCallbackData, LocalizationMap, LocaleString, Permissions, 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, 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 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 to 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 to 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 to 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 to 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 select menu option from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool select menu', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a select menu option 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 an {@link ButtonBuilder}. + */ + [ComponentType.Button]: ButtonBuilder; + /** + * The string select component type is associated with an {@link StringSelectMenuBuilder}. + */ + [ComponentType.StringSelect]: StringSelectMenuBuilder; + /** + * The text inpiut component type is associated with an {@link TextInputBuilder}. + */ + [ComponentType.TextInput]: TextInputBuilder; + /** + * The user select component type is associated with an {@link UserSelectMenuBuilder}. + */ + [ComponentType.UserSelect]: UserSelectMenuBuilder; + /** + * The role select component type is associated with an {@link RoleSelectMenuBuilder}. + */ + [ComponentType.RoleSelect]: RoleSelectMenuBuilder; + /** + * The mentionable select component type is associated with an {@link MentionableSelectMenuBuilder}. + */ + [ComponentType.MentionableSelect]: MentionableSelectMenuBuilder; + /** + * The channel select component type is associated with an {@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[]; + /** + * 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} + */ + 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[]; + /** + * 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. + */ + readonly dm_permission: boolean | undefined; + /** + * 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 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, 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; + /** + * 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. + */ + readonly dm_permission: boolean | undefined; + /** + * 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} + */ + 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 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_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/Bot/node_modules/@discordjs/builders/dist/index.d.ts b/Bot/node_modules/@discordjs/builders/dist/index.d.ts new file mode 100644 index 0000000..d129ca5 --- /dev/null +++ b/Bot/node_modules/@discordjs/builders/dist/index.d.ts @@ -0,0 +1,1971 @@ +import * as _sapphire_shapeshift from '@sapphire/shapeshift'; +import { APIEmbedField, APIEmbedAuthor, APIEmbedFooter, APIEmbedImage, APIEmbed, APISelectMenuOption, APIMessageComponentEmoji, ButtonStyle, ChannelType, APIActionRowComponent, APIActionRowComponentTypes, APIBaseComponent, ComponentType, APIButtonComponent, APISelectMenuComponent, APIChannelSelectComponent, Snowflake, APIMentionableSelectComponent, APISelectMenuDefaultValue, SelectMenuDefaultValueType, APIRoleSelectComponent, APIStringSelectComponent, APIUserSelectComponent, APITextInputComponent, TextInputStyle, APIMessageActionRowComponent, APIModalActionRowComponent, APIModalComponent, APIMessageComponent, APIModalInteractionResponseCallbackData, LocalizationMap, LocaleString, Permissions, 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, 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 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 to 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 to 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 to 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 to 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 select menu option from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool select menu', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a select menu option 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 an {@link ButtonBuilder}. + */ + [ComponentType.Button]: ButtonBuilder; + /** + * The string select component type is associated with an {@link StringSelectMenuBuilder}. + */ + [ComponentType.StringSelect]: StringSelectMenuBuilder; + /** + * The text inpiut component type is associated with an {@link TextInputBuilder}. + */ + [ComponentType.TextInput]: TextInputBuilder; + /** + * The user select component type is associated with an {@link UserSelectMenuBuilder}. + */ + [ComponentType.UserSelect]: UserSelectMenuBuilder; + /** + * The role select component type is associated with an {@link RoleSelectMenuBuilder}. + */ + [ComponentType.RoleSelect]: RoleSelectMenuBuilder; + /** + * The mentionable select component type is associated with an {@link MentionableSelectMenuBuilder}. + */ + [ComponentType.MentionableSelect]: MentionableSelectMenuBuilder; + /** + * The channel select component type is associated with an {@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[]; + /** + * 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} + */ + 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[]; + /** + * 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. + */ + readonly dm_permission: boolean | undefined; + /** + * 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 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, 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; + /** + * 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. + */ + readonly dm_permission: boolean | undefined; + /** + * 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} + */ + 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 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_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/Bot/node_modules/@discordjs/builders/dist/index.js b/Bot/node_modules/@discordjs/builders/dist/index.js new file mode 100644 index 0000000..cbb7eb6 --- /dev/null +++ b/Bot/node_modules/@discordjs/builders/dist/index.js @@ -0,0 +1,2811 @@ +"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.lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled); +var fieldValuePredicate = import_shapeshift.s.string.lengthGreaterThanOrEqual(1).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.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.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, url) { + if (url && customId) { + throw new RangeError("URL and custom id are mutually exclusive"); + } + if (!label && !emoji) { + throw new RangeError("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-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 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.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 to 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 to 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 to 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 to 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 select menu option from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool select menu', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a select menu option 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, + 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"); + +// 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 SharedSlashCommand = class { + static { + __name(this, "SharedSlashCommand"); + } + name = void 0; + name_localizations; + description = void 0; + description_localizations; + options = []; + /** + * 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} + */ + 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, + options: this.options.map((option) => option.toJSON()) + }; + } +}; + +// src/interactions/slashCommands/options/attachment.ts +var import_v1013 = 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_v1013.ApplicationCommandOptionType.Attachment; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/boolean.ts +var import_v1014 = require("discord-api-types/v10"); +var SlashCommandBooleanOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandBooleanOption"); + } + /** + * The type of this option. + */ + type = import_v1014.ApplicationCommandOptionType.Boolean; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/channel.ts +var import_v1016 = 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_v1015 = require("discord-api-types/v10"); +var allowedChannelTypes = [ + import_v1015.ChannelType.GuildText, + import_v1015.ChannelType.GuildVoice, + import_v1015.ChannelType.GuildCategory, + import_v1015.ChannelType.GuildAnnouncement, + import_v1015.ChannelType.AnnouncementThread, + import_v1015.ChannelType.PublicThread, + import_v1015.ChannelType.PrivateThread, + import_v1015.ChannelType.GuildStageVoice, + import_v1015.ChannelType.GuildForum, + import_v1015.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_v1016.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_v1018 = 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_v1017 = 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_v1017.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_v1018.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_v1019 = require("discord-api-types/v10"); +var SlashCommandMentionableOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandMentionableOption"); + } + /** + * The type of this option. + */ + type = import_v1019.ApplicationCommandOptionType.Mentionable; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/number.ts +var import_shapeshift10 = require("@sapphire/shapeshift"); +var import_v1020 = 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_v1020.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_v1021 = require("discord-api-types/v10"); +var SlashCommandRoleOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandRoleOption"); + } + /** + * The type of this option. + */ + type = import_v1021.ApplicationCommandOptionType.Role; + /** + * {@inheritDoc ApplicationCommandOptionBase.toJSON} + */ + toJSON() { + this.runRequiredValidations(); + return { ...this }; + } +}; + +// src/interactions/slashCommands/options/string.ts +var import_shapeshift11 = require("@sapphire/shapeshift"); +var import_v1022 = 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_v1022.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_v1023 = require("discord-api-types/v10"); +var SlashCommandUserOption = class extends ApplicationCommandOptionBase { + static { + __name(this, "SlashCommandUserOption"); + } + /** + * The type of this option. + */ + type = import_v1023.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_v1024 = 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_v1024.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_v1024.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 = []; + /** + * 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. + */ + dm_permission = void 0; + /** + * 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, { + validateDMPermission: () => validateDMPermission2, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions2, + validateDefaultPermission: () => validateDefaultPermission2, + validateName: () => validateName2, + validateRequiredParameters: () => validateRequiredParameters4, + validateType: () => validateType +}); +var import_shapeshift12 = require("@sapphire/shapeshift"); +var import_v1025 = 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_v1025.ApplicationCommandType.User), import_shapeshift12.s.literal(import_v1025.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"); + +// 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; + /** + * 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. + */ + dm_permission = void 0; + /** + * 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} + */ + 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.8.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/Bot/node_modules/@discordjs/builders/dist/index.js.map b/Bot/node_modules/@discordjs/builders/dist/index.js.map new file mode 100644 index 0000000..cc20ff3 --- /dev/null +++ b/Bot/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.8.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\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(256)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const fieldValuePredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(1_024)\n\t.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.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const imageURLPredicate = s.string\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'attachment:'],\n\t})\n\t.nullish.setValidationEnabled(isValidationEnabled);\n\nexport const urlPredicate = s.string\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:'],\n\t})\n\t.nullish.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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(255)\n\t.setValidationEnabled(isValidationEnabled);\nexport const colorPredicate = s.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(0xffffff)\n\t.or(s.tuple([RGBPredicate, RGBPredicate, RGBPredicate]))\n\t.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const descriptionPredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(4_096)\n\t.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const footerTextPredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(2_048)\n\t.nullable.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.nullable.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.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.strict.setValidationEnabled(isValidationEnabled);\n\nexport const disabledValidator = s.boolean;\n\nexport const buttonLabelValidator = s.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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const labelValueDescriptionValidator = s.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.array\n\t.lengthGreaterThanOrEqual(0)\n\t.setValidationEnabled(isValidationEnabled);\nexport const optionsLengthValidator = s.number.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.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\turl?: string,\n) {\n\tif (url && customId) {\n\t\tthrow new RangeError('URL and custom id are mutually exclusive');\n\t}\n\n\tif (!label && !emoji) {\n\t\tthrow new RangeError('Buttons must have a label and/or an emoji');\n\t}\n\n\tif (style === ButtonStyle.Link) {\n\t\tif (!url) {\n\t\t\tthrow new RangeError('Link buttons must have a url');\n\t\t}\n\t} else if (url) {\n\t\tthrow new RangeError('Non-link buttons cannot have a url');\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 an {@link ButtonBuilder}.\n\t */\n\t[ComponentType.Button]: ButtonBuilder;\n\t/**\n\t * The string select component type is associated with an {@link StringSelectMenuBuilder}.\n\t */\n\t[ComponentType.StringSelect]: StringSelectMenuBuilder;\n\t/**\n\t * The text inpiut component type is associated with an {@link TextInputBuilder}.\n\t */\n\t[ComponentType.TextInput]: TextInputBuilder;\n\t/**\n\t * The user select component type is associated with an {@link UserSelectMenuBuilder}.\n\t */\n\t[ComponentType.UserSelect]: UserSelectMenuBuilder;\n\t/**\n\t * The role select component type is associated with an {@link RoleSelectMenuBuilder}.\n\t */\n\t[ComponentType.RoleSelect]: RoleSelectMenuBuilder;\n\t/**\n\t * The mentionable select component type is associated with an {@link MentionableSelectMenuBuilder}.\n\t */\n\t[ComponentType.MentionableSelect]: MentionableSelectMenuBuilder;\n\t/**\n\t * The channel select component type is associated with an {@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 APIMessageComponentEmoji,\n\ttype APIButtonComponent,\n\ttype APIButtonComponentWithURL,\n\ttype APIButtonComponentWithCustomId,\n\ttype ButtonStyle,\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 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\tthis.data.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\tthis.data.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\tthis.data.label,\n\t\t\tthis.data.emoji,\n\t\t\t(this.data as APIButtonComponentWithCustomId).custom_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 to 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 to 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 to 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 to 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 select menu option from an API data object:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tlabel: 'Type something',\n\t * \tstyle: TextInputStyle.Short,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu option 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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const maxLengthValidator = s.number.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.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.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\nexport const componentsValidator = s\n\t.instance(ActionRowBuilder)\n\t.array.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 { Locale, type APIApplicationCommandOptionChoice, type LocalizationMap } 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.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.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.nullish.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.union(\n\ts.bigint.transform((value) => value.toString()),\n\ts.number.safeInt.transform((value) => value.toString()),\n\ts.string.regex(/^\\d+$/),\n).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","import type { APIApplicationCommandOption, LocalizationMap, Permissions } 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 * 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 */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\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 type {\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIChatInputApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport {\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\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 */\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\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.object({\n\tname: stringPredicate,\n\tname_localizations: localizationMapPredicate,\n\tvalue: s.union(stringPredicate, numberPredicate),\n}).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 } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ContextMenuCommandType } from './ContextMenuCommandBuilder.js';\n\nconst namePredicate = s.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.union(\n\ts.bigint.transform((value) => value.toString()),\n\ts.number.safeInt.transform((value) => value.toString()),\n\ts.string.regex(/^\\d+$/),\n).nullish;\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n","import type {\n\tApplicationCommandType,\n\tLocaleString,\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIContextMenuApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport { validateLocale, validateLocalizationMap } from '../slashCommands/Assertions.js';\nimport {\n\tvalidateRequiredParameters,\n\tvalidateName,\n\tvalidateType,\n\tvalidateDefaultPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDMPermission,\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 * 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 */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\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 */\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","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","validateDMPermission","validateDefaultMemberPermissions","validateDefaultPermission","validateName","validateRequiredParameters","import_shapeshift","import_v10","namePredicate","booleanPredicate","validateDefaultPermission","validateName","validateRequiredParameters","dmPermissionPredicate","validateDMPermission","memberPermissionPredicate","validateDefaultMemberPermissions","validateName","validateDefaultPermission","validateDefaultMemberPermissions","validateDMPermission","validateRequiredParameters"]} \ No newline at end of file diff --git a/Bot/node_modules/@discordjs/builders/dist/index.mjs b/Bot/node_modules/@discordjs/builders/dist/index.mjs new file mode 100644 index 0000000..e4d8e05 --- /dev/null +++ b/Bot/node_modules/@discordjs/builders/dist/index.mjs @@ -0,0 +1,2748 @@ +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.lengthGreaterThanOrEqual(1).lengthLessThanOrEqual(256).setValidationEnabled(isValidationEnabled); +var fieldValuePredicate = s.string.lengthGreaterThanOrEqual(1).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.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.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, url) { + if (url && customId) { + throw new RangeError("URL and custom id are mutually exclusive"); + } + if (!label && !emoji) { + throw new RangeError("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-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 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.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 to 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 to 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 to 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 to 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 select menu option from an API data object: + * ```ts + * const textInput = new TextInputBuilder({ + * custom_id: 'a cool select menu', + * label: 'Type something', + * style: TextInputStyle.Short, + * }); + * ``` + * @example + * Creating a select menu option 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, + 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 { 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"); + +// 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 +var SharedSlashCommand = class { + static { + __name(this, "SharedSlashCommand"); + } + name = void 0; + name_localizations; + description = void 0; + description_localizations; + options = []; + /** + * 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} + */ + 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, + 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 = []; + /** + * 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. + */ + dm_permission = void 0; + /** + * 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, { + validateDMPermission: () => validateDMPermission2, + validateDefaultMemberPermissions: () => validateDefaultMemberPermissions2, + validateDefaultPermission: () => validateDefaultPermission2, + validateName: () => validateName2, + validateRequiredParameters: () => validateRequiredParameters4, + validateType: () => validateType +}); +import { s as s12 } from "@sapphire/shapeshift"; +import { ApplicationCommandType } 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(ApplicationCommandType.User), s12.literal(ApplicationCommandType.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"); + +// 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; + /** + * 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. + */ + dm_permission = void 0; + /** + * 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} + */ + 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.8.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/Bot/node_modules/@discordjs/builders/dist/index.mjs.map b/Bot/node_modules/@discordjs/builders/dist/index.mjs.map new file mode 100644 index 0000000..6ca8b64 --- /dev/null +++ b/Bot/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\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(256)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const fieldValuePredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(1_024)\n\t.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.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const imageURLPredicate = s.string\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:', 'attachment:'],\n\t})\n\t.nullish.setValidationEnabled(isValidationEnabled);\n\nexport const urlPredicate = s.string\n\t.url({\n\t\tallowedProtocols: ['http:', 'https:'],\n\t})\n\t.nullish.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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(255)\n\t.setValidationEnabled(isValidationEnabled);\nexport const colorPredicate = s.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(0xffffff)\n\t.or(s.tuple([RGBPredicate, RGBPredicate, RGBPredicate]))\n\t.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const descriptionPredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(4_096)\n\t.nullable.setValidationEnabled(isValidationEnabled);\n\nexport const footerTextPredicate = s.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(2_048)\n\t.nullable.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.nullable.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.8.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.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.strict.setValidationEnabled(isValidationEnabled);\n\nexport const disabledValidator = s.boolean;\n\nexport const buttonLabelValidator = s.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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(25)\n\t.setValidationEnabled(isValidationEnabled);\n\nexport const labelValueDescriptionValidator = s.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.array\n\t.lengthGreaterThanOrEqual(0)\n\t.setValidationEnabled(isValidationEnabled);\nexport const optionsLengthValidator = s.number.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.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\turl?: string,\n) {\n\tif (url && customId) {\n\t\tthrow new RangeError('URL and custom id are mutually exclusive');\n\t}\n\n\tif (!label && !emoji) {\n\t\tthrow new RangeError('Buttons must have a label and/or an emoji');\n\t}\n\n\tif (style === ButtonStyle.Link) {\n\t\tif (!url) {\n\t\t\tthrow new RangeError('Link buttons must have a url');\n\t\t}\n\t} else if (url) {\n\t\tthrow new RangeError('Non-link buttons cannot have a url');\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 an {@link ButtonBuilder}.\n\t */\n\t[ComponentType.Button]: ButtonBuilder;\n\t/**\n\t * The string select component type is associated with an {@link StringSelectMenuBuilder}.\n\t */\n\t[ComponentType.StringSelect]: StringSelectMenuBuilder;\n\t/**\n\t * The text inpiut component type is associated with an {@link TextInputBuilder}.\n\t */\n\t[ComponentType.TextInput]: TextInputBuilder;\n\t/**\n\t * The user select component type is associated with an {@link UserSelectMenuBuilder}.\n\t */\n\t[ComponentType.UserSelect]: UserSelectMenuBuilder;\n\t/**\n\t * The role select component type is associated with an {@link RoleSelectMenuBuilder}.\n\t */\n\t[ComponentType.RoleSelect]: RoleSelectMenuBuilder;\n\t/**\n\t * The mentionable select component type is associated with an {@link MentionableSelectMenuBuilder}.\n\t */\n\t[ComponentType.MentionableSelect]: MentionableSelectMenuBuilder;\n\t/**\n\t * The channel select component type is associated with an {@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 APIMessageComponentEmoji,\n\ttype APIButtonComponent,\n\ttype APIButtonComponentWithURL,\n\ttype APIButtonComponentWithCustomId,\n\ttype ButtonStyle,\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 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\tthis.data.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\tthis.data.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\tthis.data.label,\n\t\t\tthis.data.emoji,\n\t\t\t(this.data as APIButtonComponentWithCustomId).custom_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 to 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 to 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 to 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 to 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 select menu option from an API data object:\n\t * ```ts\n\t * const textInput = new TextInputBuilder({\n\t * \tcustom_id: 'a cool select menu',\n\t * \tlabel: 'Type something',\n\t * \tstyle: TextInputStyle.Short,\n\t * });\n\t * ```\n\t * @example\n\t * Creating a select menu option 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.number.int\n\t.greaterThanOrEqual(0)\n\t.lessThanOrEqual(4_000)\n\t.setValidationEnabled(isValidationEnabled);\nexport const maxLengthValidator = s.number.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.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.string\n\t.lengthGreaterThanOrEqual(1)\n\t.lengthLessThanOrEqual(45)\n\t.setValidationEnabled(isValidationEnabled);\nexport const componentsValidator = s\n\t.instance(ActionRowBuilder)\n\t.array.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 { Locale, type APIApplicationCommandOptionChoice, type LocalizationMap } 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.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.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.nullish.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.union(\n\ts.bigint.transform((value) => value.toString()),\n\ts.number.safeInt.transform((value) => value.toString()),\n\ts.string.regex(/^\\d+$/),\n).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","import type { APIApplicationCommandOption, LocalizationMap, Permissions } 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 * 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 */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\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 type {\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIChatInputApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport {\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\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 */\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\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.object({\n\tname: stringPredicate,\n\tname_localizations: localizationMapPredicate,\n\tvalue: s.union(stringPredicate, numberPredicate),\n}).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 } from 'discord-api-types/v10';\nimport { isValidationEnabled } from '../../util/validation.js';\nimport type { ContextMenuCommandType } from './ContextMenuCommandBuilder.js';\n\nconst namePredicate = s.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.union(\n\ts.bigint.transform((value) => value.toString()),\n\ts.number.safeInt.transform((value) => value.toString()),\n\ts.string.regex(/^\\d+$/),\n).nullish;\n\nexport function validateDefaultMemberPermissions(permissions: unknown) {\n\treturn memberPermissionPredicate.parse(permissions);\n}\n","import type {\n\tApplicationCommandType,\n\tLocaleString,\n\tLocalizationMap,\n\tPermissions,\n\tRESTPostAPIContextMenuApplicationCommandsJSONBody,\n} from 'discord-api-types/v10';\nimport { validateLocale, validateLocalizationMap } from '../slashCommands/Assertions.js';\nimport {\n\tvalidateRequiredParameters,\n\tvalidateName,\n\tvalidateType,\n\tvalidateDefaultPermission,\n\tvalidateDefaultMemberPermissions,\n\tvalidateDMPermission,\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 * 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 */\n\tpublic readonly dm_permission: boolean | undefined = undefined;\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 */\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","validateDMPermission","validateDefaultMemberPermissions","validateDefaultPermission","validateName","validateRequiredParameters","s","namePredicate","s","booleanPredicate","validateDefaultPermission","validateName","validateRequiredParameters","dmPermissionPredicate","validateDMPermission","memberPermissionPredicate","validateDefaultMemberPermissions","validateName","validateDefaultPermission","validateDefaultMemberPermissions","validateDMPermission","validateRequiredParameters"]} \ No newline at end of file diff --git a/Bot/node_modules/@discordjs/builders/package.json b/Bot/node_modules/@discordjs/builders/package.json new file mode 100644 index 0000000..61f9cf8 --- /dev/null +++ b/Bot/node_modules/@discordjs/builders/package.json @@ -0,0 +1,99 @@ +{ + "$schema": "https://json.schemastore.org/package.json", + "name": "@discordjs/builders", + "version": "1.8.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": "^3.9.7", + "discord-api-types": "0.37.83", + "fast-deep-equal": "^3.1.3", + "ts-mixer": "^6.0.4", + "tslib": "^2.6.2", + "@discordjs/formatters": "^0.4.0", + "@discordjs/util": "^1.1.0" + }, + "devDependencies": { + "@favware/cliff-jumper": "^3.0.2", + "@types/node": "16.18.60", + "@vitest/coverage-v8": "^1.5.0", + "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.2.5", + "tsup": "^8.0.2", + "turbo": "^1.13.2", + "typescript": "^5.4.5", + "vitest": "^1.5.0", + "@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/Bot/node_modules/@discordjs/collection/CHANGELOG.md b/Bot/node_modules/@discordjs/collection/CHANGELOG.md new file mode 100644 index 0000000..2c43057 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/LICENSE b/Bot/node_modules/@discordjs/collection/LICENSE new file mode 100644 index 0000000..d21f37a --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/README.md b/Bot/node_modules/@discordjs/collection/README.md new file mode 100644 index 0000000..4ddde14 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/dist/index.d.mts b/Bot/node_modules/@discordjs/collection/dist/index.d.mts new file mode 100644 index 0000000..5990c61 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/dist/index.d.ts b/Bot/node_modules/@discordjs/collection/dist/index.d.ts new file mode 100644 index 0000000..5990c61 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/dist/index.js b/Bot/node_modules/@discordjs/collection/dist/index.js new file mode 100644 index 0000000..d9379ea --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/dist/index.js.map b/Bot/node_modules/@discordjs/collection/dist/index.js.map new file mode 100644 index 0000000..247240c --- /dev/null +++ b/Bot/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":"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","names":[]} \ No newline at end of file diff --git a/Bot/node_modules/@discordjs/collection/dist/index.mjs b/Bot/node_modules/@discordjs/collection/dist/index.mjs new file mode 100644 index 0000000..c31c9ee --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/dist/index.mjs.map b/Bot/node_modules/@discordjs/collection/dist/index.mjs.map new file mode 100644 index 0000000..fcf72ab --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/collection/package.json b/Bot/node_modules/@discordjs/collection/package.json new file mode 100644 index 0000000..81e2418 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/formatters/LICENSE b/Bot/node_modules/@discordjs/formatters/LICENSE new file mode 100644 index 0000000..e2baac1 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/formatters/README.md b/Bot/node_modules/@discordjs/formatters/README.md new file mode 100644 index 0000000..65ad4b0 --- /dev/null +++ b/Bot/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/Bot/node_modules/@discordjs/formatters/dist/index.d.mts b/Bot/node_modules/@discordjs/formatters/dist/index.d.mts new file mode 100644 index 0000000..6a97e7c --- /dev/null +++ b/Bot/node_modules/@discordjs/formatters/dist/index.d.mts @@ -0,0 +1,650 @@ +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 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