From 20011df1dccdb12abb0f534be6104b01eae673c8 Mon Sep 17 00:00:00 2001 From: GitHub Action Date: Sun, 3 Oct 2021 10:52:13 +0000 Subject: [PATCH] docs: Generate documentation. --- docs-release/assets/css/main.css | 2609 +++++++++++++++++ docs-release/assets/images/icons.png | Bin 0 -> 9615 bytes docs-release/assets/images/icons@2x.png | Bin 0 -> 28144 bytes docs-release/assets/images/widgets.png | Bin 0 -> 8629 bytes docs-release/assets/images/widgets@2x.png | Bin 0 -> 7809 bytes docs-release/assets/js/main.js | 248 ++ docs-release/assets/js/search.js | 1 + docs-release/classes/AdvancedClient.html | 2429 +++++++++++++++ docs-release/classes/Argument.html | 268 ++ docs-release/classes/ArgumentContext.html | 1400 +++++++++ docs-release/classes/ArgumentParser.html | 583 ++++ docs-release/classes/BetterEmbed.html | 1257 ++++++++ docs-release/classes/Command.html | 1218 ++++++++ docs-release/classes/CommandArgument.html | 449 +++ docs-release/classes/CommandContext.html | 1356 +++++++++ docs-release/classes/CommandError.html | 467 +++ docs-release/classes/CommandHandlerError.html | 415 +++ docs-release/classes/Event.html | 353 +++ docs-release/classes/EventContext.html | 331 +++ docs-release/classes/ImageCommand.html | 1276 ++++++++ docs-release/classes/Logger.html | 849 ++++++ docs-release/classes/SlowCommand.html | 1295 ++++++++ docs-release/classes/SubCommand.html | 1259 ++++++++ docs-release/classes/SubCommandContext.html | 1416 +++++++++ docs-release/enums/ArgumentType.html | 431 +++ docs-release/enums/CommandErrorType.html | 273 ++ docs-release/enums/DataType.html | 288 ++ docs-release/enums/LogLevel.html | 288 ++ docs-release/enums/Tag.html | 316 ++ docs-release/index.html | 415 +++ docs-release/interfaces/ArgumentOptions.html | 229 ++ .../interfaces/CommandContextBuilder.html | 259 ++ .../interfaces/CommandErrorBuilder.html | 233 ++ .../CommandHandler.CommandCooldown.html | 322 ++ ...ndHandler.CreateCommandHandlerOptions.html | 406 +++ .../CommandHandler.HelpOptions.html | 337 +++ ...ndHandler.LaunchCommandHandlerOptions.html | 441 +++ .../CommandHandler.MessageCreateOptions.html | 391 +++ .../interfaces/CommandSignatureOptions.html | 191 ++ docs-release/interfaces/Cooldown.html | 235 ++ .../interfaces/DeleteMessageOptions.html | 208 ++ .../interfaces/ImageEmbedContextOptions.html | 277 ++ .../interfaces/ImageEmbedOptions.html | 268 ++ .../interfaces/ImageLocalContextOptions.html | 235 ++ .../interfaces/ImageLocalOptions.html | 228 ++ .../interfaces/MissingPermissions.html | 208 ++ .../interfaces/SubCommandContextBuilder.html | 277 ++ .../interfaces/SubCommandOptions.html | 288 ++ docs-release/modules.html | 2436 +++++++++++++++ docs-release/modules/CommandHandler.html | 1248 ++++++++ docs-release/modules/Tag.html | 195 ++ 51 files changed, 30402 insertions(+) create mode 100644 docs-release/assets/css/main.css create mode 100644 docs-release/assets/images/icons.png create mode 100644 docs-release/assets/images/icons@2x.png create mode 100644 docs-release/assets/images/widgets.png create mode 100644 docs-release/assets/images/widgets@2x.png create mode 100644 docs-release/assets/js/main.js create mode 100644 docs-release/assets/js/search.js create mode 100644 docs-release/classes/AdvancedClient.html create mode 100644 docs-release/classes/Argument.html create mode 100644 docs-release/classes/ArgumentContext.html create mode 100644 docs-release/classes/ArgumentParser.html create mode 100644 docs-release/classes/BetterEmbed.html create mode 100644 docs-release/classes/Command.html create mode 100644 docs-release/classes/CommandArgument.html create mode 100644 docs-release/classes/CommandContext.html create mode 100644 docs-release/classes/CommandError.html create mode 100644 docs-release/classes/CommandHandlerError.html create mode 100644 docs-release/classes/Event.html create mode 100644 docs-release/classes/EventContext.html create mode 100644 docs-release/classes/ImageCommand.html create mode 100644 docs-release/classes/Logger.html create mode 100644 docs-release/classes/SlowCommand.html create mode 100644 docs-release/classes/SubCommand.html create mode 100644 docs-release/classes/SubCommandContext.html create mode 100644 docs-release/enums/ArgumentType.html create mode 100644 docs-release/enums/CommandErrorType.html create mode 100644 docs-release/enums/DataType.html create mode 100644 docs-release/enums/LogLevel.html create mode 100644 docs-release/enums/Tag.html create mode 100644 docs-release/index.html create mode 100644 docs-release/interfaces/ArgumentOptions.html create mode 100644 docs-release/interfaces/CommandContextBuilder.html create mode 100644 docs-release/interfaces/CommandErrorBuilder.html create mode 100644 docs-release/interfaces/CommandHandler.CommandCooldown.html create mode 100644 docs-release/interfaces/CommandHandler.CreateCommandHandlerOptions.html create mode 100644 docs-release/interfaces/CommandHandler.HelpOptions.html create mode 100644 docs-release/interfaces/CommandHandler.LaunchCommandHandlerOptions.html create mode 100644 docs-release/interfaces/CommandHandler.MessageCreateOptions.html create mode 100644 docs-release/interfaces/CommandSignatureOptions.html create mode 100644 docs-release/interfaces/Cooldown.html create mode 100644 docs-release/interfaces/DeleteMessageOptions.html create mode 100644 docs-release/interfaces/ImageEmbedContextOptions.html create mode 100644 docs-release/interfaces/ImageEmbedOptions.html create mode 100644 docs-release/interfaces/ImageLocalContextOptions.html create mode 100644 docs-release/interfaces/ImageLocalOptions.html create mode 100644 docs-release/interfaces/MissingPermissions.html create mode 100644 docs-release/interfaces/SubCommandContextBuilder.html create mode 100644 docs-release/interfaces/SubCommandOptions.html create mode 100644 docs-release/modules.html create mode 100644 docs-release/modules/CommandHandler.html create mode 100644 docs-release/modules/Tag.html diff --git a/docs-release/assets/css/main.css b/docs-release/assets/css/main.css new file mode 100644 index 0000000..f2cdee9 --- /dev/null +++ b/docs-release/assets/css/main.css @@ -0,0 +1,2609 @@ +:root { + --color-background: #1e1e1e; + --color-text: #ececec; + --color-text-aside: #585858; + --color-link: #4da6ff; + --color-menu-divider: #e6e6e6; + --color-menu-divider-focus: #fff; + --color-menu-label: #5f5f5f; + --color-panel: #171717; + --color-panel-divider: #414141; + --color-sources: #ababab; + --color-comment-tag: #282828; + --color-comment-tag-text: #e6e6e6; + --color-code-background: #151515; + --color-ts: #be60ff; + --color-ts-interface: #c9ff39; + --color-ts-enum: #ffbf00; + --color-ts-class: #4da6ff; + --color-ts-private: #808080; + --toolbar-color: #1e1e1e; + --toolbar-text-color: #d0d0d0; +} + +/*! normalize.css v1.1.3 | MIT License | git.io/normalize */ +/* ========================================================================== + * * HTML5 display definitions + * * ========================================================================== */ +/** + * * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */ +article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { + display: block; +} + +/** + * * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */ +audio, canvas, video { + display: inline-block; + *display: inline; + *zoom: 1; +} + +/** + * * Prevent modern browsers from displaying `audio` without controls. + * * Remove excess height in iOS 5 devices. */ +audio:not([controls]) { + display: none; + height: 0; +} + +/** + * * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4. + * * Known issue: no IE 6 support. */ +[hidden] { + display: none; +} + +/* ========================================================================== + * * Base + * * ========================================================================== */ +/** + * * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using + * * `em` units. + * * 2. Prevent iOS text size adjust after orientation change, without disabling + * * user zoom. */ +html { + font-size: 100%; + /* 1 */ + -ms-text-size-adjust: 100%; + /* 2 */ + -webkit-text-size-adjust: 100%; + /* 2 */ + font-family: sans-serif; +} + +/** + * * Address `font-family` inconsistency between `textarea` and other form + * * elements. */ +button, input, select, textarea { + font-family: sans-serif; +} + +/** + * * Address margins handled incorrectly in IE 6/7. */ +body { + margin: 0; +} + +/* ========================================================================== + * * Links + * * ========================================================================== */ +/** + * * Address `outline` inconsistency between Chrome and other browsers. */ +a:focus { + outline: thin dotted; +} +a:active, a:hover { + outline: 0; +} + +/** + * * Improve readability when focused and also mouse hovered in all browsers. */ +/* ========================================================================== + * * Typography + * * ========================================================================== */ +/** + * * Address font sizes and margins set differently in IE 6/7. + * * Address font sizes within `section` and `article` in Firefox 4+, Safari 5, + * * and Chrome. */ +h1 { + font-size: 2em; + margin: 0.67em 0; +} + +h2 { + font-size: 1.5em; + margin: 0.83em 0; +} + +h3 { + font-size: 1.17em; + margin: 1em 0; +} + +h4, .tsd-index-panel h3 { + font-size: 1em; + margin: 1.33em 0; +} + +h5 { + font-size: 0.83em; + margin: 1.67em 0; +} + +h6 { + font-size: 0.67em; + margin: 2.33em 0; +} + +/** + * * Address styling not present in IE 7/8/9, Safari 5, and Chrome. */ +abbr[title] { + border-bottom: 1px dotted; +} + +/** + * * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */ +b, strong { + font-weight: bold; +} + +blockquote { + margin: 1em 40px; +} + +/** + * * Address styling not present in Safari 5 and Chrome. */ +dfn { + font-style: italic; +} + +/** + * * Address differences between Firefox and other browsers. + * * Known issue: no IE 6/7 normalization. */ +hr { + -moz-box-sizing: content-box; + box-sizing: content-box; + height: 0; +} + +/** + * * Address styling not present in IE 6/7/8/9. */ +mark { + background: #ff0; + color: #000; +} + +/** + * * Address margins set differently in IE 6/7. */ +p, pre { + margin: 1em 0; +} + +/** + * * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */ +code, kbd, pre, samp { + font-family: monospace, serif; + _font-family: "courier new", monospace; + font-size: 1em; +} + +/** + * * Improve readability of pre-formatted text in all browsers. */ +pre { + white-space: pre; + white-space: pre-wrap; + word-wrap: break-word; +} + +/** + * * Address CSS quotes not supported in IE 6/7. */ +q { + quotes: none; +} +q:before, q:after { + content: ""; + content: none; +} + +/** + * * Address `quotes` property not supported in Safari 4. */ +/** + * * Address inconsistent and variable font size in all browsers. */ +small { + font-size: 80%; +} + +/** + * * Prevent `sub` and `sup` affecting `line-height` in all browsers. */ +sub { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} + +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; + top: -0.5em; +} + +sub { + bottom: -0.25em; +} + +/* ========================================================================== + * * Lists + * * ========================================================================== */ +/** + * * Address margins set differently in IE 6/7. */ +dl, menu, ol, ul { + margin: 1em 0; +} + +dd { + margin: 0 0 0 40px; +} + +/** + * * Address paddings set differently in IE 6/7. */ +menu, ol, ul { + padding: 0 0 0 40px; +} + +/** + * * Correct list images handled incorrectly in IE 7. */ +nav ul, nav ol { + list-style: none; + list-style-image: none; +} + +/* ========================================================================== + * * Embedded content + * * ========================================================================== */ +/** + * * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3. + * * 2. Improve image quality when scaled in IE 7. */ +img { + border: 0; + /* 1 */ + -ms-interpolation-mode: bicubic; +} + +/* 2 */ +/** + * * Correct overflow displayed oddly in IE 9. */ +svg:not(:root) { + overflow: hidden; +} + +/* ========================================================================== + * * Figures + * * ========================================================================== */ +/** + * * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */ +figure, form { + margin: 0; +} + +/* ========================================================================== + * * Forms + * * ========================================================================== */ +/** + * * Correct margin displayed oddly in IE 6/7. */ +/** + * * Define consistent border, margin, and padding. */ +fieldset { + border: 1px solid #c0c0c0; + margin: 0 2px; + padding: 0.35em 0.625em 0.75em; +} + +/** + * * 1. Correct color not being inherited in IE 6/7/8/9. + * * 2. Correct text not wrapping in Firefox 3. + * * 3. Correct alignment displayed oddly in IE 6/7. */ +legend { + border: 0; + /* 1 */ + padding: 0; + white-space: normal; + /* 2 */ + *margin-left: -7px; +} + +/* 3 */ +/** + * * 1. Correct font size not being inherited in all browsers. + * * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5, + * * and Chrome. + * * 3. Improve appearance and consistency in all browsers. */ +button, input, select, textarea { + font-size: 100%; + /* 1 */ + margin: 0; + /* 2 */ + vertical-align: baseline; + /* 3 */ + *vertical-align: middle; +} + +/* 3 */ +/** + * * Address Firefox 3+ setting `line-height` on `input` using `!important` in + * * the UA stylesheet. */ +button, input { + line-height: normal; +} + +/** + * * Address inconsistent `text-transform` inheritance for `button` and `select`. + * * All other form control elements do not inherit `text-transform` values. + * * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+. + * * Correct `select` style inheritance in Firefox 4+ and Opera. */ +button, select { + text-transform: none; +} + +/** + * * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` + * * and `video` controls. + * * 2. Correct inability to style clickable `input` types in iOS. + * * 3. Improve usability and consistency of cursor style between image-type + * * `input` and others. + * * 4. Remove inner spacing in IE 7 without affecting normal text inputs. + * * Known issue: inner spacing remains in IE 6. */ +button, html input[type=button] { + -webkit-appearance: button; + /* 2 */ + cursor: pointer; + /* 3 */ + *overflow: visible; +} + +/* 4 */ +input[type=reset], input[type=submit] { + -webkit-appearance: button; + /* 2 */ + cursor: pointer; + /* 3 */ + *overflow: visible; +} + +/* 4 */ +/** + * * Re-set default cursor for disabled elements. */ +button[disabled], html input[disabled] { + cursor: default; +} + +/** + * * 1. Address box sizing set to content-box in IE 8/9. + * * 2. Remove excess padding in IE 8/9. + * * 3. Remove excess padding in IE 7. + * * Known issue: excess padding remains in IE 6. */ +input { + /* 3 */ +} +input[type=checkbox], input[type=radio] { + box-sizing: border-box; + /* 1 */ + padding: 0; + /* 2 */ + *height: 13px; + /* 3 */ + *width: 13px; +} +input[type=search] { + -webkit-appearance: textfield; + /* 1 */ + -moz-box-sizing: content-box; + -webkit-box-sizing: content-box; + /* 2 */ + box-sizing: content-box; +} +input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration { + -webkit-appearance: none; +} + +/** + * * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. + * * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome + * * (include `-moz` to future-proof). */ +/** + * * Remove inner padding and search cancel button in Safari 5 and Chrome + * * on OS X. */ +/** + * * Remove inner padding and border in Firefox 3+. */ +button::-moz-focus-inner, input::-moz-focus-inner { + border: 0; + padding: 0; +} + +/** + * * 1. Remove default vertical scrollbar in IE 6/7/8/9. + * * 2. Improve readability and alignment in all browsers. */ +textarea { + overflow: auto; + /* 1 */ + vertical-align: top; +} + +/* 2 */ +/* ========================================================================== + * * Tables + * * ========================================================================== */ +/** + * * Remove most spacing between table cells. */ +table { + border-collapse: collapse; + border-spacing: 0; +} + +ul.tsd-descriptions > li > :first-child, .tsd-panel > :first-child, .col > :first-child, .col-11 > :first-child, .col-10 > :first-child, .col-9 > :first-child, .col-8 > :first-child, .col-7 > :first-child, .col-6 > :first-child, .col-5 > :first-child, .col-4 > :first-child, .col-3 > :first-child, .col-2 > :first-child, .col-1 > :first-child, +ul.tsd-descriptions > li > :first-child > :first-child, +.tsd-panel > :first-child > :first-child, +.col > :first-child > :first-child, +.col-11 > :first-child > :first-child, +.col-10 > :first-child > :first-child, +.col-9 > :first-child > :first-child, +.col-8 > :first-child > :first-child, +.col-7 > :first-child > :first-child, +.col-6 > :first-child > :first-child, +.col-5 > :first-child > :first-child, +.col-4 > :first-child > :first-child, +.col-3 > :first-child > :first-child, +.col-2 > :first-child > :first-child, +.col-1 > :first-child > :first-child, +ul.tsd-descriptions > li > :first-child > :first-child > :first-child, +.tsd-panel > :first-child > :first-child > :first-child, +.col > :first-child > :first-child > :first-child, +.col-11 > :first-child > :first-child > :first-child, +.col-10 > :first-child > :first-child > :first-child, +.col-9 > :first-child > :first-child > :first-child, +.col-8 > :first-child > :first-child > :first-child, +.col-7 > :first-child > :first-child > :first-child, +.col-6 > :first-child > :first-child > :first-child, +.col-5 > :first-child > :first-child > :first-child, +.col-4 > :first-child > :first-child > :first-child, +.col-3 > :first-child > :first-child > :first-child, +.col-2 > :first-child > :first-child > :first-child, +.col-1 > :first-child > :first-child > :first-child { + margin-top: 0; +} +ul.tsd-descriptions > li > :last-child, .tsd-panel > :last-child, .col > :last-child, .col-11 > :last-child, .col-10 > :last-child, .col-9 > :last-child, .col-8 > :last-child, .col-7 > :last-child, .col-6 > :last-child, .col-5 > :last-child, .col-4 > :last-child, .col-3 > :last-child, .col-2 > :last-child, .col-1 > :last-child, +ul.tsd-descriptions > li > :last-child > :last-child, +.tsd-panel > :last-child > :last-child, +.col > :last-child > :last-child, +.col-11 > :last-child > :last-child, +.col-10 > :last-child > :last-child, +.col-9 > :last-child > :last-child, +.col-8 > :last-child > :last-child, +.col-7 > :last-child > :last-child, +.col-6 > :last-child > :last-child, +.col-5 > :last-child > :last-child, +.col-4 > :last-child > :last-child, +.col-3 > :last-child > :last-child, +.col-2 > :last-child > :last-child, +.col-1 > :last-child > :last-child, +ul.tsd-descriptions > li > :last-child > :last-child > :last-child, +.tsd-panel > :last-child > :last-child > :last-child, +.col > :last-child > :last-child > :last-child, +.col-11 > :last-child > :last-child > :last-child, +.col-10 > :last-child > :last-child > :last-child, +.col-9 > :last-child > :last-child > :last-child, +.col-8 > :last-child > :last-child > :last-child, +.col-7 > :last-child > :last-child > :last-child, +.col-6 > :last-child > :last-child > :last-child, +.col-5 > :last-child > :last-child > :last-child, +.col-4 > :last-child > :last-child > :last-child, +.col-3 > :last-child > :last-child > :last-child, +.col-2 > :last-child > :last-child > :last-child, +.col-1 > :last-child > :last-child > :last-child { + margin-bottom: 0; +} + +.container { + max-width: 1200px; + margin: 0 auto; + padding: 0 40px; +} +@media (max-width: 640px) { + .container { + padding: 0 20px; + } +} + +.container-main { + padding-bottom: 200px; +} + +.row { + display: flex; + position: relative; + margin: 0 -10px; +} +.row:after { + visibility: hidden; + display: block; + content: ""; + clear: both; + height: 0; +} + +.col, .col-11, .col-10, .col-9, .col-8, .col-7, .col-6, .col-5, .col-4, .col-3, .col-2, .col-1 { + box-sizing: border-box; + float: left; + padding: 0 10px; +} + +.col-1 { + width: 8.3333333333%; +} + +.offset-1 { + margin-left: 8.3333333333%; +} + +.col-2 { + width: 16.6666666667%; +} + +.offset-2 { + margin-left: 16.6666666667%; +} + +.col-3 { + width: 25%; +} + +.offset-3 { + margin-left: 25%; +} + +.col-4 { + width: 33.3333333333%; +} + +.offset-4 { + margin-left: 33.3333333333%; +} + +.col-5 { + width: 41.6666666667%; +} + +.offset-5 { + margin-left: 41.6666666667%; +} + +.col-6 { + width: 50%; +} + +.offset-6 { + margin-left: 50%; +} + +.col-7 { + width: 58.3333333333%; +} + +.offset-7 { + margin-left: 58.3333333333%; +} + +.col-8 { + width: 66.6666666667%; +} + +.offset-8 { + margin-left: 66.6666666667%; +} + +.col-9 { + width: 75%; +} + +.offset-9 { + margin-left: 75%; +} + +.col-10 { + width: 83.3333333333%; +} + +.offset-10 { + margin-left: 83.3333333333%; +} + +.col-11 { + width: 91.6666666667%; +} + +.offset-11 { + margin-left: 91.6666666667%; +} + +.tsd-kind-icon { + display: block; + position: relative; + padding-left: 20px; + text-indent: -20px; +} +.tsd-kind-icon:before { + content: ""; + display: inline-block; + vertical-align: middle; + width: 17px; + height: 17px; + margin: 0 3px 2px 0; + background-image: url(../images/icons.png); +} +@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { + .tsd-kind-icon:before { + background-image: url(../images/icons@2x.png); + background-size: 238px 204px; + } +} + +.tsd-signature.tsd-kind-icon:before { + background-position: 0 -153px; +} + +.tsd-kind-object-literal > .tsd-kind-icon:before { + background-position: 0px -17px; +} +.tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -17px; +} +.tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -17px; +} + +.tsd-kind-class > .tsd-kind-icon:before { + background-position: 0px -34px; +} +.tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -34px; +} +.tsd-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -34px; +} + +.tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -51px; +} +.tsd-kind-class.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -51px; +} +.tsd-kind-class.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -51px; +} + +.tsd-kind-interface > .tsd-kind-icon:before { + background-position: 0px -68px; +} +.tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -68px; +} +.tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -68px; +} + +.tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -85px; +} +.tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -85px; +} +.tsd-kind-interface.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -85px; +} + +.tsd-kind-namespace > .tsd-kind-icon:before { + background-position: 0px -102px; +} +.tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -102px; +} +.tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -102px; +} + +.tsd-kind-module > .tsd-kind-icon:before { + background-position: 0px -102px; +} +.tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -102px; +} +.tsd-kind-module.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -102px; +} + +.tsd-kind-enum > .tsd-kind-icon:before { + background-position: 0px -119px; +} +.tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -119px; +} +.tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -119px; +} + +.tsd-kind-enum-member > .tsd-kind-icon:before { + background-position: 0px -136px; +} +.tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -136px; +} +.tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -136px; +} + +.tsd-kind-signature > .tsd-kind-icon:before { + background-position: 0px -153px; +} +.tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -153px; +} +.tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -153px; +} + +.tsd-kind-type-alias > .tsd-kind-icon:before { + background-position: 0px -170px; +} +.tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -170px; +} +.tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -170px; +} + +.tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -187px; +} +.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -187px; +} +.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -187px; +} + +.tsd-kind-variable > .tsd-kind-icon:before { + background-position: -136px -0px; +} +.tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -0px; +} +.tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -0px; +} +.tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -0px; +} + +.tsd-kind-property > .tsd-kind-icon:before { + background-position: -136px -0px; +} +.tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -0px; +} +.tsd-kind-property.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -0px; +} +.tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -0px; +} + +.tsd-kind-get-signature > .tsd-kind-icon:before { + background-position: -136px -17px; +} +.tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -17px; +} +.tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -17px; +} + +.tsd-kind-set-signature > .tsd-kind-icon:before { + background-position: -136px -34px; +} +.tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -34px; +} +.tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -34px; +} + +.tsd-kind-accessor > .tsd-kind-icon:before { + background-position: -136px -51px; +} +.tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -51px; +} +.tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -51px; +} + +.tsd-kind-function > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-method > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-call-signature > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: -136px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -85px; +} + +.tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: -136px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -85px; +} + +.tsd-kind-constructor > .tsd-kind-icon:before { + background-position: -136px -102px; +} +.tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -102px; +} +.tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -102px; +} + +.tsd-kind-constructor-signature > .tsd-kind-icon:before { + background-position: -136px -102px; +} +.tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -102px; +} +.tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -102px; +} + +.tsd-kind-index-signature > .tsd-kind-icon:before { + background-position: -136px -119px; +} +.tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -119px; +} +.tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -119px; +} + +.tsd-kind-event > .tsd-kind-icon:before { + background-position: -136px -136px; +} +.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -136px; +} +.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -136px; +} +.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -136px; +} + +.tsd-is-static > .tsd-kind-icon:before { + background-position: -136px -153px; +} +.tsd-is-static.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -153px; +} +.tsd-is-static.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -153px; +} +.tsd-is-static.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -153px; +} +.tsd-is-static.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -153px; +} +.tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -153px; +} + +.tsd-is-static.tsd-kind-function > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-method > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-event > .tsd-kind-icon:before { + background-position: -136px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -102px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -221px -187px; +} + +@keyframes fade-in { + from { + opacity: 0; + } + to { + opacity: 1; + } +} +@keyframes fade-out { + from { + opacity: 1; + visibility: visible; + } + to { + opacity: 0; + } +} +@keyframes fade-in-delayed { + 0% { + opacity: 0; + } + 33% { + opacity: 0; + } + 100% { + opacity: 1; + } +} +@keyframes fade-out-delayed { + 0% { + opacity: 1; + visibility: visible; + } + 66% { + opacity: 0; + } + 100% { + opacity: 0; + } +} +@keyframes shift-to-left { + from { + transform: translate(0, 0); + } + to { + transform: translate(-25%, 0); + } +} +@keyframes unshift-to-left { + from { + transform: translate(-25%, 0); + } + to { + transform: translate(0, 0); + } +} +@keyframes pop-in-from-right { + from { + transform: translate(100%, 0); + } + to { + transform: translate(0, 0); + } +} +@keyframes pop-out-to-right { + from { + transform: translate(0, 0); + visibility: visible; + } + to { + transform: translate(100%, 0); + } +} +body { + background: var(--color-background); + font-family: "Segoe UI", sans-serif; + font-size: 16px; + color: var(--color-text); +} + +a { + color: var(--color-link); + text-decoration: none; +} +a:hover { + text-decoration: underline; +} + +code, pre { + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + padding: 0.2em; + margin: 0; + font-size: 14px; + background-color: var(--color-code-background); +} + +pre { + padding: 10px; +} +pre code { + padding: 0; + font-size: 100%; + background-color: transparent; +} + +blockquote { + margin: 1em 0; + padding-left: 1em; + border-left: 4px solid gray; +} + +.tsd-typography { + line-height: 1.333em; +} +.tsd-typography ul { + list-style: square; + padding: 0 0 0 20px; + margin: 0; +} +.tsd-typography h4, .tsd-typography .tsd-index-panel h3, .tsd-index-panel .tsd-typography h3, .tsd-typography h5, .tsd-typography h6 { + font-size: 1em; + margin: 0; +} +.tsd-typography h5, .tsd-typography h6 { + font-weight: normal; +} +.tsd-typography p, .tsd-typography ul, .tsd-typography ol { + margin: 1em 0; +} + +@media (min-width: 901px) and (max-width: 1024px) { + html.default .col-content { + width: 72%; + } + html.default .col-menu { + width: 28%; + } + html.default .tsd-navigation { + padding-left: 10px; + } +} +@media (max-width: 900px) { + html.default .col-content { + float: none; + width: 100%; + } + html.default .col-menu { + position: fixed !important; + overflow: auto; + -webkit-overflow-scrolling: touch; + z-index: 1024; + top: 0 !important; + bottom: 0 !important; + left: auto !important; + right: 0 !important; + width: 100%; + padding: 20px 20px 0 0; + max-width: 450px; + visibility: hidden; + background-color: var(--color-panel); + transform: translate(100%, 0); + } + html.default .col-menu > *:last-child { + padding-bottom: 20px; + } + html.default .overlay { + content: ""; + display: block; + position: fixed; + z-index: 1023; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: rgba(0, 0, 0, 0.75); + visibility: hidden; + } + html.default.to-has-menu .overlay { + animation: fade-in 0.4s; + } + html.default.to-has-menu header, +html.default.to-has-menu footer, +html.default.to-has-menu .col-content { + animation: shift-to-left 0.4s; + } + html.default.to-has-menu .col-menu { + animation: pop-in-from-right 0.4s; + } + html.default.from-has-menu .overlay { + animation: fade-out 0.4s; + } + html.default.from-has-menu header, +html.default.from-has-menu footer, +html.default.from-has-menu .col-content { + animation: unshift-to-left 0.4s; + } + html.default.from-has-menu .col-menu { + animation: pop-out-to-right 0.4s; + } + html.default.has-menu body { + overflow: hidden; + } + html.default.has-menu .overlay { + visibility: visible; + } + html.default.has-menu header, +html.default.has-menu footer, +html.default.has-menu .col-content { + transform: translate(-25%, 0); + } + html.default.has-menu .col-menu { + visibility: visible; + transform: translate(0, 0); + } +} + +.tsd-page-title { + padding: 70px 0 20px 0; + margin: 0 0 40px 0; + background: var(--color-panel); + box-shadow: 0 0 5px rgba(0, 0, 0, 0.35); +} +.tsd-page-title h1 { + margin: 0; +} + +.tsd-breadcrumb { + margin: 0; + padding: 0; + color: var(--toolbar-text-color); +} +.tsd-breadcrumb a { + color: var(--toolbar-text-color); + text-decoration: none; +} +.tsd-breadcrumb a:hover { + text-decoration: underline; +} +.tsd-breadcrumb li { + display: inline; +} +.tsd-breadcrumb li:after { + content: " / "; +} + +dl.tsd-comment-tags { + overflow: hidden; +} +dl.tsd-comment-tags dt { + float: left; + padding: 1px 5px; + margin: 0 10px 0 0; + border-radius: 4px; + border: 1px solid var(--color-menu-label); + color: var(--color-comment-tag-text); + font-size: 0.8em; + font-weight: normal; +} +dl.tsd-comment-tags dd { + margin: 0 0 10px 0; +} +dl.tsd-comment-tags dd:before, dl.tsd-comment-tags dd:after { + display: table; + content: " "; +} +dl.tsd-comment-tags dd pre, dl.tsd-comment-tags dd:after { + clear: both; +} +dl.tsd-comment-tags p { + margin: 0; +} + +.tsd-panel.tsd-comment .lead { + font-size: 1.1em; + line-height: 1.333em; + margin-bottom: 2em; +} +.tsd-panel.tsd-comment .lead:last-child { + margin-bottom: 0; +} + +.toggle-protected .tsd-is-private { + display: none; +} + +.toggle-public .tsd-is-private, +.toggle-public .tsd-is-protected, +.toggle-public .tsd-is-private-protected { + display: none; +} + +.toggle-inherited .tsd-is-inherited { + display: none; +} + +.toggle-externals .tsd-is-external { + display: none; +} + +#tsd-filter { + position: relative; + display: inline-block; + height: 40px; + vertical-align: bottom; +} +.no-filter #tsd-filter { + display: none; +} +#tsd-filter .tsd-filter-group { + display: inline-block; + height: 40px; + vertical-align: bottom; + white-space: nowrap; +} +#tsd-filter input { + display: none; +} +@media (max-width: 900px) { + #tsd-filter .tsd-filter-group { + display: block; + position: absolute; + top: 40px; + right: 20px; + height: auto; + background-color: var(--color-panel); + visibility: hidden; + transform: translate(50%, 0); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); + } + .has-options #tsd-filter .tsd-filter-group { + visibility: visible; + } + .to-has-options #tsd-filter .tsd-filter-group { + animation: fade-in 0.2s; + } + .from-has-options #tsd-filter .tsd-filter-group { + animation: fade-out 0.2s; + } + #tsd-filter label, +#tsd-filter .tsd-select { + display: block; + padding-right: 20px; + } +} + +footer { + border-top: 1px solid var(--color-panel-divider); + background-color: var(--color-panel); +} +footer.with-border-bottom { + border-bottom: 1px solid var(--color-panel-divider); +} +footer .tsd-legend-group { + font-size: 0; +} +footer .tsd-legend { + display: inline-block; + width: 25%; + padding: 0; + font-size: 16px; + list-style: none; + line-height: 1.333em; + vertical-align: top; +} +@media (max-width: 900px) { + footer .tsd-legend { + width: 50%; + } +} + +.tsd-hierarchy { + list-style: square; + padding: 0 0 0 20px; + margin: 0; +} +.tsd-hierarchy .target { + font-weight: bold; +} + +.tsd-index-panel .tsd-index-content { + margin-bottom: -30px !important; +} +.tsd-index-panel .tsd-index-section { + margin-bottom: 30px !important; +} +.tsd-index-panel h3 { + margin: 0 -20px 10px -20px; + padding: 0 20px 10px 20px; + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 3; + -moz-column-count: 3; + -ms-column-count: 3; + -o-column-count: 3; + column-count: 3; + -webkit-column-gap: 20px; + -moz-column-gap: 20px; + -ms-column-gap: 20px; + -o-column-gap: 20px; + column-gap: 20px; + padding: 0; + list-style: none; + line-height: 1.333em; +} +@media (max-width: 900px) { + .tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 1; + -moz-column-count: 1; + -ms-column-count: 1; + -o-column-count: 1; + column-count: 1; + } +} +@media (min-width: 901px) and (max-width: 1024px) { + .tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 2; + -moz-column-count: 2; + -ms-column-count: 2; + -o-column-count: 2; + column-count: 2; + } +} +.tsd-index-panel ul.tsd-index-list li { + -webkit-page-break-inside: avoid; + -moz-page-break-inside: avoid; + -ms-page-break-inside: avoid; + -o-page-break-inside: avoid; + page-break-inside: avoid; +} +.tsd-index-panel a, +.tsd-index-panel .tsd-parent-kind-module a { + color: var(--color-ts); +} +.tsd-index-panel .tsd-parent-kind-interface a { + color: var(--color-ts-interface); +} +.tsd-index-panel .tsd-parent-kind-enum a { + color: var(--color-ts-enum); +} +.tsd-index-panel .tsd-parent-kind-class a { + color: var(--color-ts-class); +} +.tsd-index-panel .tsd-kind-module a { + color: var(--color-ts); +} +.tsd-index-panel .tsd-kind-interface a { + color: var(--color-ts-interface); +} +.tsd-index-panel .tsd-kind-enum a { + color: var(--color-ts-enum); +} +.tsd-index-panel .tsd-kind-class a { + color: var(--color-ts-class); +} +.tsd-index-panel .tsd-is-private a { + color: var(--color-ts-private); +} + +.tsd-flag { + display: inline-block; + padding: 1px 5px; + border-radius: 4px; + color: var(--color-comment-tag-text); + background-color: var(--color-comment-tag); + text-indent: 0; + font-size: 14px; + font-weight: normal; +} + +.tsd-anchor { + position: absolute; + top: -100px; +} + +.tsd-member { + position: relative; +} +.tsd-member .tsd-anchor + h3 { + margin-top: 0; + margin-bottom: 0; + border-bottom: none; +} +.tsd-member a[data-tsd-kind] { + color: var(--color-ts); +} +.tsd-member a[data-tsd-kind=Interface] { + color: var(--color-ts-interface); +} +.tsd-member a[data-tsd-kind=Enum] { + color: var(--color-ts-enum); +} +.tsd-member a[data-tsd-kind=Class] { + color: var(--color-ts-class); +} +.tsd-member a[data-tsd-kind=Private] { + color: var(--color-ts-private); +} + +.tsd-navigation { + margin: 0 0 0 40px; +} +.tsd-navigation a { + display: block; + padding-top: 2px; + padding-bottom: 2px; + border-left: 2px solid transparent; + color: var(--color-text); + text-decoration: none; + transition: border-left-color 0.1s; +} +.tsd-navigation a:hover { + text-decoration: underline; +} +.tsd-navigation ul { + margin: 0; + padding: 0; + list-style: none; +} +.tsd-navigation li { + padding: 0; +} + +.tsd-navigation.primary { + padding-bottom: 40px; +} +.tsd-navigation.primary a { + display: block; + padding-top: 6px; + padding-bottom: 6px; +} +.tsd-navigation.primary ul li a { + padding-left: 5px; +} +.tsd-navigation.primary ul li li a { + padding-left: 25px; +} +.tsd-navigation.primary ul li li li a { + padding-left: 45px; +} +.tsd-navigation.primary ul li li li li a { + padding-left: 65px; +} +.tsd-navigation.primary ul li li li li li a { + padding-left: 85px; +} +.tsd-navigation.primary ul li li li li li li a { + padding-left: 105px; +} +.tsd-navigation.primary > ul { + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-navigation.primary li { + border-top: 1px solid var(--color-panel-divider); +} +.tsd-navigation.primary li.current > a { + font-weight: bold; +} +.tsd-navigation.primary li.label span { + display: block; + padding: 20px 0 6px 5px; + color: var(--color-menu-label); +} +.tsd-navigation.primary li.globals + li > span, .tsd-navigation.primary li.globals + li > a { + padding-top: 20px; +} + +.tsd-navigation.secondary { + max-height: calc(100vh - 1rem - 40px); + overflow: auto; + position: -webkit-sticky; + position: sticky; + top: calc(.5rem + 40px); + transition: 0.3s; +} +.tsd-navigation.secondary.tsd-navigation--toolbar-hide { + max-height: calc(100vh - 1rem); + top: 0.5rem; +} +.tsd-navigation.secondary ul { + transition: opacity 0.2s; +} +.tsd-navigation.secondary ul li a { + padding-left: 25px; +} +.tsd-navigation.secondary ul li li a { + padding-left: 45px; +} +.tsd-navigation.secondary ul li li li a { + padding-left: 65px; +} +.tsd-navigation.secondary ul li li li li a { + padding-left: 85px; +} +.tsd-navigation.secondary ul li li li li li a { + padding-left: 105px; +} +.tsd-navigation.secondary ul li li li li li li a { + padding-left: 125px; +} +.tsd-navigation.secondary ul.current a { + border-left-color: var(--color-panel-divider); +} +.tsd-navigation.secondary li.focus > a, +.tsd-navigation.secondary ul.current li.focus > a { + border-left-color: var(--color-menu-divider-focus); +} +.tsd-navigation.secondary li.current { + margin-top: 20px; + margin-bottom: 20px; + border-left-color: var(--color-panel-divider); +} +.tsd-navigation.secondary li.current > a { + font-weight: bold; +} + +@media (min-width: 901px) { + .menu-sticky-wrap { + position: static; + } +} + +.tsd-panel { + margin: 20px 0; + padding: 20px; + background-color: var(--color-panel); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); +} +.tsd-panel:empty { + display: none; +} +.tsd-panel > h1, .tsd-panel > h2, .tsd-panel > h3 { + margin: 1.5em -20px 10px -20px; + padding: 0 20px 10px 20px; + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-panel > h1.tsd-before-signature, .tsd-panel > h2.tsd-before-signature, .tsd-panel > h3.tsd-before-signature { + margin-bottom: 0; + border-bottom: 0; +} +.tsd-panel table { + display: block; + width: 100%; + overflow: auto; + margin-top: 10px; + word-break: normal; + word-break: keep-all; +} +.tsd-panel table th { + font-weight: bold; +} +.tsd-panel table th, .tsd-panel table td { + padding: 6px 13px; + border: 1px solid #ddd; +} +.tsd-panel table tr { + background-color: var(--color-background); + border-top: 1px solid #ccc; +} +.tsd-panel table tr:nth-child(2n) { + background-color: var(--color-background); +} + +.tsd-panel-group { + margin: 60px 0; +} +.tsd-panel-group > h1, .tsd-panel-group > h2, .tsd-panel-group > h3 { + padding-left: 20px; + padding-right: 20px; +} + +#tsd-search { + transition: background-color 0.2s; +} +#tsd-search .title { + position: relative; + z-index: 2; +} +#tsd-search .field { + position: absolute; + left: 0; + top: 0; + right: 40px; + height: 40px; +} +#tsd-search .field input { + box-sizing: border-box; + position: relative; + top: -50px; + z-index: 1; + width: 100%; + padding: 0 10px; + opacity: 0; + outline: 0; + border: 0; + background: transparent; + color: var(--color-text); +} +#tsd-search .field label { + position: absolute; + overflow: hidden; + right: -40px; +} +#tsd-search .field input, +#tsd-search .title { + transition: opacity 0.2s; +} +#tsd-search .results { + position: absolute; + visibility: hidden; + top: 40px; + width: 100%; + margin: 0; + padding: 0; + list-style: none; + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); +} +#tsd-search .results li { + padding: 0 10px; + background-color: var(--color-background); +} +#tsd-search .results li:nth-child(even) { + background-color: var(--color-panel); +} +#tsd-search .results li.state { + display: none; +} +#tsd-search .results li.current, +#tsd-search .results li:hover { + background-color: var(--color-comment-tag); +} +#tsd-search .results a { + display: block; +} +#tsd-search .results a:before { + top: 10px; +} +#tsd-search .results span.parent { + color: var(--color-sources); + font-weight: normal; +} +#tsd-search.has-focus { + background-color: var(--color-comment-tag); +} +#tsd-search.has-focus .field input { + top: 0; + opacity: 1; +} +#tsd-search.has-focus .title { + z-index: 0; + opacity: 0; +} +#tsd-search.has-focus .results { + visibility: visible; +} +#tsd-search.loading .results li.state.loading { + display: block; +} +#tsd-search.failure .results li.state.failure { + display: block; +} + +.tsd-signature { + margin: 0 0 1em 0; + padding: 10px; + border: 1px solid var(--color-panel-divider); + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + font-size: 14px; + overflow-x: auto; +} +.tsd-signature.tsd-kind-icon { + padding-left: 30px; +} +.tsd-signature.tsd-kind-icon:before { + top: 10px; + left: 10px; +} +.tsd-panel > .tsd-signature { + margin-left: -20px; + margin-right: -20px; + border-width: 1px 0; +} +.tsd-panel > .tsd-signature.tsd-kind-icon { + padding-left: 40px; +} +.tsd-panel > .tsd-signature.tsd-kind-icon:before { + left: 20px; +} + +.tsd-signature-symbol { + font-weight: normal; + color: var(--color-sources); +} + +.tsd-signature-type { + font-style: italic; + font-weight: normal; + color: var(--color-sources); +} + +.tsd-signatures { + padding: 0; + margin: 0 0 1em 0; + border: 1px solid var(--color-panel-divider); +} +.tsd-signatures .tsd-signature { + margin: 0; + border-width: 1px 0 0 0; + transition: background-color 0.1s; +} +.tsd-signatures .tsd-signature:first-child { + border-top-width: 0; +} +.tsd-signatures .tsd-signature.current { + background-color: var(--color-comment-tag); +} +.tsd-signatures.active > .tsd-signature { + cursor: pointer; +} +.tsd-panel > .tsd-signatures { + margin-left: -20px; + margin-right: -20px; + border-width: 1px 0; +} +.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon { + padding-left: 40px; +} +.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before { + left: 20px; +} +.tsd-panel > a.anchor + .tsd-signatures { + border-top-width: 0; + margin-top: -20px; +} + +ul.tsd-descriptions { + position: relative; + overflow: hidden; + padding: 0; + list-style: none; +} +ul.tsd-descriptions.active > .tsd-description { + display: none; +} +ul.tsd-descriptions.active > .tsd-description.current { + display: block; +} +ul.tsd-descriptions.active > .tsd-description.fade-in { + animation: fade-in-delayed 0.3s; +} +ul.tsd-descriptions.active > .tsd-description.fade-out { + animation: fade-out-delayed 0.3s; + position: absolute; + display: block; + top: 0; + left: 0; + right: 0; + opacity: 0; + visibility: hidden; +} +ul.tsd-descriptions h4, ul.tsd-descriptions .tsd-index-panel h3, .tsd-index-panel ul.tsd-descriptions h3 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} + +ul.tsd-parameters, +ul.tsd-type-parameters { + list-style: square; + margin: 0; + padding-left: 20px; +} +ul.tsd-parameters > li.tsd-parameter-signature, +ul.tsd-type-parameters > li.tsd-parameter-signature { + list-style: none; + margin-left: -20px; +} +ul.tsd-parameters h5, +ul.tsd-type-parameters h5 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} +ul.tsd-parameters .tsd-comment, +ul.tsd-type-parameters .tsd-comment { + margin-top: -0.5em; +} + +.tsd-sources { + font-size: 14px; + color: var(--color-sources); + margin: 0 0 1em 0; +} +.tsd-sources a { + text-decoration: underline; +} +.tsd-sources ul, .tsd-sources p { + margin: 0 !important; +} +.tsd-sources ul { + list-style: none; + padding: 0; +} + +.tsd-page-toolbar { + position: fixed; + z-index: 1; + top: 0; + left: 0; + width: 100%; + height: 40px; + color: var(--color-menu-divider-focus); + background: var(--toolbar-color); + border-bottom: 1px solid var(--color-panel-divider); + transition: transform 0.3s linear; +} +.tsd-page-toolbar a { + color: var(--toolbar-text-color); + text-decoration: none; +} +.tsd-page-toolbar a.title { + font-weight: bold; +} +.tsd-page-toolbar a.title:hover { + text-decoration: underline; +} +.tsd-page-toolbar .table-wrap { + display: table; + width: 100%; + height: 40px; +} +.tsd-page-toolbar .table-cell { + display: table-cell; + position: relative; + white-space: nowrap; + line-height: 40px; +} +.tsd-page-toolbar .table-cell:first-child { + width: 100%; +} + +.tsd-page-toolbar--hide { + transform: translateY(-100%); +} + +.tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before { + content: ""; + display: inline-block; + width: 40px; + height: 40px; + margin: 0 -8px 0 0; + background-image: url(../images/widgets.png); + background-repeat: no-repeat; + text-indent: -1024px; + vertical-align: bottom; +} +@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { + .tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before { + background-image: url(../images/widgets@2x.png); + background-size: 320px 40px; + } +} + +.tsd-widget { + display: inline-block; + overflow: hidden; + opacity: 0.6; + height: 40px; + transition: opacity 0.1s, background-color 0.2s; + vertical-align: bottom; + cursor: pointer; +} +.tsd-widget:hover { + opacity: 0.8; +} +.tsd-widget.active { + opacity: 1; + background-color: var(--color-panel-divider); +} +.tsd-widget.no-caption { + width: 40px; +} +.tsd-widget.no-caption:before { + margin: 0; +} +.tsd-widget.search:before { + background-position: 0 0; +} +.tsd-widget.menu:before { + background-position: -40px 0; +} +.tsd-widget.options:before { + background-position: -80px 0; +} +.tsd-widget.options, .tsd-widget.menu { + display: none; +} +@media (max-width: 900px) { + .tsd-widget.options, .tsd-widget.menu { + display: inline-block; + } +} +input[type=checkbox] + .tsd-widget:before { + background-position: -120px 0; +} +input[type=checkbox]:checked + .tsd-widget:before { + background-position: -160px 0; +} + +.tsd-select { + position: relative; + display: inline-block; + height: 40px; + transition: opacity 0.1s, background-color 0.2s; + vertical-align: bottom; + cursor: pointer; +} +.tsd-select .tsd-select-label { + opacity: 0.6; + transition: opacity 0.2s; +} +.tsd-select .tsd-select-label:before { + background-position: -240px 0; +} +.tsd-select.active .tsd-select-label { + opacity: 0.8; +} +.tsd-select.active .tsd-select-list { + visibility: visible; + opacity: 1; + transition-delay: 0s; +} +.tsd-select .tsd-select-list { + position: absolute; + visibility: hidden; + top: 40px; + left: 0; + margin: 0; + padding: 0; + opacity: 0; + list-style: none; + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); + transition: visibility 0s 0.2s, opacity 0.2s; +} +.tsd-select .tsd-select-list li { + padding: 0 20px 0 0; + background-color: var(--color-background); +} +.tsd-select .tsd-select-list li:before { + background-position: 40px 0; +} +.tsd-select .tsd-select-list li:nth-child(even) { + background-color: var(--color-panel); +} +.tsd-select .tsd-select-list li:hover { + background-color: var(--color-panel-divider); +} +.tsd-select .tsd-select-list li.selected:before { + background-position: -200px 0; +} +@media (max-width: 900px) { + .tsd-select .tsd-select-list { + top: 0; + left: auto; + right: 100%; + margin-right: -5px; + } + .tsd-select .tsd-select-label:before { + background-position: -280px 0; + } +} + +img { + max-width: 100%; +} diff --git a/docs-release/assets/images/icons.png b/docs-release/assets/images/icons.png new file mode 100644 index 0000000000000000000000000000000000000000..3836d5fe46e48bbe186116855aae879c23935327 GIT binary patch literal 9615 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 NZmR35l_G4O{0}dcmS_L~ literal 0 HcmV?d00001 diff --git a/docs-release/assets/images/icons@2x.png b/docs-release/assets/images/icons@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..5a209e2f6d7f915cc9cb6fe7a4264c8be4db87b0 GIT binary patch literal 28144 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 literal 0 HcmV?d00001 diff --git a/docs-release/assets/images/widgets@2x.png b/docs-release/assets/images/widgets@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..1a56483dc830478896aae95bb6c270d856621536 GIT binary patch literal 7809 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 J;OObI{{w&5li>gW literal 0 HcmV?d00001 diff --git a/docs-release/assets/js/main.js b/docs-release/assets/js/main.js new file mode 100644 index 0000000..bd9b186 --- /dev/null +++ b/docs-release/assets/js/main.js @@ -0,0 +1,248 @@ +/* + * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development"). + * This devtool is not neither made for production nor for readable output files. + * It uses "eval()" calls to create a separate source file in the browser devtools. + * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) + * or disable the default devtool with "devtool: false". + * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). + */ +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "../node_modules/lunr/lunr.js": +/*!************************************!*\ + !*** ../node_modules/lunr/lunr.js ***! + \************************************/ +/***/ ((module, exports, __webpack_require__) => { + +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/**\n * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9\n * Copyright (C) 2020 Oliver Nightingale\n * @license MIT\n */\n\n;(function(){\n\n/**\n * A convenience function for configuring and constructing\n * a new lunr Index.\n *\n * A lunr.Builder instance is created and the pipeline setup\n * with a trimmer, stop word filter and stemmer.\n *\n * This builder object is yielded to the configuration function\n * that is passed as a parameter, allowing the list of fields\n * and other builder parameters to be customised.\n *\n * All documents _must_ be added within the passed config function.\n *\n * @example\n * var idx = lunr(function () {\n * this.field('title')\n * this.field('body')\n * this.ref('id')\n *\n * documents.forEach(function (doc) {\n * this.add(doc)\n * }, this)\n * })\n *\n * @see {@link lunr.Builder}\n * @see {@link lunr.Pipeline}\n * @see {@link lunr.trimmer}\n * @see {@link lunr.stopWordFilter}\n * @see {@link lunr.stemmer}\n * @namespace {function} lunr\n */\nvar lunr = function (config) {\n var builder = new lunr.Builder\n\n builder.pipeline.add(\n lunr.trimmer,\n lunr.stopWordFilter,\n lunr.stemmer\n )\n\n builder.searchPipeline.add(\n lunr.stemmer\n )\n\n config.call(builder, builder)\n return builder.build()\n}\n\nlunr.version = \"2.3.9\"\n/*!\n * lunr.utils\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * A namespace containing utils for the rest of the lunr library\n * @namespace lunr.utils\n */\nlunr.utils = {}\n\n/**\n * Print a warning message to the console.\n *\n * @param {String} message The message to be printed.\n * @memberOf lunr.utils\n * @function\n */\nlunr.utils.warn = (function (global) {\n /* eslint-disable no-console */\n return function (message) {\n if (global.console && console.warn) {\n console.warn(message)\n }\n }\n /* eslint-enable no-console */\n})(this)\n\n/**\n * Convert an object to a string.\n *\n * In the case of `null` and `undefined` the function returns\n * the empty string, in all other cases the result of calling\n * `toString` on the passed object is returned.\n *\n * @param {Any} obj The object to convert to a string.\n * @return {String} string representation of the passed object.\n * @memberOf lunr.utils\n */\nlunr.utils.asString = function (obj) {\n if (obj === void 0 || obj === null) {\n return \"\"\n } else {\n return obj.toString()\n }\n}\n\n/**\n * Clones an object.\n *\n * Will create a copy of an existing object such that any mutations\n * on the copy cannot affect the original.\n *\n * Only shallow objects are supported, passing a nested object to this\n * function will cause a TypeError.\n *\n * Objects with primitives, and arrays of primitives are supported.\n *\n * @param {Object} obj The object to clone.\n * @return {Object} a clone of the passed object.\n * @throws {TypeError} when a nested object is passed.\n * @memberOf Utils\n */\nlunr.utils.clone = function (obj) {\n if (obj === null || obj === undefined) {\n return obj\n }\n\n var clone = Object.create(null),\n keys = Object.keys(obj)\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i],\n val = obj[key]\n\n if (Array.isArray(val)) {\n clone[key] = val.slice()\n continue\n }\n\n if (typeof val === 'string' ||\n typeof val === 'number' ||\n typeof val === 'boolean') {\n clone[key] = val\n continue\n }\n\n throw new TypeError(\"clone is not deep and does not support nested objects\")\n }\n\n return clone\n}\nlunr.FieldRef = function (docRef, fieldName, stringValue) {\n this.docRef = docRef\n this.fieldName = fieldName\n this._stringValue = stringValue\n}\n\nlunr.FieldRef.joiner = \"/\"\n\nlunr.FieldRef.fromString = function (s) {\n var n = s.indexOf(lunr.FieldRef.joiner)\n\n if (n === -1) {\n throw \"malformed field ref string\"\n }\n\n var fieldRef = s.slice(0, n),\n docRef = s.slice(n + 1)\n\n return new lunr.FieldRef (docRef, fieldRef, s)\n}\n\nlunr.FieldRef.prototype.toString = function () {\n if (this._stringValue == undefined) {\n this._stringValue = this.fieldName + lunr.FieldRef.joiner + this.docRef\n }\n\n return this._stringValue\n}\n/*!\n * lunr.Set\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * A lunr set.\n *\n * @constructor\n */\nlunr.Set = function (elements) {\n this.elements = Object.create(null)\n\n if (elements) {\n this.length = elements.length\n\n for (var i = 0; i < this.length; i++) {\n this.elements[elements[i]] = true\n }\n } else {\n this.length = 0\n }\n}\n\n/**\n * A complete set that contains all elements.\n *\n * @static\n * @readonly\n * @type {lunr.Set}\n */\nlunr.Set.complete = {\n intersect: function (other) {\n return other\n },\n\n union: function () {\n return this\n },\n\n contains: function () {\n return true\n }\n}\n\n/**\n * An empty set that contains no elements.\n *\n * @static\n * @readonly\n * @type {lunr.Set}\n */\nlunr.Set.empty = {\n intersect: function () {\n return this\n },\n\n union: function (other) {\n return other\n },\n\n contains: function () {\n return false\n }\n}\n\n/**\n * Returns true if this set contains the specified object.\n *\n * @param {object} object - Object whose presence in this set is to be tested.\n * @returns {boolean} - True if this set contains the specified object.\n */\nlunr.Set.prototype.contains = function (object) {\n return !!this.elements[object]\n}\n\n/**\n * Returns a new set containing only the elements that are present in both\n * this set and the specified set.\n *\n * @param {lunr.Set} other - set to intersect with this set.\n * @returns {lunr.Set} a new set that is the intersection of this and the specified set.\n */\n\nlunr.Set.prototype.intersect = function (other) {\n var a, b, elements, intersection = []\n\n if (other === lunr.Set.complete) {\n return this\n }\n\n if (other === lunr.Set.empty) {\n return other\n }\n\n if (this.length < other.length) {\n a = this\n b = other\n } else {\n a = other\n b = this\n }\n\n elements = Object.keys(a.elements)\n\n for (var i = 0; i < elements.length; i++) {\n var element = elements[i]\n if (element in b.elements) {\n intersection.push(element)\n }\n }\n\n return new lunr.Set (intersection)\n}\n\n/**\n * Returns a new set combining the elements of this and the specified set.\n *\n * @param {lunr.Set} other - set to union with this set.\n * @return {lunr.Set} a new set that is the union of this and the specified set.\n */\n\nlunr.Set.prototype.union = function (other) {\n if (other === lunr.Set.complete) {\n return lunr.Set.complete\n }\n\n if (other === lunr.Set.empty) {\n return this\n }\n\n return new lunr.Set(Object.keys(this.elements).concat(Object.keys(other.elements)))\n}\n/**\n * A function to calculate the inverse document frequency for\n * a posting. This is shared between the builder and the index\n *\n * @private\n * @param {object} posting - The posting for a given term\n * @param {number} documentCount - The total number of documents.\n */\nlunr.idf = function (posting, documentCount) {\n var documentsWithTerm = 0\n\n for (var fieldName in posting) {\n if (fieldName == '_index') continue // Ignore the term index, its not a field\n documentsWithTerm += Object.keys(posting[fieldName]).length\n }\n\n var x = (documentCount - documentsWithTerm + 0.5) / (documentsWithTerm + 0.5)\n\n return Math.log(1 + Math.abs(x))\n}\n\n/**\n * A token wraps a string representation of a token\n * as it is passed through the text processing pipeline.\n *\n * @constructor\n * @param {string} [str=''] - The string token being wrapped.\n * @param {object} [metadata={}] - Metadata associated with this token.\n */\nlunr.Token = function (str, metadata) {\n this.str = str || \"\"\n this.metadata = metadata || {}\n}\n\n/**\n * Returns the token string that is being wrapped by this object.\n *\n * @returns {string}\n */\nlunr.Token.prototype.toString = function () {\n return this.str\n}\n\n/**\n * A token update function is used when updating or optionally\n * when cloning a token.\n *\n * @callback lunr.Token~updateFunction\n * @param {string} str - The string representation of the token.\n * @param {Object} metadata - All metadata associated with this token.\n */\n\n/**\n * Applies the given function to the wrapped string token.\n *\n * @example\n * token.update(function (str, metadata) {\n * return str.toUpperCase()\n * })\n *\n * @param {lunr.Token~updateFunction} fn - A function to apply to the token string.\n * @returns {lunr.Token}\n */\nlunr.Token.prototype.update = function (fn) {\n this.str = fn(this.str, this.metadata)\n return this\n}\n\n/**\n * Creates a clone of this token. Optionally a function can be\n * applied to the cloned token.\n *\n * @param {lunr.Token~updateFunction} [fn] - An optional function to apply to the cloned token.\n * @returns {lunr.Token}\n */\nlunr.Token.prototype.clone = function (fn) {\n fn = fn || function (s) { return s }\n return new lunr.Token (fn(this.str, this.metadata), this.metadata)\n}\n/*!\n * lunr.tokenizer\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * A function for splitting a string into tokens ready to be inserted into\n * the search index. Uses `lunr.tokenizer.separator` to split strings, change\n * the value of this property to change how strings are split into tokens.\n *\n * This tokenizer will convert its parameter to a string by calling `toString` and\n * then will split this string on the character in `lunr.tokenizer.separator`.\n * Arrays will have their elements converted to strings and wrapped in a lunr.Token.\n *\n * Optional metadata can be passed to the tokenizer, this metadata will be cloned and\n * added as metadata to every token that is created from the object to be tokenized.\n *\n * @static\n * @param {?(string|object|object[])} obj - The object to convert into tokens\n * @param {?object} metadata - Optional metadata to associate with every token\n * @returns {lunr.Token[]}\n * @see {@link lunr.Pipeline}\n */\nlunr.tokenizer = function (obj, metadata) {\n if (obj == null || obj == undefined) {\n return []\n }\n\n if (Array.isArray(obj)) {\n return obj.map(function (t) {\n return new lunr.Token(\n lunr.utils.asString(t).toLowerCase(),\n lunr.utils.clone(metadata)\n )\n })\n }\n\n var str = obj.toString().toLowerCase(),\n len = str.length,\n tokens = []\n\n for (var sliceEnd = 0, sliceStart = 0; sliceEnd <= len; sliceEnd++) {\n var char = str.charAt(sliceEnd),\n sliceLength = sliceEnd - sliceStart\n\n if ((char.match(lunr.tokenizer.separator) || sliceEnd == len)) {\n\n if (sliceLength > 0) {\n var tokenMetadata = lunr.utils.clone(metadata) || {}\n tokenMetadata[\"position\"] = [sliceStart, sliceLength]\n tokenMetadata[\"index\"] = tokens.length\n\n tokens.push(\n new lunr.Token (\n str.slice(sliceStart, sliceEnd),\n tokenMetadata\n )\n )\n }\n\n sliceStart = sliceEnd + 1\n }\n\n }\n\n return tokens\n}\n\n/**\n * The separator used to split a string into tokens. Override this property to change the behaviour of\n * `lunr.tokenizer` behaviour when tokenizing strings. By default this splits on whitespace and hyphens.\n *\n * @static\n * @see lunr.tokenizer\n */\nlunr.tokenizer.separator = /[\\s\\-]+/\n/*!\n * lunr.Pipeline\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * lunr.Pipelines maintain an ordered list of functions to be applied to all\n * tokens in documents entering the search index and queries being ran against\n * the index.\n *\n * An instance of lunr.Index created with the lunr shortcut will contain a\n * pipeline with a stop word filter and an English language stemmer. Extra\n * functions can be added before or after either of these functions or these\n * default functions can be removed.\n *\n * When run the pipeline will call each function in turn, passing a token, the\n * index of that token in the original list of all tokens and finally a list of\n * all the original tokens.\n *\n * The output of functions in the pipeline will be passed to the next function\n * in the pipeline. To exclude a token from entering the index the function\n * should return undefined, the rest of the pipeline will not be called with\n * this token.\n *\n * For serialisation of pipelines to work, all functions used in an instance of\n * a pipeline should be registered with lunr.Pipeline. Registered functions can\n * then be loaded. If trying to load a serialised pipeline that uses functions\n * that are not registered an error will be thrown.\n *\n * If not planning on serialising the pipeline then registering pipeline functions\n * is not necessary.\n *\n * @constructor\n */\nlunr.Pipeline = function () {\n this._stack = []\n}\n\nlunr.Pipeline.registeredFunctions = Object.create(null)\n\n/**\n * A pipeline function maps lunr.Token to lunr.Token. A lunr.Token contains the token\n * string as well as all known metadata. A pipeline function can mutate the token string\n * or mutate (or add) metadata for a given token.\n *\n * A pipeline function can indicate that the passed token should be discarded by returning\n * null, undefined or an empty string. This token will not be passed to any downstream pipeline\n * functions and will not be added to the index.\n *\n * Multiple tokens can be returned by returning an array of tokens. Each token will be passed\n * to any downstream pipeline functions and all will returned tokens will be added to the index.\n *\n * Any number of pipeline functions may be chained together using a lunr.Pipeline.\n *\n * @interface lunr.PipelineFunction\n * @param {lunr.Token} token - A token from the document being processed.\n * @param {number} i - The index of this token in the complete list of tokens for this document/field.\n * @param {lunr.Token[]} tokens - All tokens for this document/field.\n * @returns {(?lunr.Token|lunr.Token[])}\n */\n\n/**\n * Register a function with the pipeline.\n *\n * Functions that are used in the pipeline should be registered if the pipeline\n * needs to be serialised, or a serialised pipeline needs to be loaded.\n *\n * Registering a function does not add it to a pipeline, functions must still be\n * added to instances of the pipeline for them to be used when running a pipeline.\n *\n * @param {lunr.PipelineFunction} fn - The function to check for.\n * @param {String} label - The label to register this function with\n */\nlunr.Pipeline.registerFunction = function (fn, label) {\n if (label in this.registeredFunctions) {\n lunr.utils.warn('Overwriting existing registered function: ' + label)\n }\n\n fn.label = label\n lunr.Pipeline.registeredFunctions[fn.label] = fn\n}\n\n/**\n * Warns if the function is not registered as a Pipeline function.\n *\n * @param {lunr.PipelineFunction} fn - The function to check for.\n * @private\n */\nlunr.Pipeline.warnIfFunctionNotRegistered = function (fn) {\n var isRegistered = fn.label && (fn.label in this.registeredFunctions)\n\n if (!isRegistered) {\n lunr.utils.warn('Function is not registered with pipeline. This may cause problems when serialising the index.\\n', fn)\n }\n}\n\n/**\n * Loads a previously serialised pipeline.\n *\n * All functions to be loaded must already be registered with lunr.Pipeline.\n * If any function from the serialised data has not been registered then an\n * error will be thrown.\n *\n * @param {Object} serialised - The serialised pipeline to load.\n * @returns {lunr.Pipeline}\n */\nlunr.Pipeline.load = function (serialised) {\n var pipeline = new lunr.Pipeline\n\n serialised.forEach(function (fnName) {\n var fn = lunr.Pipeline.registeredFunctions[fnName]\n\n if (fn) {\n pipeline.add(fn)\n } else {\n throw new Error('Cannot load unregistered function: ' + fnName)\n }\n })\n\n return pipeline\n}\n\n/**\n * Adds new functions to the end of the pipeline.\n *\n * Logs a warning if the function has not been registered.\n *\n * @param {lunr.PipelineFunction[]} functions - Any number of functions to add to the pipeline.\n */\nlunr.Pipeline.prototype.add = function () {\n var fns = Array.prototype.slice.call(arguments)\n\n fns.forEach(function (fn) {\n lunr.Pipeline.warnIfFunctionNotRegistered(fn)\n this._stack.push(fn)\n }, this)\n}\n\n/**\n * Adds a single function after a function that already exists in the\n * pipeline.\n *\n * Logs a warning if the function has not been registered.\n *\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\n */\nlunr.Pipeline.prototype.after = function (existingFn, newFn) {\n lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\n\n var pos = this._stack.indexOf(existingFn)\n if (pos == -1) {\n throw new Error('Cannot find existingFn')\n }\n\n pos = pos + 1\n this._stack.splice(pos, 0, newFn)\n}\n\n/**\n * Adds a single function before a function that already exists in the\n * pipeline.\n *\n * Logs a warning if the function has not been registered.\n *\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\n */\nlunr.Pipeline.prototype.before = function (existingFn, newFn) {\n lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\n\n var pos = this._stack.indexOf(existingFn)\n if (pos == -1) {\n throw new Error('Cannot find existingFn')\n }\n\n this._stack.splice(pos, 0, newFn)\n}\n\n/**\n * Removes a function from the pipeline.\n *\n * @param {lunr.PipelineFunction} fn The function to remove from the pipeline.\n */\nlunr.Pipeline.prototype.remove = function (fn) {\n var pos = this._stack.indexOf(fn)\n if (pos == -1) {\n return\n }\n\n this._stack.splice(pos, 1)\n}\n\n/**\n * Runs the current list of functions that make up the pipeline against the\n * passed tokens.\n *\n * @param {Array} tokens The tokens to run through the pipeline.\n * @returns {Array}\n */\nlunr.Pipeline.prototype.run = function (tokens) {\n var stackLength = this._stack.length\n\n for (var i = 0; i < stackLength; i++) {\n var fn = this._stack[i]\n var memo = []\n\n for (var j = 0; j < tokens.length; j++) {\n var result = fn(tokens[j], j, tokens)\n\n if (result === null || result === void 0 || result === '') continue\n\n if (Array.isArray(result)) {\n for (var k = 0; k < result.length; k++) {\n memo.push(result[k])\n }\n } else {\n memo.push(result)\n }\n }\n\n tokens = memo\n }\n\n return tokens\n}\n\n/**\n * Convenience method for passing a string through a pipeline and getting\n * strings out. This method takes care of wrapping the passed string in a\n * token and mapping the resulting tokens back to strings.\n *\n * @param {string} str - The string to pass through the pipeline.\n * @param {?object} metadata - Optional metadata to associate with the token\n * passed to the pipeline.\n * @returns {string[]}\n */\nlunr.Pipeline.prototype.runString = function (str, metadata) {\n var token = new lunr.Token (str, metadata)\n\n return this.run([token]).map(function (t) {\n return t.toString()\n })\n}\n\n/**\n * Resets the pipeline by removing any existing processors.\n *\n */\nlunr.Pipeline.prototype.reset = function () {\n this._stack = []\n}\n\n/**\n * Returns a representation of the pipeline ready for serialisation.\n *\n * Logs a warning if the function has not been registered.\n *\n * @returns {Array}\n */\nlunr.Pipeline.prototype.toJSON = function () {\n return this._stack.map(function (fn) {\n lunr.Pipeline.warnIfFunctionNotRegistered(fn)\n\n return fn.label\n })\n}\n/*!\n * lunr.Vector\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * A vector is used to construct the vector space of documents and queries. These\n * vectors support operations to determine the similarity between two documents or\n * a document and a query.\n *\n * Normally no parameters are required for initializing a vector, but in the case of\n * loading a previously dumped vector the raw elements can be provided to the constructor.\n *\n * For performance reasons vectors are implemented with a flat array, where an elements\n * index is immediately followed by its value. E.g. [index, value, index, value]. This\n * allows the underlying array to be as sparse as possible and still offer decent\n * performance when being used for vector calculations.\n *\n * @constructor\n * @param {Number[]} [elements] - The flat list of element index and element value pairs.\n */\nlunr.Vector = function (elements) {\n this._magnitude = 0\n this.elements = elements || []\n}\n\n\n/**\n * Calculates the position within the vector to insert a given index.\n *\n * This is used internally by insert and upsert. If there are duplicate indexes then\n * the position is returned as if the value for that index were to be updated, but it\n * is the callers responsibility to check whether there is a duplicate at that index\n *\n * @param {Number} insertIdx - The index at which the element should be inserted.\n * @returns {Number}\n */\nlunr.Vector.prototype.positionForIndex = function (index) {\n // For an empty vector the tuple can be inserted at the beginning\n if (this.elements.length == 0) {\n return 0\n }\n\n var start = 0,\n end = this.elements.length / 2,\n sliceLength = end - start,\n pivotPoint = Math.floor(sliceLength / 2),\n pivotIndex = this.elements[pivotPoint * 2]\n\n while (sliceLength > 1) {\n if (pivotIndex < index) {\n start = pivotPoint\n }\n\n if (pivotIndex > index) {\n end = pivotPoint\n }\n\n if (pivotIndex == index) {\n break\n }\n\n sliceLength = end - start\n pivotPoint = start + Math.floor(sliceLength / 2)\n pivotIndex = this.elements[pivotPoint * 2]\n }\n\n if (pivotIndex == index) {\n return pivotPoint * 2\n }\n\n if (pivotIndex > index) {\n return pivotPoint * 2\n }\n\n if (pivotIndex < index) {\n return (pivotPoint + 1) * 2\n }\n}\n\n/**\n * Inserts an element at an index within the vector.\n *\n * Does not allow duplicates, will throw an error if there is already an entry\n * for this index.\n *\n * @param {Number} insertIdx - The index at which the element should be inserted.\n * @param {Number} val - The value to be inserted into the vector.\n */\nlunr.Vector.prototype.insert = function (insertIdx, val) {\n this.upsert(insertIdx, val, function () {\n throw \"duplicate index\"\n })\n}\n\n/**\n * Inserts or updates an existing index within the vector.\n *\n * @param {Number} insertIdx - The index at which the element should be inserted.\n * @param {Number} val - The value to be inserted into the vector.\n * @param {function} fn - A function that is called for updates, the existing value and the\n * requested value are passed as arguments\n */\nlunr.Vector.prototype.upsert = function (insertIdx, val, fn) {\n this._magnitude = 0\n var position = this.positionForIndex(insertIdx)\n\n if (this.elements[position] == insertIdx) {\n this.elements[position + 1] = fn(this.elements[position + 1], val)\n } else {\n this.elements.splice(position, 0, insertIdx, val)\n }\n}\n\n/**\n * Calculates the magnitude of this vector.\n *\n * @returns {Number}\n */\nlunr.Vector.prototype.magnitude = function () {\n if (this._magnitude) return this._magnitude\n\n var sumOfSquares = 0,\n elementsLength = this.elements.length\n\n for (var i = 1; i < elementsLength; i += 2) {\n var val = this.elements[i]\n sumOfSquares += val * val\n }\n\n return this._magnitude = Math.sqrt(sumOfSquares)\n}\n\n/**\n * Calculates the dot product of this vector and another vector.\n *\n * @param {lunr.Vector} otherVector - The vector to compute the dot product with.\n * @returns {Number}\n */\nlunr.Vector.prototype.dot = function (otherVector) {\n var dotProduct = 0,\n a = this.elements, b = otherVector.elements,\n aLen = a.length, bLen = b.length,\n aVal = 0, bVal = 0,\n i = 0, j = 0\n\n while (i < aLen && j < bLen) {\n aVal = a[i], bVal = b[j]\n if (aVal < bVal) {\n i += 2\n } else if (aVal > bVal) {\n j += 2\n } else if (aVal == bVal) {\n dotProduct += a[i + 1] * b[j + 1]\n i += 2\n j += 2\n }\n }\n\n return dotProduct\n}\n\n/**\n * Calculates the similarity between this vector and another vector.\n *\n * @param {lunr.Vector} otherVector - The other vector to calculate the\n * similarity with.\n * @returns {Number}\n */\nlunr.Vector.prototype.similarity = function (otherVector) {\n return this.dot(otherVector) / this.magnitude() || 0\n}\n\n/**\n * Converts the vector to an array of the elements within the vector.\n *\n * @returns {Number[]}\n */\nlunr.Vector.prototype.toArray = function () {\n var output = new Array (this.elements.length / 2)\n\n for (var i = 1, j = 0; i < this.elements.length; i += 2, j++) {\n output[j] = this.elements[i]\n }\n\n return output\n}\n\n/**\n * A JSON serializable representation of the vector.\n *\n * @returns {Number[]}\n */\nlunr.Vector.prototype.toJSON = function () {\n return this.elements\n}\n/* eslint-disable */\n/*!\n * lunr.stemmer\n * Copyright (C) 2020 Oliver Nightingale\n * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt\n */\n\n/**\n * lunr.stemmer is an english language stemmer, this is a JavaScript\n * implementation of the PorterStemmer taken from http://tartarus.org/~martin\n *\n * @static\n * @implements {lunr.PipelineFunction}\n * @param {lunr.Token} token - The string to stem\n * @returns {lunr.Token}\n * @see {@link lunr.Pipeline}\n * @function\n */\nlunr.stemmer = (function(){\n var step2list = {\n \"ational\" : \"ate\",\n \"tional\" : \"tion\",\n \"enci\" : \"ence\",\n \"anci\" : \"ance\",\n \"izer\" : \"ize\",\n \"bli\" : \"ble\",\n \"alli\" : \"al\",\n \"entli\" : \"ent\",\n \"eli\" : \"e\",\n \"ousli\" : \"ous\",\n \"ization\" : \"ize\",\n \"ation\" : \"ate\",\n \"ator\" : \"ate\",\n \"alism\" : \"al\",\n \"iveness\" : \"ive\",\n \"fulness\" : \"ful\",\n \"ousness\" : \"ous\",\n \"aliti\" : \"al\",\n \"iviti\" : \"ive\",\n \"biliti\" : \"ble\",\n \"logi\" : \"log\"\n },\n\n step3list = {\n \"icate\" : \"ic\",\n \"ative\" : \"\",\n \"alize\" : \"al\",\n \"iciti\" : \"ic\",\n \"ical\" : \"ic\",\n \"ful\" : \"\",\n \"ness\" : \"\"\n },\n\n c = \"[^aeiou]\", // consonant\n v = \"[aeiouy]\", // vowel\n C = c + \"[^aeiouy]*\", // consonant sequence\n V = v + \"[aeiou]*\", // vowel sequence\n\n mgr0 = \"^(\" + C + \")?\" + V + C, // [C]VC... is m>0\n meq1 = \"^(\" + C + \")?\" + V + C + \"(\" + V + \")?$\", // [C]VC[V] is m=1\n mgr1 = \"^(\" + C + \")?\" + V + C + V + C, // [C]VCVC... is m>1\n s_v = \"^(\" + C + \")?\" + v; // vowel in stem\n\n var re_mgr0 = new RegExp(mgr0);\n var re_mgr1 = new RegExp(mgr1);\n var re_meq1 = new RegExp(meq1);\n var re_s_v = new RegExp(s_v);\n\n var re_1a = /^(.+?)(ss|i)es$/;\n var re2_1a = /^(.+?)([^s])s$/;\n var re_1b = /^(.+?)eed$/;\n var re2_1b = /^(.+?)(ed|ing)$/;\n var re_1b_2 = /.$/;\n var re2_1b_2 = /(at|bl|iz)$/;\n var re3_1b_2 = new RegExp(\"([^aeiouylsz])\\\\1$\");\n var re4_1b_2 = new RegExp(\"^\" + C + v + \"[^aeiouwxy]$\");\n\n var re_1c = /^(.+?[^aeiou])y$/;\n var re_2 = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;\n\n var re_3 = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;\n\n var re_4 = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;\n var re2_4 = /^(.+?)(s|t)(ion)$/;\n\n var re_5 = /^(.+?)e$/;\n var re_5_1 = /ll$/;\n var re3_5 = new RegExp(\"^\" + C + v + \"[^aeiouwxy]$\");\n\n var porterStemmer = function porterStemmer(w) {\n var stem,\n suffix,\n firstch,\n re,\n re2,\n re3,\n re4;\n\n if (w.length < 3) { return w; }\n\n firstch = w.substr(0,1);\n if (firstch == \"y\") {\n w = firstch.toUpperCase() + w.substr(1);\n }\n\n // Step 1a\n re = re_1a\n re2 = re2_1a;\n\n if (re.test(w)) { w = w.replace(re,\"$1$2\"); }\n else if (re2.test(w)) { w = w.replace(re2,\"$1$2\"); }\n\n // Step 1b\n re = re_1b;\n re2 = re2_1b;\n if (re.test(w)) {\n var fp = re.exec(w);\n re = re_mgr0;\n if (re.test(fp[1])) {\n re = re_1b_2;\n w = w.replace(re,\"\");\n }\n } else if (re2.test(w)) {\n var fp = re2.exec(w);\n stem = fp[1];\n re2 = re_s_v;\n if (re2.test(stem)) {\n w = stem;\n re2 = re2_1b_2;\n re3 = re3_1b_2;\n re4 = re4_1b_2;\n if (re2.test(w)) { w = w + \"e\"; }\n else if (re3.test(w)) { re = re_1b_2; w = w.replace(re,\"\"); }\n else if (re4.test(w)) { w = w + \"e\"; }\n }\n }\n\n // Step 1c - replace suffix y or Y by i if preceded by a non-vowel which is not the first letter of the word (so cry -> cri, by -> by, say -> say)\n re = re_1c;\n if (re.test(w)) {\n var fp = re.exec(w);\n stem = fp[1];\n w = stem + \"i\";\n }\n\n // Step 2\n re = re_2;\n if (re.test(w)) {\n var fp = re.exec(w);\n stem = fp[1];\n suffix = fp[2];\n re = re_mgr0;\n if (re.test(stem)) {\n w = stem + step2list[suffix];\n }\n }\n\n // Step 3\n re = re_3;\n if (re.test(w)) {\n var fp = re.exec(w);\n stem = fp[1];\n suffix = fp[2];\n re = re_mgr0;\n if (re.test(stem)) {\n w = stem + step3list[suffix];\n }\n }\n\n // Step 4\n re = re_4;\n re2 = re2_4;\n if (re.test(w)) {\n var fp = re.exec(w);\n stem = fp[1];\n re = re_mgr1;\n if (re.test(stem)) {\n w = stem;\n }\n } else if (re2.test(w)) {\n var fp = re2.exec(w);\n stem = fp[1] + fp[2];\n re2 = re_mgr1;\n if (re2.test(stem)) {\n w = stem;\n }\n }\n\n // Step 5\n re = re_5;\n if (re.test(w)) {\n var fp = re.exec(w);\n stem = fp[1];\n re = re_mgr1;\n re2 = re_meq1;\n re3 = re3_5;\n if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) {\n w = stem;\n }\n }\n\n re = re_5_1;\n re2 = re_mgr1;\n if (re.test(w) && re2.test(w)) {\n re = re_1b_2;\n w = w.replace(re,\"\");\n }\n\n // and turn initial Y back to y\n\n if (firstch == \"y\") {\n w = firstch.toLowerCase() + w.substr(1);\n }\n\n return w;\n };\n\n return function (token) {\n return token.update(porterStemmer);\n }\n})();\n\nlunr.Pipeline.registerFunction(lunr.stemmer, 'stemmer')\n/*!\n * lunr.stopWordFilter\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * lunr.generateStopWordFilter builds a stopWordFilter function from the provided\n * list of stop words.\n *\n * The built in lunr.stopWordFilter is built using this generator and can be used\n * to generate custom stopWordFilters for applications or non English languages.\n *\n * @function\n * @param {Array} token The token to pass through the filter\n * @returns {lunr.PipelineFunction}\n * @see lunr.Pipeline\n * @see lunr.stopWordFilter\n */\nlunr.generateStopWordFilter = function (stopWords) {\n var words = stopWords.reduce(function (memo, stopWord) {\n memo[stopWord] = stopWord\n return memo\n }, {})\n\n return function (token) {\n if (token && words[token.toString()] !== token.toString()) return token\n }\n}\n\n/**\n * lunr.stopWordFilter is an English language stop word list filter, any words\n * contained in the list will not be passed through the filter.\n *\n * This is intended to be used in the Pipeline. If the token does not pass the\n * filter then undefined will be returned.\n *\n * @function\n * @implements {lunr.PipelineFunction}\n * @params {lunr.Token} token - A token to check for being a stop word.\n * @returns {lunr.Token}\n * @see {@link lunr.Pipeline}\n */\nlunr.stopWordFilter = lunr.generateStopWordFilter([\n 'a',\n 'able',\n 'about',\n 'across',\n 'after',\n 'all',\n 'almost',\n 'also',\n 'am',\n 'among',\n 'an',\n 'and',\n 'any',\n 'are',\n 'as',\n 'at',\n 'be',\n 'because',\n 'been',\n 'but',\n 'by',\n 'can',\n 'cannot',\n 'could',\n 'dear',\n 'did',\n 'do',\n 'does',\n 'either',\n 'else',\n 'ever',\n 'every',\n 'for',\n 'from',\n 'get',\n 'got',\n 'had',\n 'has',\n 'have',\n 'he',\n 'her',\n 'hers',\n 'him',\n 'his',\n 'how',\n 'however',\n 'i',\n 'if',\n 'in',\n 'into',\n 'is',\n 'it',\n 'its',\n 'just',\n 'least',\n 'let',\n 'like',\n 'likely',\n 'may',\n 'me',\n 'might',\n 'most',\n 'must',\n 'my',\n 'neither',\n 'no',\n 'nor',\n 'not',\n 'of',\n 'off',\n 'often',\n 'on',\n 'only',\n 'or',\n 'other',\n 'our',\n 'own',\n 'rather',\n 'said',\n 'say',\n 'says',\n 'she',\n 'should',\n 'since',\n 'so',\n 'some',\n 'than',\n 'that',\n 'the',\n 'their',\n 'them',\n 'then',\n 'there',\n 'these',\n 'they',\n 'this',\n 'tis',\n 'to',\n 'too',\n 'twas',\n 'us',\n 'wants',\n 'was',\n 'we',\n 'were',\n 'what',\n 'when',\n 'where',\n 'which',\n 'while',\n 'who',\n 'whom',\n 'why',\n 'will',\n 'with',\n 'would',\n 'yet',\n 'you',\n 'your'\n])\n\nlunr.Pipeline.registerFunction(lunr.stopWordFilter, 'stopWordFilter')\n/*!\n * lunr.trimmer\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * lunr.trimmer is a pipeline function for trimming non word\n * characters from the beginning and end of tokens before they\n * enter the index.\n *\n * This implementation may not work correctly for non latin\n * characters and should either be removed or adapted for use\n * with languages with non-latin characters.\n *\n * @static\n * @implements {lunr.PipelineFunction}\n * @param {lunr.Token} token The token to pass through the filter\n * @returns {lunr.Token}\n * @see lunr.Pipeline\n */\nlunr.trimmer = function (token) {\n return token.update(function (s) {\n return s.replace(/^\\W+/, '').replace(/\\W+$/, '')\n })\n}\n\nlunr.Pipeline.registerFunction(lunr.trimmer, 'trimmer')\n/*!\n * lunr.TokenSet\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * A token set is used to store the unique list of all tokens\n * within an index. Token sets are also used to represent an\n * incoming query to the index, this query token set and index\n * token set are then intersected to find which tokens to look\n * up in the inverted index.\n *\n * A token set can hold multiple tokens, as in the case of the\n * index token set, or it can hold a single token as in the\n * case of a simple query token set.\n *\n * Additionally token sets are used to perform wildcard matching.\n * Leading, contained and trailing wildcards are supported, and\n * from this edit distance matching can also be provided.\n *\n * Token sets are implemented as a minimal finite state automata,\n * where both common prefixes and suffixes are shared between tokens.\n * This helps to reduce the space used for storing the token set.\n *\n * @constructor\n */\nlunr.TokenSet = function () {\n this.final = false\n this.edges = {}\n this.id = lunr.TokenSet._nextId\n lunr.TokenSet._nextId += 1\n}\n\n/**\n * Keeps track of the next, auto increment, identifier to assign\n * to a new tokenSet.\n *\n * TokenSets require a unique identifier to be correctly minimised.\n *\n * @private\n */\nlunr.TokenSet._nextId = 1\n\n/**\n * Creates a TokenSet instance from the given sorted array of words.\n *\n * @param {String[]} arr - A sorted array of strings to create the set from.\n * @returns {lunr.TokenSet}\n * @throws Will throw an error if the input array is not sorted.\n */\nlunr.TokenSet.fromArray = function (arr) {\n var builder = new lunr.TokenSet.Builder\n\n for (var i = 0, len = arr.length; i < len; i++) {\n builder.insert(arr[i])\n }\n\n builder.finish()\n return builder.root\n}\n\n/**\n * Creates a token set from a query clause.\n *\n * @private\n * @param {Object} clause - A single clause from lunr.Query.\n * @param {string} clause.term - The query clause term.\n * @param {number} [clause.editDistance] - The optional edit distance for the term.\n * @returns {lunr.TokenSet}\n */\nlunr.TokenSet.fromClause = function (clause) {\n if ('editDistance' in clause) {\n return lunr.TokenSet.fromFuzzyString(clause.term, clause.editDistance)\n } else {\n return lunr.TokenSet.fromString(clause.term)\n }\n}\n\n/**\n * Creates a token set representing a single string with a specified\n * edit distance.\n *\n * Insertions, deletions, substitutions and transpositions are each\n * treated as an edit distance of 1.\n *\n * Increasing the allowed edit distance will have a dramatic impact\n * on the performance of both creating and intersecting these TokenSets.\n * It is advised to keep the edit distance less than 3.\n *\n * @param {string} str - The string to create the token set from.\n * @param {number} editDistance - The allowed edit distance to match.\n * @returns {lunr.Vector}\n */\nlunr.TokenSet.fromFuzzyString = function (str, editDistance) {\n var root = new lunr.TokenSet\n\n var stack = [{\n node: root,\n editsRemaining: editDistance,\n str: str\n }]\n\n while (stack.length) {\n var frame = stack.pop()\n\n // no edit\n if (frame.str.length > 0) {\n var char = frame.str.charAt(0),\n noEditNode\n\n if (char in frame.node.edges) {\n noEditNode = frame.node.edges[char]\n } else {\n noEditNode = new lunr.TokenSet\n frame.node.edges[char] = noEditNode\n }\n\n if (frame.str.length == 1) {\n noEditNode.final = true\n }\n\n stack.push({\n node: noEditNode,\n editsRemaining: frame.editsRemaining,\n str: frame.str.slice(1)\n })\n }\n\n if (frame.editsRemaining == 0) {\n continue\n }\n\n // insertion\n if (\"*\" in frame.node.edges) {\n var insertionNode = frame.node.edges[\"*\"]\n } else {\n var insertionNode = new lunr.TokenSet\n frame.node.edges[\"*\"] = insertionNode\n }\n\n if (frame.str.length == 0) {\n insertionNode.final = true\n }\n\n stack.push({\n node: insertionNode,\n editsRemaining: frame.editsRemaining - 1,\n str: frame.str\n })\n\n // deletion\n // can only do a deletion if we have enough edits remaining\n // and if there are characters left to delete in the string\n if (frame.str.length > 1) {\n stack.push({\n node: frame.node,\n editsRemaining: frame.editsRemaining - 1,\n str: frame.str.slice(1)\n })\n }\n\n // deletion\n // just removing the last character from the str\n if (frame.str.length == 1) {\n frame.node.final = true\n }\n\n // substitution\n // can only do a substitution if we have enough edits remaining\n // and if there are characters left to substitute\n if (frame.str.length >= 1) {\n if (\"*\" in frame.node.edges) {\n var substitutionNode = frame.node.edges[\"*\"]\n } else {\n var substitutionNode = new lunr.TokenSet\n frame.node.edges[\"*\"] = substitutionNode\n }\n\n if (frame.str.length == 1) {\n substitutionNode.final = true\n }\n\n stack.push({\n node: substitutionNode,\n editsRemaining: frame.editsRemaining - 1,\n str: frame.str.slice(1)\n })\n }\n\n // transposition\n // can only do a transposition if there are edits remaining\n // and there are enough characters to transpose\n if (frame.str.length > 1) {\n var charA = frame.str.charAt(0),\n charB = frame.str.charAt(1),\n transposeNode\n\n if (charB in frame.node.edges) {\n transposeNode = frame.node.edges[charB]\n } else {\n transposeNode = new lunr.TokenSet\n frame.node.edges[charB] = transposeNode\n }\n\n if (frame.str.length == 1) {\n transposeNode.final = true\n }\n\n stack.push({\n node: transposeNode,\n editsRemaining: frame.editsRemaining - 1,\n str: charA + frame.str.slice(2)\n })\n }\n }\n\n return root\n}\n\n/**\n * Creates a TokenSet from a string.\n *\n * The string may contain one or more wildcard characters (*)\n * that will allow wildcard matching when intersecting with\n * another TokenSet.\n *\n * @param {string} str - The string to create a TokenSet from.\n * @returns {lunr.TokenSet}\n */\nlunr.TokenSet.fromString = function (str) {\n var node = new lunr.TokenSet,\n root = node\n\n /*\n * Iterates through all characters within the passed string\n * appending a node for each character.\n *\n * When a wildcard character is found then a self\n * referencing edge is introduced to continually match\n * any number of any characters.\n */\n for (var i = 0, len = str.length; i < len; i++) {\n var char = str[i],\n final = (i == len - 1)\n\n if (char == \"*\") {\n node.edges[char] = node\n node.final = final\n\n } else {\n var next = new lunr.TokenSet\n next.final = final\n\n node.edges[char] = next\n node = next\n }\n }\n\n return root\n}\n\n/**\n * Converts this TokenSet into an array of strings\n * contained within the TokenSet.\n *\n * This is not intended to be used on a TokenSet that\n * contains wildcards, in these cases the results are\n * undefined and are likely to cause an infinite loop.\n *\n * @returns {string[]}\n */\nlunr.TokenSet.prototype.toArray = function () {\n var words = []\n\n var stack = [{\n prefix: \"\",\n node: this\n }]\n\n while (stack.length) {\n var frame = stack.pop(),\n edges = Object.keys(frame.node.edges),\n len = edges.length\n\n if (frame.node.final) {\n /* In Safari, at this point the prefix is sometimes corrupted, see:\n * https://github.com/olivernn/lunr.js/issues/279 Calling any\n * String.prototype method forces Safari to \"cast\" this string to what\n * it's supposed to be, fixing the bug. */\n frame.prefix.charAt(0)\n words.push(frame.prefix)\n }\n\n for (var i = 0; i < len; i++) {\n var edge = edges[i]\n\n stack.push({\n prefix: frame.prefix.concat(edge),\n node: frame.node.edges[edge]\n })\n }\n }\n\n return words\n}\n\n/**\n * Generates a string representation of a TokenSet.\n *\n * This is intended to allow TokenSets to be used as keys\n * in objects, largely to aid the construction and minimisation\n * of a TokenSet. As such it is not designed to be a human\n * friendly representation of the TokenSet.\n *\n * @returns {string}\n */\nlunr.TokenSet.prototype.toString = function () {\n // NOTE: Using Object.keys here as this.edges is very likely\n // to enter 'hash-mode' with many keys being added\n //\n // avoiding a for-in loop here as it leads to the function\n // being de-optimised (at least in V8). From some simple\n // benchmarks the performance is comparable, but allowing\n // V8 to optimize may mean easy performance wins in the future.\n\n if (this._str) {\n return this._str\n }\n\n var str = this.final ? '1' : '0',\n labels = Object.keys(this.edges).sort(),\n len = labels.length\n\n for (var i = 0; i < len; i++) {\n var label = labels[i],\n node = this.edges[label]\n\n str = str + label + node.id\n }\n\n return str\n}\n\n/**\n * Returns a new TokenSet that is the intersection of\n * this TokenSet and the passed TokenSet.\n *\n * This intersection will take into account any wildcards\n * contained within the TokenSet.\n *\n * @param {lunr.TokenSet} b - An other TokenSet to intersect with.\n * @returns {lunr.TokenSet}\n */\nlunr.TokenSet.prototype.intersect = function (b) {\n var output = new lunr.TokenSet,\n frame = undefined\n\n var stack = [{\n qNode: b,\n output: output,\n node: this\n }]\n\n while (stack.length) {\n frame = stack.pop()\n\n // NOTE: As with the #toString method, we are using\n // Object.keys and a for loop instead of a for-in loop\n // as both of these objects enter 'hash' mode, causing\n // the function to be de-optimised in V8\n var qEdges = Object.keys(frame.qNode.edges),\n qLen = qEdges.length,\n nEdges = Object.keys(frame.node.edges),\n nLen = nEdges.length\n\n for (var q = 0; q < qLen; q++) {\n var qEdge = qEdges[q]\n\n for (var n = 0; n < nLen; n++) {\n var nEdge = nEdges[n]\n\n if (nEdge == qEdge || qEdge == '*') {\n var node = frame.node.edges[nEdge],\n qNode = frame.qNode.edges[qEdge],\n final = node.final && qNode.final,\n next = undefined\n\n if (nEdge in frame.output.edges) {\n // an edge already exists for this character\n // no need to create a new node, just set the finality\n // bit unless this node is already final\n next = frame.output.edges[nEdge]\n next.final = next.final || final\n\n } else {\n // no edge exists yet, must create one\n // set the finality bit and insert it\n // into the output\n next = new lunr.TokenSet\n next.final = final\n frame.output.edges[nEdge] = next\n }\n\n stack.push({\n qNode: qNode,\n output: next,\n node: node\n })\n }\n }\n }\n }\n\n return output\n}\nlunr.TokenSet.Builder = function () {\n this.previousWord = \"\"\n this.root = new lunr.TokenSet\n this.uncheckedNodes = []\n this.minimizedNodes = {}\n}\n\nlunr.TokenSet.Builder.prototype.insert = function (word) {\n var node,\n commonPrefix = 0\n\n if (word < this.previousWord) {\n throw new Error (\"Out of order word insertion\")\n }\n\n for (var i = 0; i < word.length && i < this.previousWord.length; i++) {\n if (word[i] != this.previousWord[i]) break\n commonPrefix++\n }\n\n this.minimize(commonPrefix)\n\n if (this.uncheckedNodes.length == 0) {\n node = this.root\n } else {\n node = this.uncheckedNodes[this.uncheckedNodes.length - 1].child\n }\n\n for (var i = commonPrefix; i < word.length; i++) {\n var nextNode = new lunr.TokenSet,\n char = word[i]\n\n node.edges[char] = nextNode\n\n this.uncheckedNodes.push({\n parent: node,\n char: char,\n child: nextNode\n })\n\n node = nextNode\n }\n\n node.final = true\n this.previousWord = word\n}\n\nlunr.TokenSet.Builder.prototype.finish = function () {\n this.minimize(0)\n}\n\nlunr.TokenSet.Builder.prototype.minimize = function (downTo) {\n for (var i = this.uncheckedNodes.length - 1; i >= downTo; i--) {\n var node = this.uncheckedNodes[i],\n childKey = node.child.toString()\n\n if (childKey in this.minimizedNodes) {\n node.parent.edges[node.char] = this.minimizedNodes[childKey]\n } else {\n // Cache the key for this node since\n // we know it can't change anymore\n node.child._str = childKey\n\n this.minimizedNodes[childKey] = node.child\n }\n\n this.uncheckedNodes.pop()\n }\n}\n/*!\n * lunr.Index\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * An index contains the built index of all documents and provides a query interface\n * to the index.\n *\n * Usually instances of lunr.Index will not be created using this constructor, instead\n * lunr.Builder should be used to construct new indexes, or lunr.Index.load should be\n * used to load previously built and serialized indexes.\n *\n * @constructor\n * @param {Object} attrs - The attributes of the built search index.\n * @param {Object} attrs.invertedIndex - An index of term/field to document reference.\n * @param {Object} attrs.fieldVectors - Field vectors\n * @param {lunr.TokenSet} attrs.tokenSet - An set of all corpus tokens.\n * @param {string[]} attrs.fields - The names of indexed document fields.\n * @param {lunr.Pipeline} attrs.pipeline - The pipeline to use for search terms.\n */\nlunr.Index = function (attrs) {\n this.invertedIndex = attrs.invertedIndex\n this.fieldVectors = attrs.fieldVectors\n this.tokenSet = attrs.tokenSet\n this.fields = attrs.fields\n this.pipeline = attrs.pipeline\n}\n\n/**\n * A result contains details of a document matching a search query.\n * @typedef {Object} lunr.Index~Result\n * @property {string} ref - The reference of the document this result represents.\n * @property {number} score - A number between 0 and 1 representing how similar this document is to the query.\n * @property {lunr.MatchData} matchData - Contains metadata about this match including which term(s) caused the match.\n */\n\n/**\n * Although lunr provides the ability to create queries using lunr.Query, it also provides a simple\n * query language which itself is parsed into an instance of lunr.Query.\n *\n * For programmatically building queries it is advised to directly use lunr.Query, the query language\n * is best used for human entered text rather than program generated text.\n *\n * At its simplest queries can just be a single term, e.g. `hello`, multiple terms are also supported\n * and will be combined with OR, e.g `hello world` will match documents that contain either 'hello'\n * or 'world', though those that contain both will rank higher in the results.\n *\n * Wildcards can be included in terms to match one or more unspecified characters, these wildcards can\n * be inserted anywhere within the term, and more than one wildcard can exist in a single term. Adding\n * wildcards will increase the number of documents that will be found but can also have a negative\n * impact on query performance, especially with wildcards at the beginning of a term.\n *\n * Terms can be restricted to specific fields, e.g. `title:hello`, only documents with the term\n * hello in the title field will match this query. Using a field not present in the index will lead\n * to an error being thrown.\n *\n * Modifiers can also be added to terms, lunr supports edit distance and boost modifiers on terms. A term\n * boost will make documents matching that term score higher, e.g. `foo^5`. Edit distance is also supported\n * to provide fuzzy matching, e.g. 'hello~2' will match documents with hello with an edit distance of 2.\n * Avoid large values for edit distance to improve query performance.\n *\n * Each term also supports a presence modifier. By default a term's presence in document is optional, however\n * this can be changed to either required or prohibited. For a term's presence to be required in a document the\n * term should be prefixed with a '+', e.g. `+foo bar` is a search for documents that must contain 'foo' and\n * optionally contain 'bar'. Conversely a leading '-' sets the terms presence to prohibited, i.e. it must not\n * appear in a document, e.g. `-foo bar` is a search for documents that do not contain 'foo' but may contain 'bar'.\n *\n * To escape special characters the backslash character '\\' can be used, this allows searches to include\n * characters that would normally be considered modifiers, e.g. `foo\\~2` will search for a term \"foo~2\" instead\n * of attempting to apply a boost of 2 to the search term \"foo\".\n *\n * @typedef {string} lunr.Index~QueryString\n * @example Simple single term query\n * hello\n * @example Multiple term query\n * hello world\n * @example term scoped to a field\n * title:hello\n * @example term with a boost of 10\n * hello^10\n * @example term with an edit distance of 2\n * hello~2\n * @example terms with presence modifiers\n * -foo +bar baz\n */\n\n/**\n * Performs a search against the index using lunr query syntax.\n *\n * Results will be returned sorted by their score, the most relevant results\n * will be returned first. For details on how the score is calculated, please see\n * the {@link https://lunrjs.com/guides/searching.html#scoring|guide}.\n *\n * For more programmatic querying use lunr.Index#query.\n *\n * @param {lunr.Index~QueryString} queryString - A string containing a lunr query.\n * @throws {lunr.QueryParseError} If the passed query string cannot be parsed.\n * @returns {lunr.Index~Result[]}\n */\nlunr.Index.prototype.search = function (queryString) {\n return this.query(function (query) {\n var parser = new lunr.QueryParser(queryString, query)\n parser.parse()\n })\n}\n\n/**\n * A query builder callback provides a query object to be used to express\n * the query to perform on the index.\n *\n * @callback lunr.Index~queryBuilder\n * @param {lunr.Query} query - The query object to build up.\n * @this lunr.Query\n */\n\n/**\n * Performs a query against the index using the yielded lunr.Query object.\n *\n * If performing programmatic queries against the index, this method is preferred\n * over lunr.Index#search so as to avoid the additional query parsing overhead.\n *\n * A query object is yielded to the supplied function which should be used to\n * express the query to be run against the index.\n *\n * Note that although this function takes a callback parameter it is _not_ an\n * asynchronous operation, the callback is just yielded a query object to be\n * customized.\n *\n * @param {lunr.Index~queryBuilder} fn - A function that is used to build the query.\n * @returns {lunr.Index~Result[]}\n */\nlunr.Index.prototype.query = function (fn) {\n // for each query clause\n // * process terms\n // * expand terms from token set\n // * find matching documents and metadata\n // * get document vectors\n // * score documents\n\n var query = new lunr.Query(this.fields),\n matchingFields = Object.create(null),\n queryVectors = Object.create(null),\n termFieldCache = Object.create(null),\n requiredMatches = Object.create(null),\n prohibitedMatches = Object.create(null)\n\n /*\n * To support field level boosts a query vector is created per\n * field. An empty vector is eagerly created to support negated\n * queries.\n */\n for (var i = 0; i < this.fields.length; i++) {\n queryVectors[this.fields[i]] = new lunr.Vector\n }\n\n fn.call(query, query)\n\n for (var i = 0; i < query.clauses.length; i++) {\n /*\n * Unless the pipeline has been disabled for this term, which is\n * the case for terms with wildcards, we need to pass the clause\n * term through the search pipeline. A pipeline returns an array\n * of processed terms. Pipeline functions may expand the passed\n * term, which means we may end up performing multiple index lookups\n * for a single query term.\n */\n var clause = query.clauses[i],\n terms = null,\n clauseMatches = lunr.Set.empty\n\n if (clause.usePipeline) {\n terms = this.pipeline.runString(clause.term, {\n fields: clause.fields\n })\n } else {\n terms = [clause.term]\n }\n\n for (var m = 0; m < terms.length; m++) {\n var term = terms[m]\n\n /*\n * Each term returned from the pipeline needs to use the same query\n * clause object, e.g. the same boost and or edit distance. The\n * simplest way to do this is to re-use the clause object but mutate\n * its term property.\n */\n clause.term = term\n\n /*\n * From the term in the clause we create a token set which will then\n * be used to intersect the indexes token set to get a list of terms\n * to lookup in the inverted index\n */\n var termTokenSet = lunr.TokenSet.fromClause(clause),\n expandedTerms = this.tokenSet.intersect(termTokenSet).toArray()\n\n /*\n * If a term marked as required does not exist in the tokenSet it is\n * impossible for the search to return any matches. We set all the field\n * scoped required matches set to empty and stop examining any further\n * clauses.\n */\n if (expandedTerms.length === 0 && clause.presence === lunr.Query.presence.REQUIRED) {\n for (var k = 0; k < clause.fields.length; k++) {\n var field = clause.fields[k]\n requiredMatches[field] = lunr.Set.empty\n }\n\n break\n }\n\n for (var j = 0; j < expandedTerms.length; j++) {\n /*\n * For each term get the posting and termIndex, this is required for\n * building the query vector.\n */\n var expandedTerm = expandedTerms[j],\n posting = this.invertedIndex[expandedTerm],\n termIndex = posting._index\n\n for (var k = 0; k < clause.fields.length; k++) {\n /*\n * For each field that this query term is scoped by (by default\n * all fields are in scope) we need to get all the document refs\n * that have this term in that field.\n *\n * The posting is the entry in the invertedIndex for the matching\n * term from above.\n */\n var field = clause.fields[k],\n fieldPosting = posting[field],\n matchingDocumentRefs = Object.keys(fieldPosting),\n termField = expandedTerm + \"/\" + field,\n matchingDocumentsSet = new lunr.Set(matchingDocumentRefs)\n\n /*\n * if the presence of this term is required ensure that the matching\n * documents are added to the set of required matches for this clause.\n *\n */\n if (clause.presence == lunr.Query.presence.REQUIRED) {\n clauseMatches = clauseMatches.union(matchingDocumentsSet)\n\n if (requiredMatches[field] === undefined) {\n requiredMatches[field] = lunr.Set.complete\n }\n }\n\n /*\n * if the presence of this term is prohibited ensure that the matching\n * documents are added to the set of prohibited matches for this field,\n * creating that set if it does not yet exist.\n */\n if (clause.presence == lunr.Query.presence.PROHIBITED) {\n if (prohibitedMatches[field] === undefined) {\n prohibitedMatches[field] = lunr.Set.empty\n }\n\n prohibitedMatches[field] = prohibitedMatches[field].union(matchingDocumentsSet)\n\n /*\n * Prohibited matches should not be part of the query vector used for\n * similarity scoring and no metadata should be extracted so we continue\n * to the next field\n */\n continue\n }\n\n /*\n * The query field vector is populated using the termIndex found for\n * the term and a unit value with the appropriate boost applied.\n * Using upsert because there could already be an entry in the vector\n * for the term we are working with. In that case we just add the scores\n * together.\n */\n queryVectors[field].upsert(termIndex, clause.boost, function (a, b) { return a + b })\n\n /**\n * If we've already seen this term, field combo then we've already collected\n * the matching documents and metadata, no need to go through all that again\n */\n if (termFieldCache[termField]) {\n continue\n }\n\n for (var l = 0; l < matchingDocumentRefs.length; l++) {\n /*\n * All metadata for this term/field/document triple\n * are then extracted and collected into an instance\n * of lunr.MatchData ready to be returned in the query\n * results\n */\n var matchingDocumentRef = matchingDocumentRefs[l],\n matchingFieldRef = new lunr.FieldRef (matchingDocumentRef, field),\n metadata = fieldPosting[matchingDocumentRef],\n fieldMatch\n\n if ((fieldMatch = matchingFields[matchingFieldRef]) === undefined) {\n matchingFields[matchingFieldRef] = new lunr.MatchData (expandedTerm, field, metadata)\n } else {\n fieldMatch.add(expandedTerm, field, metadata)\n }\n\n }\n\n termFieldCache[termField] = true\n }\n }\n }\n\n /**\n * If the presence was required we need to update the requiredMatches field sets.\n * We do this after all fields for the term have collected their matches because\n * the clause terms presence is required in _any_ of the fields not _all_ of the\n * fields.\n */\n if (clause.presence === lunr.Query.presence.REQUIRED) {\n for (var k = 0; k < clause.fields.length; k++) {\n var field = clause.fields[k]\n requiredMatches[field] = requiredMatches[field].intersect(clauseMatches)\n }\n }\n }\n\n /**\n * Need to combine the field scoped required and prohibited\n * matching documents into a global set of required and prohibited\n * matches\n */\n var allRequiredMatches = lunr.Set.complete,\n allProhibitedMatches = lunr.Set.empty\n\n for (var i = 0; i < this.fields.length; i++) {\n var field = this.fields[i]\n\n if (requiredMatches[field]) {\n allRequiredMatches = allRequiredMatches.intersect(requiredMatches[field])\n }\n\n if (prohibitedMatches[field]) {\n allProhibitedMatches = allProhibitedMatches.union(prohibitedMatches[field])\n }\n }\n\n var matchingFieldRefs = Object.keys(matchingFields),\n results = [],\n matches = Object.create(null)\n\n /*\n * If the query is negated (contains only prohibited terms)\n * we need to get _all_ fieldRefs currently existing in the\n * index. This is only done when we know that the query is\n * entirely prohibited terms to avoid any cost of getting all\n * fieldRefs unnecessarily.\n *\n * Additionally, blank MatchData must be created to correctly\n * populate the results.\n */\n if (query.isNegated()) {\n matchingFieldRefs = Object.keys(this.fieldVectors)\n\n for (var i = 0; i < matchingFieldRefs.length; i++) {\n var matchingFieldRef = matchingFieldRefs[i]\n var fieldRef = lunr.FieldRef.fromString(matchingFieldRef)\n matchingFields[matchingFieldRef] = new lunr.MatchData\n }\n }\n\n for (var i = 0; i < matchingFieldRefs.length; i++) {\n /*\n * Currently we have document fields that match the query, but we\n * need to return documents. The matchData and scores are combined\n * from multiple fields belonging to the same document.\n *\n * Scores are calculated by field, using the query vectors created\n * above, and combined into a final document score using addition.\n */\n var fieldRef = lunr.FieldRef.fromString(matchingFieldRefs[i]),\n docRef = fieldRef.docRef\n\n if (!allRequiredMatches.contains(docRef)) {\n continue\n }\n\n if (allProhibitedMatches.contains(docRef)) {\n continue\n }\n\n var fieldVector = this.fieldVectors[fieldRef],\n score = queryVectors[fieldRef.fieldName].similarity(fieldVector),\n docMatch\n\n if ((docMatch = matches[docRef]) !== undefined) {\n docMatch.score += score\n docMatch.matchData.combine(matchingFields[fieldRef])\n } else {\n var match = {\n ref: docRef,\n score: score,\n matchData: matchingFields[fieldRef]\n }\n matches[docRef] = match\n results.push(match)\n }\n }\n\n /*\n * Sort the results objects by score, highest first.\n */\n return results.sort(function (a, b) {\n return b.score - a.score\n })\n}\n\n/**\n * Prepares the index for JSON serialization.\n *\n * The schema for this JSON blob will be described in a\n * separate JSON schema file.\n *\n * @returns {Object}\n */\nlunr.Index.prototype.toJSON = function () {\n var invertedIndex = Object.keys(this.invertedIndex)\n .sort()\n .map(function (term) {\n return [term, this.invertedIndex[term]]\n }, this)\n\n var fieldVectors = Object.keys(this.fieldVectors)\n .map(function (ref) {\n return [ref, this.fieldVectors[ref].toJSON()]\n }, this)\n\n return {\n version: lunr.version,\n fields: this.fields,\n fieldVectors: fieldVectors,\n invertedIndex: invertedIndex,\n pipeline: this.pipeline.toJSON()\n }\n}\n\n/**\n * Loads a previously serialized lunr.Index\n *\n * @param {Object} serializedIndex - A previously serialized lunr.Index\n * @returns {lunr.Index}\n */\nlunr.Index.load = function (serializedIndex) {\n var attrs = {},\n fieldVectors = {},\n serializedVectors = serializedIndex.fieldVectors,\n invertedIndex = Object.create(null),\n serializedInvertedIndex = serializedIndex.invertedIndex,\n tokenSetBuilder = new lunr.TokenSet.Builder,\n pipeline = lunr.Pipeline.load(serializedIndex.pipeline)\n\n if (serializedIndex.version != lunr.version) {\n lunr.utils.warn(\"Version mismatch when loading serialised index. Current version of lunr '\" + lunr.version + \"' does not match serialized index '\" + serializedIndex.version + \"'\")\n }\n\n for (var i = 0; i < serializedVectors.length; i++) {\n var tuple = serializedVectors[i],\n ref = tuple[0],\n elements = tuple[1]\n\n fieldVectors[ref] = new lunr.Vector(elements)\n }\n\n for (var i = 0; i < serializedInvertedIndex.length; i++) {\n var tuple = serializedInvertedIndex[i],\n term = tuple[0],\n posting = tuple[1]\n\n tokenSetBuilder.insert(term)\n invertedIndex[term] = posting\n }\n\n tokenSetBuilder.finish()\n\n attrs.fields = serializedIndex.fields\n\n attrs.fieldVectors = fieldVectors\n attrs.invertedIndex = invertedIndex\n attrs.tokenSet = tokenSetBuilder.root\n attrs.pipeline = pipeline\n\n return new lunr.Index(attrs)\n}\n/*!\n * lunr.Builder\n * Copyright (C) 2020 Oliver Nightingale\n */\n\n/**\n * lunr.Builder performs indexing on a set of documents and\n * returns instances of lunr.Index ready for querying.\n *\n * All configuration of the index is done via the builder, the\n * fields to index, the document reference, the text processing\n * pipeline and document scoring parameters are all set on the\n * builder before indexing.\n *\n * @constructor\n * @property {string} _ref - Internal reference to the document reference field.\n * @property {string[]} _fields - Internal reference to the document fields to index.\n * @property {object} invertedIndex - The inverted index maps terms to document fields.\n * @property {object} documentTermFrequencies - Keeps track of document term frequencies.\n * @property {object} documentLengths - Keeps track of the length of documents added to the index.\n * @property {lunr.tokenizer} tokenizer - Function for splitting strings into tokens for indexing.\n * @property {lunr.Pipeline} pipeline - The pipeline performs text processing on tokens before indexing.\n * @property {lunr.Pipeline} searchPipeline - A pipeline for processing search terms before querying the index.\n * @property {number} documentCount - Keeps track of the total number of documents indexed.\n * @property {number} _b - A parameter to control field length normalization, setting this to 0 disabled normalization, 1 fully normalizes field lengths, the default value is 0.75.\n * @property {number} _k1 - A parameter to control how quickly an increase in term frequency results in term frequency saturation, the default value is 1.2.\n * @property {number} termIndex - A counter incremented for each unique term, used to identify a terms position in the vector space.\n * @property {array} metadataWhitelist - A list of metadata keys that have been whitelisted for entry in the index.\n */\nlunr.Builder = function () {\n this._ref = \"id\"\n this._fields = Object.create(null)\n this._documents = Object.create(null)\n this.invertedIndex = Object.create(null)\n this.fieldTermFrequencies = {}\n this.fieldLengths = {}\n this.tokenizer = lunr.tokenizer\n this.pipeline = new lunr.Pipeline\n this.searchPipeline = new lunr.Pipeline\n this.documentCount = 0\n this._b = 0.75\n this._k1 = 1.2\n this.termIndex = 0\n this.metadataWhitelist = []\n}\n\n/**\n * Sets the document field used as the document reference. Every document must have this field.\n * The type of this field in the document should be a string, if it is not a string it will be\n * coerced into a string by calling toString.\n *\n * The default ref is 'id'.\n *\n * The ref should _not_ be changed during indexing, it should be set before any documents are\n * added to the index. Changing it during indexing can lead to inconsistent results.\n *\n * @param {string} ref - The name of the reference field in the document.\n */\nlunr.Builder.prototype.ref = function (ref) {\n this._ref = ref\n}\n\n/**\n * A function that is used to extract a field from a document.\n *\n * Lunr expects a field to be at the top level of a document, if however the field\n * is deeply nested within a document an extractor function can be used to extract\n * the right field for indexing.\n *\n * @callback fieldExtractor\n * @param {object} doc - The document being added to the index.\n * @returns {?(string|object|object[])} obj - The object that will be indexed for this field.\n * @example Extracting a nested field\n * function (doc) { return doc.nested.field }\n */\n\n/**\n * Adds a field to the list of document fields that will be indexed. Every document being\n * indexed should have this field. Null values for this field in indexed documents will\n * not cause errors but will limit the chance of that document being retrieved by searches.\n *\n * All fields should be added before adding documents to the index. Adding fields after\n * a document has been indexed will have no effect on already indexed documents.\n *\n * Fields can be boosted at build time. This allows terms within that field to have more\n * importance when ranking search results. Use a field boost to specify that matches within\n * one field are more important than other fields.\n *\n * @param {string} fieldName - The name of a field to index in all documents.\n * @param {object} attributes - Optional attributes associated with this field.\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this field.\n * @param {fieldExtractor} [attributes.extractor] - Function to extract a field from a document.\n * @throws {RangeError} fieldName cannot contain unsupported characters '/'\n */\nlunr.Builder.prototype.field = function (fieldName, attributes) {\n if (/\\//.test(fieldName)) {\n throw new RangeError (\"Field '\" + fieldName + \"' contains illegal character '/'\")\n }\n\n this._fields[fieldName] = attributes || {}\n}\n\n/**\n * A parameter to tune the amount of field length normalisation that is applied when\n * calculating relevance scores. A value of 0 will completely disable any normalisation\n * and a value of 1 will fully normalise field lengths. The default is 0.75. Values of b\n * will be clamped to the range 0 - 1.\n *\n * @param {number} number - The value to set for this tuning parameter.\n */\nlunr.Builder.prototype.b = function (number) {\n if (number < 0) {\n this._b = 0\n } else if (number > 1) {\n this._b = 1\n } else {\n this._b = number\n }\n}\n\n/**\n * A parameter that controls the speed at which a rise in term frequency results in term\n * frequency saturation. The default value is 1.2. Setting this to a higher value will give\n * slower saturation levels, a lower value will result in quicker saturation.\n *\n * @param {number} number - The value to set for this tuning parameter.\n */\nlunr.Builder.prototype.k1 = function (number) {\n this._k1 = number\n}\n\n/**\n * Adds a document to the index.\n *\n * Before adding fields to the index the index should have been fully setup, with the document\n * ref and all fields to index already having been specified.\n *\n * The document must have a field name as specified by the ref (by default this is 'id') and\n * it should have all fields defined for indexing, though null or undefined values will not\n * cause errors.\n *\n * Entire documents can be boosted at build time. Applying a boost to a document indicates that\n * this document should rank higher in search results than other documents.\n *\n * @param {object} doc - The document to add to the index.\n * @param {object} attributes - Optional attributes associated with this document.\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this document.\n */\nlunr.Builder.prototype.add = function (doc, attributes) {\n var docRef = doc[this._ref],\n fields = Object.keys(this._fields)\n\n this._documents[docRef] = attributes || {}\n this.documentCount += 1\n\n for (var i = 0; i < fields.length; i++) {\n var fieldName = fields[i],\n extractor = this._fields[fieldName].extractor,\n field = extractor ? extractor(doc) : doc[fieldName],\n tokens = this.tokenizer(field, {\n fields: [fieldName]\n }),\n terms = this.pipeline.run(tokens),\n fieldRef = new lunr.FieldRef (docRef, fieldName),\n fieldTerms = Object.create(null)\n\n this.fieldTermFrequencies[fieldRef] = fieldTerms\n this.fieldLengths[fieldRef] = 0\n\n // store the length of this field for this document\n this.fieldLengths[fieldRef] += terms.length\n\n // calculate term frequencies for this field\n for (var j = 0; j < terms.length; j++) {\n var term = terms[j]\n\n if (fieldTerms[term] == undefined) {\n fieldTerms[term] = 0\n }\n\n fieldTerms[term] += 1\n\n // add to inverted index\n // create an initial posting if one doesn't exist\n if (this.invertedIndex[term] == undefined) {\n var posting = Object.create(null)\n posting[\"_index\"] = this.termIndex\n this.termIndex += 1\n\n for (var k = 0; k < fields.length; k++) {\n posting[fields[k]] = Object.create(null)\n }\n\n this.invertedIndex[term] = posting\n }\n\n // add an entry for this term/fieldName/docRef to the invertedIndex\n if (this.invertedIndex[term][fieldName][docRef] == undefined) {\n this.invertedIndex[term][fieldName][docRef] = Object.create(null)\n }\n\n // store all whitelisted metadata about this token in the\n // inverted index\n for (var l = 0; l < this.metadataWhitelist.length; l++) {\n var metadataKey = this.metadataWhitelist[l],\n metadata = term.metadata[metadataKey]\n\n if (this.invertedIndex[term][fieldName][docRef][metadataKey] == undefined) {\n this.invertedIndex[term][fieldName][docRef][metadataKey] = []\n }\n\n this.invertedIndex[term][fieldName][docRef][metadataKey].push(metadata)\n }\n }\n\n }\n}\n\n/**\n * Calculates the average document length for this index\n *\n * @private\n */\nlunr.Builder.prototype.calculateAverageFieldLengths = function () {\n\n var fieldRefs = Object.keys(this.fieldLengths),\n numberOfFields = fieldRefs.length,\n accumulator = {},\n documentsWithField = {}\n\n for (var i = 0; i < numberOfFields; i++) {\n var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\n field = fieldRef.fieldName\n\n documentsWithField[field] || (documentsWithField[field] = 0)\n documentsWithField[field] += 1\n\n accumulator[field] || (accumulator[field] = 0)\n accumulator[field] += this.fieldLengths[fieldRef]\n }\n\n var fields = Object.keys(this._fields)\n\n for (var i = 0; i < fields.length; i++) {\n var fieldName = fields[i]\n accumulator[fieldName] = accumulator[fieldName] / documentsWithField[fieldName]\n }\n\n this.averageFieldLength = accumulator\n}\n\n/**\n * Builds a vector space model of every document using lunr.Vector\n *\n * @private\n */\nlunr.Builder.prototype.createFieldVectors = function () {\n var fieldVectors = {},\n fieldRefs = Object.keys(this.fieldTermFrequencies),\n fieldRefsLength = fieldRefs.length,\n termIdfCache = Object.create(null)\n\n for (var i = 0; i < fieldRefsLength; i++) {\n var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\n fieldName = fieldRef.fieldName,\n fieldLength = this.fieldLengths[fieldRef],\n fieldVector = new lunr.Vector,\n termFrequencies = this.fieldTermFrequencies[fieldRef],\n terms = Object.keys(termFrequencies),\n termsLength = terms.length\n\n\n var fieldBoost = this._fields[fieldName].boost || 1,\n docBoost = this._documents[fieldRef.docRef].boost || 1\n\n for (var j = 0; j < termsLength; j++) {\n var term = terms[j],\n tf = termFrequencies[term],\n termIndex = this.invertedIndex[term]._index,\n idf, score, scoreWithPrecision\n\n if (termIdfCache[term] === undefined) {\n idf = lunr.idf(this.invertedIndex[term], this.documentCount)\n termIdfCache[term] = idf\n } else {\n idf = termIdfCache[term]\n }\n\n score = idf * ((this._k1 + 1) * tf) / (this._k1 * (1 - this._b + this._b * (fieldLength / this.averageFieldLength[fieldName])) + tf)\n score *= fieldBoost\n score *= docBoost\n scoreWithPrecision = Math.round(score * 1000) / 1000\n // Converts 1.23456789 to 1.234.\n // Reducing the precision so that the vectors take up less\n // space when serialised. Doing it now so that they behave\n // the same before and after serialisation. Also, this is\n // the fastest approach to reducing a number's precision in\n // JavaScript.\n\n fieldVector.insert(termIndex, scoreWithPrecision)\n }\n\n fieldVectors[fieldRef] = fieldVector\n }\n\n this.fieldVectors = fieldVectors\n}\n\n/**\n * Creates a token set of all tokens in the index using lunr.TokenSet\n *\n * @private\n */\nlunr.Builder.prototype.createTokenSet = function () {\n this.tokenSet = lunr.TokenSet.fromArray(\n Object.keys(this.invertedIndex).sort()\n )\n}\n\n/**\n * Builds the index, creating an instance of lunr.Index.\n *\n * This completes the indexing process and should only be called\n * once all documents have been added to the index.\n *\n * @returns {lunr.Index}\n */\nlunr.Builder.prototype.build = function () {\n this.calculateAverageFieldLengths()\n this.createFieldVectors()\n this.createTokenSet()\n\n return new lunr.Index({\n invertedIndex: this.invertedIndex,\n fieldVectors: this.fieldVectors,\n tokenSet: this.tokenSet,\n fields: Object.keys(this._fields),\n pipeline: this.searchPipeline\n })\n}\n\n/**\n * Applies a plugin to the index builder.\n *\n * A plugin is a function that is called with the index builder as its context.\n * Plugins can be used to customise or extend the behaviour of the index\n * in some way. A plugin is just a function, that encapsulated the custom\n * behaviour that should be applied when building the index.\n *\n * The plugin function will be called with the index builder as its argument, additional\n * arguments can also be passed when calling use. The function will be called\n * with the index builder as its context.\n *\n * @param {Function} plugin The plugin to apply.\n */\nlunr.Builder.prototype.use = function (fn) {\n var args = Array.prototype.slice.call(arguments, 1)\n args.unshift(this)\n fn.apply(this, args)\n}\n/**\n * Contains and collects metadata about a matching document.\n * A single instance of lunr.MatchData is returned as part of every\n * lunr.Index~Result.\n *\n * @constructor\n * @param {string} term - The term this match data is associated with\n * @param {string} field - The field in which the term was found\n * @param {object} metadata - The metadata recorded about this term in this field\n * @property {object} metadata - A cloned collection of metadata associated with this document.\n * @see {@link lunr.Index~Result}\n */\nlunr.MatchData = function (term, field, metadata) {\n var clonedMetadata = Object.create(null),\n metadataKeys = Object.keys(metadata || {})\n\n // Cloning the metadata to prevent the original\n // being mutated during match data combination.\n // Metadata is kept in an array within the inverted\n // index so cloning the data can be done with\n // Array#slice\n for (var i = 0; i < metadataKeys.length; i++) {\n var key = metadataKeys[i]\n clonedMetadata[key] = metadata[key].slice()\n }\n\n this.metadata = Object.create(null)\n\n if (term !== undefined) {\n this.metadata[term] = Object.create(null)\n this.metadata[term][field] = clonedMetadata\n }\n}\n\n/**\n * An instance of lunr.MatchData will be created for every term that matches a\n * document. However only one instance is required in a lunr.Index~Result. This\n * method combines metadata from another instance of lunr.MatchData with this\n * objects metadata.\n *\n * @param {lunr.MatchData} otherMatchData - Another instance of match data to merge with this one.\n * @see {@link lunr.Index~Result}\n */\nlunr.MatchData.prototype.combine = function (otherMatchData) {\n var terms = Object.keys(otherMatchData.metadata)\n\n for (var i = 0; i < terms.length; i++) {\n var term = terms[i],\n fields = Object.keys(otherMatchData.metadata[term])\n\n if (this.metadata[term] == undefined) {\n this.metadata[term] = Object.create(null)\n }\n\n for (var j = 0; j < fields.length; j++) {\n var field = fields[j],\n keys = Object.keys(otherMatchData.metadata[term][field])\n\n if (this.metadata[term][field] == undefined) {\n this.metadata[term][field] = Object.create(null)\n }\n\n for (var k = 0; k < keys.length; k++) {\n var key = keys[k]\n\n if (this.metadata[term][field][key] == undefined) {\n this.metadata[term][field][key] = otherMatchData.metadata[term][field][key]\n } else {\n this.metadata[term][field][key] = this.metadata[term][field][key].concat(otherMatchData.metadata[term][field][key])\n }\n\n }\n }\n }\n}\n\n/**\n * Add metadata for a term/field pair to this instance of match data.\n *\n * @param {string} term - The term this match data is associated with\n * @param {string} field - The field in which the term was found\n * @param {object} metadata - The metadata recorded about this term in this field\n */\nlunr.MatchData.prototype.add = function (term, field, metadata) {\n if (!(term in this.metadata)) {\n this.metadata[term] = Object.create(null)\n this.metadata[term][field] = metadata\n return\n }\n\n if (!(field in this.metadata[term])) {\n this.metadata[term][field] = metadata\n return\n }\n\n var metadataKeys = Object.keys(metadata)\n\n for (var i = 0; i < metadataKeys.length; i++) {\n var key = metadataKeys[i]\n\n if (key in this.metadata[term][field]) {\n this.metadata[term][field][key] = this.metadata[term][field][key].concat(metadata[key])\n } else {\n this.metadata[term][field][key] = metadata[key]\n }\n }\n}\n/**\n * A lunr.Query provides a programmatic way of defining queries to be performed\n * against a {@link lunr.Index}.\n *\n * Prefer constructing a lunr.Query using the {@link lunr.Index#query} method\n * so the query object is pre-initialized with the right index fields.\n *\n * @constructor\n * @property {lunr.Query~Clause[]} clauses - An array of query clauses.\n * @property {string[]} allFields - An array of all available fields in a lunr.Index.\n */\nlunr.Query = function (allFields) {\n this.clauses = []\n this.allFields = allFields\n}\n\n/**\n * Constants for indicating what kind of automatic wildcard insertion will be used when constructing a query clause.\n *\n * This allows wildcards to be added to the beginning and end of a term without having to manually do any string\n * concatenation.\n *\n * The wildcard constants can be bitwise combined to select both leading and trailing wildcards.\n *\n * @constant\n * @default\n * @property {number} wildcard.NONE - The term will have no wildcards inserted, this is the default behaviour\n * @property {number} wildcard.LEADING - Prepend the term with a wildcard, unless a leading wildcard already exists\n * @property {number} wildcard.TRAILING - Append a wildcard to the term, unless a trailing wildcard already exists\n * @see lunr.Query~Clause\n * @see lunr.Query#clause\n * @see lunr.Query#term\n * @example query term with trailing wildcard\n * query.term('foo', { wildcard: lunr.Query.wildcard.TRAILING })\n * @example query term with leading and trailing wildcard\n * query.term('foo', {\n * wildcard: lunr.Query.wildcard.LEADING | lunr.Query.wildcard.TRAILING\n * })\n */\n\nlunr.Query.wildcard = new String (\"*\")\nlunr.Query.wildcard.NONE = 0\nlunr.Query.wildcard.LEADING = 1\nlunr.Query.wildcard.TRAILING = 2\n\n/**\n * Constants for indicating what kind of presence a term must have in matching documents.\n *\n * @constant\n * @enum {number}\n * @see lunr.Query~Clause\n * @see lunr.Query#clause\n * @see lunr.Query#term\n * @example query term with required presence\n * query.term('foo', { presence: lunr.Query.presence.REQUIRED })\n */\nlunr.Query.presence = {\n /**\n * Term's presence in a document is optional, this is the default value.\n */\n OPTIONAL: 1,\n\n /**\n * Term's presence in a document is required, documents that do not contain\n * this term will not be returned.\n */\n REQUIRED: 2,\n\n /**\n * Term's presence in a document is prohibited, documents that do contain\n * this term will not be returned.\n */\n PROHIBITED: 3\n}\n\n/**\n * A single clause in a {@link lunr.Query} contains a term and details on how to\n * match that term against a {@link lunr.Index}.\n *\n * @typedef {Object} lunr.Query~Clause\n * @property {string[]} fields - The fields in an index this clause should be matched against.\n * @property {number} [boost=1] - Any boost that should be applied when matching this clause.\n * @property {number} [editDistance] - Whether the term should have fuzzy matching applied, and how fuzzy the match should be.\n * @property {boolean} [usePipeline] - Whether the term should be passed through the search pipeline.\n * @property {number} [wildcard=lunr.Query.wildcard.NONE] - Whether the term should have wildcards appended or prepended.\n * @property {number} [presence=lunr.Query.presence.OPTIONAL] - The terms presence in any matching documents.\n */\n\n/**\n * Adds a {@link lunr.Query~Clause} to this query.\n *\n * Unless the clause contains the fields to be matched all fields will be matched. In addition\n * a default boost of 1 is applied to the clause.\n *\n * @param {lunr.Query~Clause} clause - The clause to add to this query.\n * @see lunr.Query~Clause\n * @returns {lunr.Query}\n */\nlunr.Query.prototype.clause = function (clause) {\n if (!('fields' in clause)) {\n clause.fields = this.allFields\n }\n\n if (!('boost' in clause)) {\n clause.boost = 1\n }\n\n if (!('usePipeline' in clause)) {\n clause.usePipeline = true\n }\n\n if (!('wildcard' in clause)) {\n clause.wildcard = lunr.Query.wildcard.NONE\n }\n\n if ((clause.wildcard & lunr.Query.wildcard.LEADING) && (clause.term.charAt(0) != lunr.Query.wildcard)) {\n clause.term = \"*\" + clause.term\n }\n\n if ((clause.wildcard & lunr.Query.wildcard.TRAILING) && (clause.term.slice(-1) != lunr.Query.wildcard)) {\n clause.term = \"\" + clause.term + \"*\"\n }\n\n if (!('presence' in clause)) {\n clause.presence = lunr.Query.presence.OPTIONAL\n }\n\n this.clauses.push(clause)\n\n return this\n}\n\n/**\n * A negated query is one in which every clause has a presence of\n * prohibited. These queries require some special processing to return\n * the expected results.\n *\n * @returns boolean\n */\nlunr.Query.prototype.isNegated = function () {\n for (var i = 0; i < this.clauses.length; i++) {\n if (this.clauses[i].presence != lunr.Query.presence.PROHIBITED) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * Adds a term to the current query, under the covers this will create a {@link lunr.Query~Clause}\n * to the list of clauses that make up this query.\n *\n * The term is used as is, i.e. no tokenization will be performed by this method. Instead conversion\n * to a token or token-like string should be done before calling this method.\n *\n * The term will be converted to a string by calling `toString`. Multiple terms can be passed as an\n * array, each term in the array will share the same options.\n *\n * @param {object|object[]} term - The term(s) to add to the query.\n * @param {object} [options] - Any additional properties to add to the query clause.\n * @returns {lunr.Query}\n * @see lunr.Query#clause\n * @see lunr.Query~Clause\n * @example adding a single term to a query\n * query.term(\"foo\")\n * @example adding a single term to a query and specifying search fields, term boost and automatic trailing wildcard\n * query.term(\"foo\", {\n * fields: [\"title\"],\n * boost: 10,\n * wildcard: lunr.Query.wildcard.TRAILING\n * })\n * @example using lunr.tokenizer to convert a string to tokens before using them as terms\n * query.term(lunr.tokenizer(\"foo bar\"))\n */\nlunr.Query.prototype.term = function (term, options) {\n if (Array.isArray(term)) {\n term.forEach(function (t) { this.term(t, lunr.utils.clone(options)) }, this)\n return this\n }\n\n var clause = options || {}\n clause.term = term.toString()\n\n this.clause(clause)\n\n return this\n}\nlunr.QueryParseError = function (message, start, end) {\n this.name = \"QueryParseError\"\n this.message = message\n this.start = start\n this.end = end\n}\n\nlunr.QueryParseError.prototype = new Error\nlunr.QueryLexer = function (str) {\n this.lexemes = []\n this.str = str\n this.length = str.length\n this.pos = 0\n this.start = 0\n this.escapeCharPositions = []\n}\n\nlunr.QueryLexer.prototype.run = function () {\n var state = lunr.QueryLexer.lexText\n\n while (state) {\n state = state(this)\n }\n}\n\nlunr.QueryLexer.prototype.sliceString = function () {\n var subSlices = [],\n sliceStart = this.start,\n sliceEnd = this.pos\n\n for (var i = 0; i < this.escapeCharPositions.length; i++) {\n sliceEnd = this.escapeCharPositions[i]\n subSlices.push(this.str.slice(sliceStart, sliceEnd))\n sliceStart = sliceEnd + 1\n }\n\n subSlices.push(this.str.slice(sliceStart, this.pos))\n this.escapeCharPositions.length = 0\n\n return subSlices.join('')\n}\n\nlunr.QueryLexer.prototype.emit = function (type) {\n this.lexemes.push({\n type: type,\n str: this.sliceString(),\n start: this.start,\n end: this.pos\n })\n\n this.start = this.pos\n}\n\nlunr.QueryLexer.prototype.escapeCharacter = function () {\n this.escapeCharPositions.push(this.pos - 1)\n this.pos += 1\n}\n\nlunr.QueryLexer.prototype.next = function () {\n if (this.pos >= this.length) {\n return lunr.QueryLexer.EOS\n }\n\n var char = this.str.charAt(this.pos)\n this.pos += 1\n return char\n}\n\nlunr.QueryLexer.prototype.width = function () {\n return this.pos - this.start\n}\n\nlunr.QueryLexer.prototype.ignore = function () {\n if (this.start == this.pos) {\n this.pos += 1\n }\n\n this.start = this.pos\n}\n\nlunr.QueryLexer.prototype.backup = function () {\n this.pos -= 1\n}\n\nlunr.QueryLexer.prototype.acceptDigitRun = function () {\n var char, charCode\n\n do {\n char = this.next()\n charCode = char.charCodeAt(0)\n } while (charCode > 47 && charCode < 58)\n\n if (char != lunr.QueryLexer.EOS) {\n this.backup()\n }\n}\n\nlunr.QueryLexer.prototype.more = function () {\n return this.pos < this.length\n}\n\nlunr.QueryLexer.EOS = 'EOS'\nlunr.QueryLexer.FIELD = 'FIELD'\nlunr.QueryLexer.TERM = 'TERM'\nlunr.QueryLexer.EDIT_DISTANCE = 'EDIT_DISTANCE'\nlunr.QueryLexer.BOOST = 'BOOST'\nlunr.QueryLexer.PRESENCE = 'PRESENCE'\n\nlunr.QueryLexer.lexField = function (lexer) {\n lexer.backup()\n lexer.emit(lunr.QueryLexer.FIELD)\n lexer.ignore()\n return lunr.QueryLexer.lexText\n}\n\nlunr.QueryLexer.lexTerm = function (lexer) {\n if (lexer.width() > 1) {\n lexer.backup()\n lexer.emit(lunr.QueryLexer.TERM)\n }\n\n lexer.ignore()\n\n if (lexer.more()) {\n return lunr.QueryLexer.lexText\n }\n}\n\nlunr.QueryLexer.lexEditDistance = function (lexer) {\n lexer.ignore()\n lexer.acceptDigitRun()\n lexer.emit(lunr.QueryLexer.EDIT_DISTANCE)\n return lunr.QueryLexer.lexText\n}\n\nlunr.QueryLexer.lexBoost = function (lexer) {\n lexer.ignore()\n lexer.acceptDigitRun()\n lexer.emit(lunr.QueryLexer.BOOST)\n return lunr.QueryLexer.lexText\n}\n\nlunr.QueryLexer.lexEOS = function (lexer) {\n if (lexer.width() > 0) {\n lexer.emit(lunr.QueryLexer.TERM)\n }\n}\n\n// This matches the separator used when tokenising fields\n// within a document. These should match otherwise it is\n// not possible to search for some tokens within a document.\n//\n// It is possible for the user to change the separator on the\n// tokenizer so it _might_ clash with any other of the special\n// characters already used within the search string, e.g. :.\n//\n// This means that it is possible to change the separator in\n// such a way that makes some words unsearchable using a search\n// string.\nlunr.QueryLexer.termSeparator = lunr.tokenizer.separator\n\nlunr.QueryLexer.lexText = function (lexer) {\n while (true) {\n var char = lexer.next()\n\n if (char == lunr.QueryLexer.EOS) {\n return lunr.QueryLexer.lexEOS\n }\n\n // Escape character is '\\'\n if (char.charCodeAt(0) == 92) {\n lexer.escapeCharacter()\n continue\n }\n\n if (char == \":\") {\n return lunr.QueryLexer.lexField\n }\n\n if (char == \"~\") {\n lexer.backup()\n if (lexer.width() > 0) {\n lexer.emit(lunr.QueryLexer.TERM)\n }\n return lunr.QueryLexer.lexEditDistance\n }\n\n if (char == \"^\") {\n lexer.backup()\n if (lexer.width() > 0) {\n lexer.emit(lunr.QueryLexer.TERM)\n }\n return lunr.QueryLexer.lexBoost\n }\n\n // \"+\" indicates term presence is required\n // checking for length to ensure that only\n // leading \"+\" are considered\n if (char == \"+\" && lexer.width() === 1) {\n lexer.emit(lunr.QueryLexer.PRESENCE)\n return lunr.QueryLexer.lexText\n }\n\n // \"-\" indicates term presence is prohibited\n // checking for length to ensure that only\n // leading \"-\" are considered\n if (char == \"-\" && lexer.width() === 1) {\n lexer.emit(lunr.QueryLexer.PRESENCE)\n return lunr.QueryLexer.lexText\n }\n\n if (char.match(lunr.QueryLexer.termSeparator)) {\n return lunr.QueryLexer.lexTerm\n }\n }\n}\n\nlunr.QueryParser = function (str, query) {\n this.lexer = new lunr.QueryLexer (str)\n this.query = query\n this.currentClause = {}\n this.lexemeIdx = 0\n}\n\nlunr.QueryParser.prototype.parse = function () {\n this.lexer.run()\n this.lexemes = this.lexer.lexemes\n\n var state = lunr.QueryParser.parseClause\n\n while (state) {\n state = state(this)\n }\n\n return this.query\n}\n\nlunr.QueryParser.prototype.peekLexeme = function () {\n return this.lexemes[this.lexemeIdx]\n}\n\nlunr.QueryParser.prototype.consumeLexeme = function () {\n var lexeme = this.peekLexeme()\n this.lexemeIdx += 1\n return lexeme\n}\n\nlunr.QueryParser.prototype.nextClause = function () {\n var completedClause = this.currentClause\n this.query.clause(completedClause)\n this.currentClause = {}\n}\n\nlunr.QueryParser.parseClause = function (parser) {\n var lexeme = parser.peekLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n switch (lexeme.type) {\n case lunr.QueryLexer.PRESENCE:\n return lunr.QueryParser.parsePresence\n case lunr.QueryLexer.FIELD:\n return lunr.QueryParser.parseField\n case lunr.QueryLexer.TERM:\n return lunr.QueryParser.parseTerm\n default:\n var errorMessage = \"expected either a field or a term, found \" + lexeme.type\n\n if (lexeme.str.length >= 1) {\n errorMessage += \" with value '\" + lexeme.str + \"'\"\n }\n\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n}\n\nlunr.QueryParser.parsePresence = function (parser) {\n var lexeme = parser.consumeLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n switch (lexeme.str) {\n case \"-\":\n parser.currentClause.presence = lunr.Query.presence.PROHIBITED\n break\n case \"+\":\n parser.currentClause.presence = lunr.Query.presence.REQUIRED\n break\n default:\n var errorMessage = \"unrecognised presence operator'\" + lexeme.str + \"'\"\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n var nextLexeme = parser.peekLexeme()\n\n if (nextLexeme == undefined) {\n var errorMessage = \"expecting term or field, found nothing\"\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n switch (nextLexeme.type) {\n case lunr.QueryLexer.FIELD:\n return lunr.QueryParser.parseField\n case lunr.QueryLexer.TERM:\n return lunr.QueryParser.parseTerm\n default:\n var errorMessage = \"expecting term or field, found '\" + nextLexeme.type + \"'\"\n throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\n }\n}\n\nlunr.QueryParser.parseField = function (parser) {\n var lexeme = parser.consumeLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n if (parser.query.allFields.indexOf(lexeme.str) == -1) {\n var possibleFields = parser.query.allFields.map(function (f) { return \"'\" + f + \"'\" }).join(', '),\n errorMessage = \"unrecognised field '\" + lexeme.str + \"', possible fields: \" + possibleFields\n\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n parser.currentClause.fields = [lexeme.str]\n\n var nextLexeme = parser.peekLexeme()\n\n if (nextLexeme == undefined) {\n var errorMessage = \"expecting term, found nothing\"\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n switch (nextLexeme.type) {\n case lunr.QueryLexer.TERM:\n return lunr.QueryParser.parseTerm\n default:\n var errorMessage = \"expecting term, found '\" + nextLexeme.type + \"'\"\n throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\n }\n}\n\nlunr.QueryParser.parseTerm = function (parser) {\n var lexeme = parser.consumeLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n parser.currentClause.term = lexeme.str.toLowerCase()\n\n if (lexeme.str.indexOf(\"*\") != -1) {\n parser.currentClause.usePipeline = false\n }\n\n var nextLexeme = parser.peekLexeme()\n\n if (nextLexeme == undefined) {\n parser.nextClause()\n return\n }\n\n switch (nextLexeme.type) {\n case lunr.QueryLexer.TERM:\n parser.nextClause()\n return lunr.QueryParser.parseTerm\n case lunr.QueryLexer.FIELD:\n parser.nextClause()\n return lunr.QueryParser.parseField\n case lunr.QueryLexer.EDIT_DISTANCE:\n return lunr.QueryParser.parseEditDistance\n case lunr.QueryLexer.BOOST:\n return lunr.QueryParser.parseBoost\n case lunr.QueryLexer.PRESENCE:\n parser.nextClause()\n return lunr.QueryParser.parsePresence\n default:\n var errorMessage = \"Unexpected lexeme type '\" + nextLexeme.type + \"'\"\n throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\n }\n}\n\nlunr.QueryParser.parseEditDistance = function (parser) {\n var lexeme = parser.consumeLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n var editDistance = parseInt(lexeme.str, 10)\n\n if (isNaN(editDistance)) {\n var errorMessage = \"edit distance must be numeric\"\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n parser.currentClause.editDistance = editDistance\n\n var nextLexeme = parser.peekLexeme()\n\n if (nextLexeme == undefined) {\n parser.nextClause()\n return\n }\n\n switch (nextLexeme.type) {\n case lunr.QueryLexer.TERM:\n parser.nextClause()\n return lunr.QueryParser.parseTerm\n case lunr.QueryLexer.FIELD:\n parser.nextClause()\n return lunr.QueryParser.parseField\n case lunr.QueryLexer.EDIT_DISTANCE:\n return lunr.QueryParser.parseEditDistance\n case lunr.QueryLexer.BOOST:\n return lunr.QueryParser.parseBoost\n case lunr.QueryLexer.PRESENCE:\n parser.nextClause()\n return lunr.QueryParser.parsePresence\n default:\n var errorMessage = \"Unexpected lexeme type '\" + nextLexeme.type + \"'\"\n throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\n }\n}\n\nlunr.QueryParser.parseBoost = function (parser) {\n var lexeme = parser.consumeLexeme()\n\n if (lexeme == undefined) {\n return\n }\n\n var boost = parseInt(lexeme.str, 10)\n\n if (isNaN(boost)) {\n var errorMessage = \"boost must be numeric\"\n throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\n }\n\n parser.currentClause.boost = boost\n\n var nextLexeme = parser.peekLexeme()\n\n if (nextLexeme == undefined) {\n parser.nextClause()\n return\n }\n\n switch (nextLexeme.type) {\n case lunr.QueryLexer.TERM:\n parser.nextClause()\n return lunr.QueryParser.parseTerm\n case lunr.QueryLexer.FIELD:\n parser.nextClause()\n return lunr.QueryParser.parseField\n case lunr.QueryLexer.EDIT_DISTANCE:\n return lunr.QueryParser.parseEditDistance\n case lunr.QueryLexer.BOOST:\n return lunr.QueryParser.parseBoost\n case lunr.QueryLexer.PRESENCE:\n parser.nextClause()\n return lunr.QueryParser.parsePresence\n default:\n var errorMessage = \"Unexpected lexeme type '\" + nextLexeme.type + \"'\"\n throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\n }\n}\n\n /**\n * export the module via AMD, CommonJS or as a browser global\n * Export code from https://github.com/umdjs/umd/blob/master/returnExports.js\n */\n ;(function (root, factory) {\n if (true) {\n // AMD. Register as an anonymous module.\n !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\n\t\t__WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))\n } else {}\n }(this, function () {\n /**\n * Just return a value to define the module export.\n * This example returns an object, but the module\n * can return a function as the exported value.\n */\n return lunr\n }))\n})();\n\n\n//# sourceURL=webpack:///../node_modules/lunr/lunr.js?"); + +/***/ }), + +/***/ "./default/assets/css/main.sass": +/*!**************************************!*\ + !*** ./default/assets/css/main.sass ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n// extracted by mini-css-extract-plugin\n\n\n//# sourceURL=webpack:///./default/assets/css/main.sass?"); + +/***/ }), + +/***/ "./default/assets/js/src/bootstrap.ts": +/*!********************************************!*\ + !*** ./default/assets/js/src/bootstrap.ts ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _css_main_sass__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../css/main.sass */ \"./default/assets/css/main.sass\");\n/* harmony import */ var _typedoc_Application__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typedoc/Application */ \"./default/assets/js/src/typedoc/Application.ts\");\n/* harmony import */ var _typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./typedoc/components/Filter */ \"./default/assets/js/src/typedoc/components/Filter.ts\");\n/* harmony import */ var _typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./typedoc/components/MenuHighlight */ \"./default/assets/js/src/typedoc/components/MenuHighlight.ts\");\n/* harmony import */ var _typedoc_components_Search__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typedoc/components/Search */ \"./default/assets/js/src/typedoc/components/Search.ts\");\n/* harmony import */ var _typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./typedoc/components/Signature */ \"./default/assets/js/src/typedoc/components/Signature.ts\");\n/* harmony import */ var _typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./typedoc/components/Toggle */ \"./default/assets/js/src/typedoc/components/Toggle.ts\");\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n(0,_typedoc_components_Search__WEBPACK_IMPORTED_MODULE_4__.initSearch)();\r\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_1__.registerComponent)(_typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_3__.MenuHighlight, '.menu-highlight');\r\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_1__.registerComponent)(_typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_5__.Signature, '.tsd-signatures');\r\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_1__.registerComponent)(_typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_6__.Toggle, 'a[data-toggle]');\r\nif (_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_2__.Filter.isSupported()) {\r\n (0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_1__.registerComponent)(_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_2__.Filter, '#tsd-filter');\r\n}\r\nelse {\r\n document.documentElement.classList.add('no-filter');\r\n}\r\nconst app = new _typedoc_Application__WEBPACK_IMPORTED_MODULE_1__.Application();\r\nObject.defineProperty(window, 'app', { value: app });\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/bootstrap.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/Application.ts": +/*!******************************************************!*\ + !*** ./default/assets/js/src/typedoc/Application.ts ***! + \******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"registerComponent\": () => /* binding */ registerComponent,\n/* harmony export */ \"Application\": () => /* binding */ Application\n/* harmony export */ });\n/**\r\n * List of all known components.\r\n */\r\nconst components = [];\r\n/**\r\n * Register a new component.\r\n */\r\nfunction registerComponent(constructor, selector) {\r\n components.push({\r\n selector: selector,\r\n constructor: constructor,\r\n });\r\n}\r\n/**\r\n * TypeDoc application class.\r\n */\r\nclass Application {\r\n /**\r\n * Create a new Application instance.\r\n */\r\n constructor() {\r\n this.createComponents(document.body);\r\n }\r\n /**\r\n * Create all components beneath the given jQuery element.\r\n */\r\n createComponents(context) {\r\n components.forEach(c => {\r\n context.querySelectorAll(c.selector).forEach(el => {\r\n if (!el.dataset.hasInstance) {\r\n new c.constructor({ el: el });\r\n el.dataset.hasInstance = String(true);\r\n }\r\n });\r\n });\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Application.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/Component.ts": +/*!****************************************************!*\ + !*** ./default/assets/js/src/typedoc/Component.ts ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Component\": () => /* binding */ Component\n/* harmony export */ });\n/**\r\n * TypeDoc component class.\r\n */\r\nclass Component {\r\n constructor(options) {\r\n this.el = options.el;\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Component.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/EventTarget.ts": +/*!******************************************************!*\ + !*** ./default/assets/js/src/typedoc/EventTarget.ts ***! + \******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"EventTarget\": () => /* binding */ EventTarget\n/* harmony export */ });\n/**\r\n * TypeDoc event target class.\r\n */\r\nclass EventTarget {\r\n constructor() {\r\n this.listeners = {};\r\n }\r\n addEventListener(type, callback) {\r\n if (!(type in this.listeners)) {\r\n this.listeners[type] = [];\r\n }\r\n this.listeners[type].push(callback);\r\n }\r\n removeEventListener(type, callback) {\r\n if (!(type in this.listeners)) {\r\n return;\r\n }\r\n const stack = this.listeners[type];\r\n for (let i = 0, l = stack.length; i < l; i++) {\r\n if (stack[i] === callback) {\r\n stack.splice(i, 1);\r\n return;\r\n }\r\n }\r\n }\r\n dispatchEvent(event) {\r\n if (!(event.type in this.listeners)) {\r\n return true;\r\n }\r\n const stack = this.listeners[event.type].slice();\r\n for (let i = 0, l = stack.length; i < l; i++) {\r\n stack[i].call(this, event);\r\n }\r\n return !event.defaultPrevented;\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/EventTarget.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/components/Filter.ts": +/*!************************************************************!*\ + !*** ./default/assets/js/src/typedoc/components/Filter.ts ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Filter\": () => /* binding */ Filter\n/* harmony export */ });\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\n\r\n\r\nclass FilterItem {\r\n constructor(key, value) {\r\n this.key = key;\r\n this.value = value;\r\n this.defaultValue = value;\r\n this.initialize();\r\n if (window.localStorage[this.key]) {\r\n this.setValue(this.fromLocalStorage(window.localStorage[this.key]));\r\n }\r\n }\r\n initialize() { }\r\n setValue(value) {\r\n if (this.value == value)\r\n return;\r\n const oldValue = this.value;\r\n this.value = value;\r\n window.localStorage[this.key] = this.toLocalStorage(value);\r\n this.handleValueChange(oldValue, value);\r\n }\r\n}\r\nclass FilterItemCheckbox extends FilterItem {\r\n initialize() {\r\n const checkbox = document.querySelector('#tsd-filter-' + this.key);\r\n if (!checkbox)\r\n return;\r\n this.checkbox = checkbox;\r\n this.checkbox.addEventListener('change', () => {\r\n this.setValue(this.checkbox.checked);\r\n });\r\n }\r\n handleValueChange(oldValue, newValue) {\r\n if (!this.checkbox)\r\n return;\r\n this.checkbox.checked = this.value;\r\n document.documentElement.classList.toggle('toggle-' + this.key, this.value != this.defaultValue);\r\n }\r\n fromLocalStorage(value) {\r\n return value == 'true';\r\n }\r\n toLocalStorage(value) {\r\n return value ? 'true' : 'false';\r\n }\r\n}\r\nclass FilterItemSelect extends FilterItem {\r\n initialize() {\r\n document.documentElement.classList.add('toggle-' + this.key + this.value);\r\n const select = document.querySelector('#tsd-filter-' + this.key);\r\n if (!select)\r\n return;\r\n this.select = select;\r\n const onActivate = () => {\r\n this.select.classList.add('active');\r\n };\r\n const onDeactivate = () => {\r\n this.select.classList.remove('active');\r\n };\r\n this.select.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, onActivate);\r\n this.select.addEventListener('mouseover', onActivate);\r\n this.select.addEventListener('mouseleave', onDeactivate);\r\n this.select.querySelectorAll('li').forEach(el => {\r\n el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, e => {\r\n select.classList.remove('active');\r\n this.setValue(e.target.dataset.value || '');\r\n });\r\n });\r\n document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, e => {\r\n if (this.select.contains(e.target))\r\n return;\r\n this.select.classList.remove('active');\r\n });\r\n }\r\n handleValueChange(oldValue, newValue) {\r\n this.select.querySelectorAll('li.selected').forEach(el => {\r\n el.classList.remove('selected');\r\n });\r\n const selected = this.select.querySelector('li[data-value=\"' + newValue + '\"]');\r\n const label = this.select.querySelector('.tsd-select-label');\r\n if (selected && label) {\r\n selected.classList.add('selected');\r\n label.textContent = selected.textContent;\r\n }\r\n document.documentElement.classList.remove('toggle-' + oldValue);\r\n document.documentElement.classList.add('toggle-' + newValue);\r\n }\r\n fromLocalStorage(value) {\r\n return value;\r\n }\r\n toLocalStorage(value) {\r\n return value;\r\n }\r\n}\r\nclass Filter extends _Component__WEBPACK_IMPORTED_MODULE_0__.Component {\r\n constructor(options) {\r\n super(options);\r\n this.optionVisibility = new FilterItemSelect('visibility', 'private');\r\n this.optionInherited = new FilterItemCheckbox('inherited', true);\r\n this.optionExternals = new FilterItemCheckbox('externals', true);\r\n }\r\n static isSupported() {\r\n try {\r\n return typeof window.localStorage != 'undefined';\r\n }\r\n catch (e) {\r\n return false;\r\n }\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Filter.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/components/MenuHighlight.ts": +/*!*******************************************************************!*\ + !*** ./default/assets/js/src/typedoc/components/MenuHighlight.ts ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"MenuHighlight\": () => /* binding */ MenuHighlight\n/* harmony export */ });\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\n\r\n\r\n/**\r\n * Manages the sticky state of the navigation and moves the highlight\r\n * to the current navigation item.\r\n */\r\nclass MenuHighlight extends _Component__WEBPACK_IMPORTED_MODULE_0__.Component {\r\n /**\r\n * Create a new MenuHighlight instance.\r\n *\r\n * @param options Backbone view constructor options.\r\n */\r\n constructor(options) {\r\n super(options);\r\n /**\r\n * List of all discovered anchors.\r\n */\r\n this.anchors = [];\r\n /**\r\n * Index of the currently highlighted anchor.\r\n */\r\n this.index = -1;\r\n _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener('resize', () => this.onResize());\r\n _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener('scroll', e => this.onScroll(e));\r\n this.createAnchors();\r\n }\r\n /**\r\n * Find all anchors on the current page.\r\n */\r\n createAnchors() {\r\n let base = window.location.href;\r\n if (base.indexOf('#') != -1) {\r\n base = base.substr(0, base.indexOf('#'));\r\n }\r\n this.el.querySelectorAll('a').forEach(el => {\r\n const href = el.href;\r\n if (href.indexOf('#') == -1)\r\n return;\r\n if (href.substr(0, base.length) != base)\r\n return;\r\n const hash = href.substr(href.indexOf('#') + 1);\r\n const anchor = document.querySelector('a.tsd-anchor[name=' + hash + ']');\r\n const link = el.parentNode;\r\n if (!anchor || !link)\r\n return;\r\n this.anchors.push({\r\n link: link,\r\n anchor: anchor,\r\n position: 0,\r\n });\r\n });\r\n this.onResize();\r\n }\r\n /**\r\n * Triggered after the viewport was resized.\r\n */\r\n onResize() {\r\n let anchor;\r\n for (let index = 0, count = this.anchors.length; index < count; index++) {\r\n anchor = this.anchors[index];\r\n const rect = anchor.anchor.getBoundingClientRect();\r\n anchor.position = rect.top + document.body.scrollTop;\r\n }\r\n this.anchors.sort((a, b) => {\r\n return a.position - b.position;\r\n });\r\n const event = new CustomEvent('scroll', {\r\n detail: {\r\n scrollTop: _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.scrollTop,\r\n },\r\n });\r\n this.onScroll(event);\r\n }\r\n /**\r\n * Triggered after the viewport was scrolled.\r\n *\r\n * @param event The custom event with the current vertical scroll position.\r\n */\r\n onScroll(event) {\r\n const scrollTop = event.detail.scrollTop + 5;\r\n const anchors = this.anchors;\r\n const count = anchors.length - 1;\r\n let index = this.index;\r\n while (index > -1 && anchors[index].position > scrollTop) {\r\n index -= 1;\r\n }\r\n while (index < count && anchors[index + 1].position < scrollTop) {\r\n index += 1;\r\n }\r\n if (this.index != index) {\r\n if (this.index > -1)\r\n this.anchors[this.index].link.classList.remove('focus');\r\n this.index = index;\r\n if (this.index > -1)\r\n this.anchors[this.index].link.classList.add('focus');\r\n }\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/MenuHighlight.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/components/Search.ts": +/*!************************************************************!*\ + !*** ./default/assets/js/src/typedoc/components/Search.ts ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"initSearch\": () => /* binding */ initSearch\n/* harmony export */ });\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! lunr */ \"../node_modules/lunr/lunr.js\");\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(lunr__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _utils_debounce__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/debounce */ \"./default/assets/js/src/typedoc/utils/debounce.ts\");\n\r\n\r\nfunction initSearch() {\r\n const searchEl = document.getElementById('tsd-search');\r\n if (!searchEl)\r\n return;\r\n const searchScript = document.getElementById('search-script');\r\n searchEl.classList.add('loading');\r\n if (searchScript) {\r\n searchScript.addEventListener('error', () => {\r\n searchEl.classList.remove('loading');\r\n searchEl.classList.add('failure');\r\n });\r\n searchScript.addEventListener('load', () => {\r\n searchEl.classList.remove('loading');\r\n searchEl.classList.add('ready');\r\n });\r\n if (window.searchData) {\r\n searchEl.classList.remove('loading');\r\n }\r\n }\r\n const field = document.querySelector('#tsd-search-field');\r\n const results = document.querySelector('.results');\r\n if (!field || !results) {\r\n throw new Error('The input field or the result list wrapper was not found');\r\n }\r\n let resultClicked = false;\r\n results.addEventListener('mousedown', () => (resultClicked = true));\r\n results.addEventListener('mouseup', () => {\r\n resultClicked = false;\r\n searchEl.classList.remove('has-focus');\r\n });\r\n field.addEventListener('focus', () => searchEl.classList.add('has-focus'));\r\n field.addEventListener('blur', () => {\r\n if (!resultClicked) {\r\n resultClicked = false;\r\n searchEl.classList.remove('has-focus');\r\n }\r\n });\r\n const state = {\r\n base: searchEl.dataset.base + '/',\r\n };\r\n bindEvents(searchEl, results, field, state);\r\n}\r\nfunction bindEvents(searchEl, results, field, state) {\r\n field.addEventListener('input', (0,_utils_debounce__WEBPACK_IMPORTED_MODULE_1__.debounce)(() => {\r\n updateResults(searchEl, results, field, state);\r\n }, 200));\r\n let preventPress = false;\r\n field.addEventListener('keydown', e => {\r\n preventPress = true;\r\n if (e.key == 'Enter') {\r\n gotoCurrentResult(results, field);\r\n }\r\n else if (e.key == 'Escape') {\r\n field.blur();\r\n }\r\n else if (e.key == 'ArrowUp') {\r\n setCurrentResult(results, -1);\r\n }\r\n else if (e.key === 'ArrowDown') {\r\n setCurrentResult(results, 1);\r\n }\r\n else {\r\n preventPress = false;\r\n }\r\n });\r\n field.addEventListener('keypress', e => {\r\n if (preventPress)\r\n e.preventDefault();\r\n });\r\n /**\r\n * Start searching by pressing slash.\r\n */\r\n document.body.addEventListener('keydown', e => {\r\n if (e.altKey || e.ctrlKey || e.metaKey)\r\n return;\r\n if (!field.matches(':focus') && e.key === '/') {\r\n field.focus();\r\n e.preventDefault();\r\n }\r\n });\r\n}\r\nfunction checkIndex(state, searchEl) {\r\n if (state.index)\r\n return;\r\n if (window.searchData) {\r\n searchEl.classList.remove('loading');\r\n searchEl.classList.add('ready');\r\n state.data = window.searchData;\r\n state.index = lunr__WEBPACK_IMPORTED_MODULE_0__.Index.load(window.searchData.index);\r\n }\r\n}\r\nfunction updateResults(searchEl, results, query, state) {\r\n checkIndex(state, searchEl);\r\n // Don't clear results if loading state is not ready,\r\n // because loading or error message can be removed.\r\n if (!state.index || !state.data)\r\n return;\r\n results.textContent = '';\r\n const searchText = query.value.trim();\r\n // Perform a wildcard search\r\n let res = state.index.search(`*${searchText}*`);\r\n for (let i = 0, c = Math.min(10, res.length); i < c; i++) {\r\n const row = state.data.rows[Number(res[i].ref)];\r\n // Bold the matched part of the query in the search results\r\n let name = boldMatches(row.name, searchText);\r\n if (row.parent) {\r\n name = `${boldMatches(row.parent, searchText)}.${name}`;\r\n }\r\n const item = document.createElement('li');\r\n item.classList.value = row.classes;\r\n const anchor = document.createElement('a');\r\n anchor.href = state.base + row.url;\r\n anchor.classList.add('tsd-kind-icon');\r\n anchor.innerHTML = name;\r\n item.append(anchor);\r\n results.appendChild(item);\r\n }\r\n}\r\n/**\r\n * Move the highlight within the result set.\r\n */\r\nfunction setCurrentResult(results, dir) {\r\n let current = results.querySelector('.current');\r\n if (!current) {\r\n current = results.querySelector(dir == 1 ? 'li:first-child' : 'li:last-child');\r\n if (current) {\r\n current.classList.add('current');\r\n }\r\n }\r\n else {\r\n const rel = dir == 1 ? current.nextElementSibling : current.previousElementSibling;\r\n if (rel) {\r\n current.classList.remove('current');\r\n rel.classList.add('current');\r\n }\r\n }\r\n}\r\n/**\r\n * Navigate to the highlighted result.\r\n */\r\nfunction gotoCurrentResult(results, field) {\r\n let current = results.querySelector('.current');\r\n if (!current) {\r\n current = results.querySelector('li:first-child');\r\n }\r\n if (current) {\r\n const link = current.querySelector('a');\r\n if (link) {\r\n window.location.href = link.href;\r\n }\r\n field.blur();\r\n }\r\n}\r\nfunction boldMatches(text, search) {\r\n if (search === '') {\r\n return text;\r\n }\r\n const lowerText = text.toLocaleLowerCase();\r\n const lowerSearch = search.toLocaleLowerCase();\r\n const parts = [];\r\n let lastIndex = 0;\r\n let index = lowerText.indexOf(lowerSearch);\r\n while (index != -1) {\r\n parts.push(escapeHtml(text.substring(lastIndex, index)), `${escapeHtml(text.substring(index, index + lowerSearch.length))}`);\r\n lastIndex = index + lowerSearch.length;\r\n index = lowerText.indexOf(lowerSearch, lastIndex);\r\n }\r\n parts.push(escapeHtml(text.substring(lastIndex)));\r\n return parts.join('');\r\n}\r\nconst SPECIAL_HTML = {\r\n '&': '&',\r\n '<': '<',\r\n '>': '>',\r\n \"'\": ''',\r\n '\"': '"',\r\n};\r\nfunction escapeHtml(text) {\r\n return text.replace(/[&<>\"'\"]/g, match => SPECIAL_HTML[match]);\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Search.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/components/Signature.ts": +/*!***************************************************************!*\ + !*** ./default/assets/js/src/typedoc/components/Signature.ts ***! + \***************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Signature\": () => /* binding */ Signature\n/* harmony export */ });\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\n\r\n\r\n/**\r\n * Holds a signature and its description.\r\n */\r\nclass SignatureGroup {\r\n /**\r\n * Create a new SignatureGroup instance.\r\n *\r\n * @param signature The target signature.\r\n * @param description The description for the signature.\r\n */\r\n constructor(signature, description) {\r\n this.signature = signature;\r\n this.description = description;\r\n }\r\n /**\r\n * Add the given class to all elements of the group.\r\n *\r\n * @param className The class name to add.\r\n */\r\n addClass(className) {\r\n this.signature.classList.add(className);\r\n this.description.classList.add(className);\r\n return this;\r\n }\r\n /**\r\n * Remove the given class from all elements of the group.\r\n *\r\n * @param className The class name to remove.\r\n */\r\n removeClass(className) {\r\n this.signature.classList.remove(className);\r\n this.description.classList.remove(className);\r\n return this;\r\n }\r\n}\r\n/**\r\n * Controls the tab like behaviour of methods and functions with multiple signatures.\r\n */\r\nclass Signature extends _Component__WEBPACK_IMPORTED_MODULE_0__.Component {\r\n /**\r\n * Create a new Signature instance.\r\n *\r\n * @param options Backbone view constructor options.\r\n */\r\n constructor(options) {\r\n super(options);\r\n /**\r\n * List of found signature groups.\r\n */\r\n this.groups = [];\r\n /**\r\n * The index of the currently displayed signature.\r\n */\r\n this.index = -1;\r\n this.createGroups();\r\n if (this.container) {\r\n this.el.classList.add('active');\r\n Array.from(this.el.children).forEach(signature => {\r\n signature.addEventListener('touchstart', event => this.onClick(event));\r\n signature.addEventListener('click', event => this.onClick(event));\r\n });\r\n this.container.classList.add('active');\r\n this.setIndex(0);\r\n }\r\n }\r\n /**\r\n * Set the index of the active signature.\r\n *\r\n * @param index The index of the signature to activate.\r\n */\r\n setIndex(index) {\r\n if (index < 0)\r\n index = 0;\r\n if (index > this.groups.length - 1)\r\n index = this.groups.length - 1;\r\n if (this.index == index)\r\n return;\r\n const to = this.groups[index];\r\n if (this.index > -1) {\r\n const from = this.groups[this.index];\r\n from.removeClass('current').addClass('fade-out');\r\n to.addClass('current');\r\n to.addClass('fade-in');\r\n _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\r\n setTimeout(() => {\r\n from.removeClass('fade-out');\r\n to.removeClass('fade-in');\r\n }, 300);\r\n }\r\n else {\r\n to.addClass('current');\r\n _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\r\n }\r\n this.index = index;\r\n }\r\n /**\r\n * Find all signature/description groups.\r\n */\r\n createGroups() {\r\n const signatures = this.el.children;\r\n if (signatures.length < 2)\r\n return;\r\n this.container = this.el.nextElementSibling;\r\n const descriptions = this.container.children;\r\n this.groups = [];\r\n for (let index = 0; index < signatures.length; index++) {\r\n this.groups.push(new SignatureGroup(signatures[index], descriptions[index]));\r\n }\r\n }\r\n /**\r\n * Triggered when the user clicks onto a signature header.\r\n *\r\n * @param e The related event object.\r\n */\r\n onClick(e) {\r\n this.groups.forEach((group, index) => {\r\n if (group.signature === e.currentTarget) {\r\n this.setIndex(index);\r\n }\r\n });\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Signature.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/components/Toggle.ts": +/*!************************************************************!*\ + !*** ./default/assets/js/src/typedoc/components/Toggle.ts ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Toggle\": () => /* binding */ Toggle\n/* harmony export */ });\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\n\r\n\r\nclass Toggle extends _Component__WEBPACK_IMPORTED_MODULE_0__.Component {\r\n constructor(options) {\r\n super(options);\r\n this.className = this.el.dataset.toggle || '';\r\n this.el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, e => this.onPointerUp(e));\r\n this.el.addEventListener('click', e => e.preventDefault());\r\n document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, e => this.onDocumentPointerDown(e));\r\n document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, e => this.onDocumentPointerUp(e));\r\n }\r\n setActive(value) {\r\n if (this.active == value)\r\n return;\r\n this.active = value;\r\n document.documentElement.classList.toggle('has-' + this.className, value);\r\n this.el.classList.toggle('active', value);\r\n const transition = (this.active ? 'to-has-' : 'from-has-') + this.className;\r\n document.documentElement.classList.add(transition);\r\n setTimeout(() => document.documentElement.classList.remove(transition), 500);\r\n }\r\n onPointerUp(event) {\r\n if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\r\n return;\r\n this.setActive(true);\r\n event.preventDefault();\r\n }\r\n onDocumentPointerDown(e) {\r\n if (this.active) {\r\n if (e.target.closest('.col-menu, .tsd-filter-group')) {\r\n return;\r\n }\r\n this.setActive(false);\r\n }\r\n }\r\n onDocumentPointerUp(e) {\r\n if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\r\n return;\r\n if (this.active) {\r\n if (e.target.closest('.col-menu')) {\r\n const link = e.target.closest('a');\r\n if (link) {\r\n let href = window.location.href;\r\n if (href.indexOf('#') != -1) {\r\n href = href.substr(0, href.indexOf('#'));\r\n }\r\n if (link.href.substr(0, href.length) == href) {\r\n setTimeout(() => this.setActive(false), 250);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Toggle.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/services/Viewport.ts": +/*!************************************************************!*\ + !*** ./default/assets/js/src/typedoc/services/Viewport.ts ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Viewport\": () => /* binding */ Viewport\n/* harmony export */ });\n/* harmony import */ var _EventTarget__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../EventTarget */ \"./default/assets/js/src/typedoc/EventTarget.ts\");\n/* harmony import */ var _utils_trottle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/trottle */ \"./default/assets/js/src/typedoc/utils/trottle.ts\");\n\r\n\r\n/**\r\n * A global service that monitors the window size and scroll position.\r\n */\r\nclass Viewport extends _EventTarget__WEBPACK_IMPORTED_MODULE_0__.EventTarget {\r\n /**\r\n * Create new Viewport instance.\r\n */\r\n constructor() {\r\n super();\r\n /**\r\n * The current scroll position.\r\n */\r\n this.scrollTop = 0;\r\n /**\r\n * The previous scrollTop.\r\n */\r\n this.lastY = 0;\r\n /**\r\n * The width of the window.\r\n */\r\n this.width = 0;\r\n /**\r\n * The height of the window.\r\n */\r\n this.height = 0;\r\n /**\r\n * Boolean indicating whether the toolbar is shown.\r\n */\r\n this.showToolbar = true;\r\n this.toolbar = document.querySelector('.tsd-page-toolbar');\r\n this.secondaryNav = document.querySelector('.tsd-navigation.secondary');\r\n window.addEventListener('scroll', (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(() => this.onScroll(), 10));\r\n window.addEventListener('resize', (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(() => this.onResize(), 10));\r\n this.onResize();\r\n this.onScroll();\r\n }\r\n /**\r\n * Trigger a resize event.\r\n */\r\n triggerResize() {\r\n const event = new CustomEvent('resize', {\r\n detail: {\r\n width: this.width,\r\n height: this.height,\r\n },\r\n });\r\n this.dispatchEvent(event);\r\n }\r\n /**\r\n * Triggered when the size of the window has changed.\r\n */\r\n onResize() {\r\n this.width = window.innerWidth || 0;\r\n this.height = window.innerHeight || 0;\r\n const event = new CustomEvent('resize', {\r\n detail: {\r\n width: this.width,\r\n height: this.height,\r\n },\r\n });\r\n this.dispatchEvent(event);\r\n }\r\n /**\r\n * Triggered when the user scrolled the viewport.\r\n */\r\n onScroll() {\r\n this.scrollTop = window.scrollY || 0;\r\n const event = new CustomEvent('scroll', {\r\n detail: {\r\n scrollTop: this.scrollTop,\r\n },\r\n });\r\n this.dispatchEvent(event);\r\n this.hideShowToolbar();\r\n }\r\n /**\r\n * Handle hiding/showing of the toolbar.\r\n */\r\n hideShowToolbar() {\r\n const isShown = this.showToolbar;\r\n this.showToolbar = this.lastY >= this.scrollTop || this.scrollTop <= 0;\r\n if (isShown !== this.showToolbar) {\r\n this.toolbar.classList.toggle('tsd-page-toolbar--hide');\r\n this.secondaryNav.classList.toggle('tsd-navigation--toolbar-hide');\r\n }\r\n this.lastY = this.scrollTop;\r\n }\r\n}\r\nViewport.instance = new Viewport();\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/services/Viewport.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/utils/debounce.ts": +/*!*********************************************************!*\ + !*** ./default/assets/js/src/typedoc/utils/debounce.ts ***! + \*********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"debounce\": () => /* binding */ debounce\n/* harmony export */ });\nconst debounce = (fn, wait = 100) => {\r\n let timeout;\r\n return (...args) => {\r\n clearTimeout(timeout);\r\n timeout = setTimeout(() => fn(args), wait);\r\n };\r\n};\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/debounce.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/utils/pointer.ts": +/*!********************************************************!*\ + !*** ./default/assets/js/src/typedoc/utils/pointer.ts ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"pointerDown\": () => /* binding */ pointerDown,\n/* harmony export */ \"pointerMove\": () => /* binding */ pointerMove,\n/* harmony export */ \"pointerUp\": () => /* binding */ pointerUp,\n/* harmony export */ \"pointerDownPosition\": () => /* binding */ pointerDownPosition,\n/* harmony export */ \"preventNextClick\": () => /* binding */ preventNextClick,\n/* harmony export */ \"isPointerDown\": () => /* binding */ isPointerDown,\n/* harmony export */ \"isPointerTouch\": () => /* binding */ isPointerTouch,\n/* harmony export */ \"hasPointerMoved\": () => /* binding */ hasPointerMoved,\n/* harmony export */ \"isMobile\": () => /* binding */ isMobile\n/* harmony export */ });\n/**\r\n * Event name of the pointer down event.\r\n */\r\nlet pointerDown = 'mousedown';\r\n/**\r\n * Event name of the pointer move event.\r\n */\r\nlet pointerMove = 'mousemove';\r\n/**\r\n * Event name of the pointer up event.\r\n */\r\nlet pointerUp = 'mouseup';\r\n/**\r\n * Position the pointer was pressed at.\r\n */\r\nconst pointerDownPosition = {\r\n x: 0,\r\n y: 0,\r\n};\r\n/**\r\n * Should the next click on the document be supressed?\r\n */\r\nlet preventNextClick = false;\r\n/**\r\n * Is the pointer down?\r\n */\r\nlet isPointerDown = false;\r\n/**\r\n * Is the pointer a touch point?\r\n */\r\nlet isPointerTouch = false;\r\n/**\r\n * Did the pointer move since the last down event?\r\n */\r\nlet hasPointerMoved = false;\r\n/**\r\n * Is the user agent a mobile agent?\r\n */\r\nconst isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);\r\ndocument.documentElement.classList.add(isMobile ? 'is-mobile' : 'not-mobile');\r\nif (isMobile && 'ontouchstart' in document.documentElement) {\r\n isPointerTouch = true;\r\n pointerDown = 'touchstart';\r\n pointerMove = 'touchmove';\r\n pointerUp = 'touchend';\r\n}\r\ndocument.addEventListener(pointerDown, e => {\r\n isPointerDown = true;\r\n hasPointerMoved = false;\r\n const t = pointerDown == 'touchstart' ? e.targetTouches[0] : e;\r\n pointerDownPosition.y = t.pageY || 0;\r\n pointerDownPosition.x = t.pageX || 0;\r\n});\r\ndocument.addEventListener(pointerMove, e => {\r\n if (!isPointerDown)\r\n return;\r\n if (!hasPointerMoved) {\r\n const t = pointerDown == 'touchstart' ? e.targetTouches[0] : e;\r\n const x = pointerDownPosition.x - (t.pageX || 0);\r\n const y = pointerDownPosition.y - (t.pageY || 0);\r\n hasPointerMoved = Math.sqrt(x * x + y * y) > 10;\r\n }\r\n});\r\ndocument.addEventListener(pointerUp, () => {\r\n isPointerDown = false;\r\n});\r\ndocument.addEventListener('click', e => {\r\n if (preventNextClick) {\r\n e.preventDefault();\r\n e.stopImmediatePropagation();\r\n preventNextClick = false;\r\n }\r\n});\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/pointer.ts?"); + +/***/ }), + +/***/ "./default/assets/js/src/typedoc/utils/trottle.ts": +/*!********************************************************!*\ + !*** ./default/assets/js/src/typedoc/utils/trottle.ts ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"throttle\": () => /* binding */ throttle\n/* harmony export */ });\nconst throttle = (fn, wait = 100) => {\r\n let time = Date.now();\r\n return (...args) => {\r\n if (time + wait - Date.now() < 0) {\r\n fn(...args);\r\n time = Date.now();\r\n }\r\n };\r\n};\r\n\n\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/trottle.ts?"); + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ if(__webpack_module_cache__[moduleId]) { +/******/ return __webpack_module_cache__[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => module['default'] : +/******/ () => module; +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +/******/ // startup +/******/ // Load entry module +/******/ __webpack_require__("./default/assets/js/src/bootstrap.ts"); +/******/ // This entry module used 'exports' so it can't be inlined +/******/ })() +; \ No newline at end of file diff --git a/docs-release/assets/js/search.js b/docs-release/assets/js/search.js new file mode 100644 index 0000000..44ad556 --- /dev/null +++ b/docs-release/assets/js/search.js @@ -0,0 +1 @@ +window.searchData = {"kinds":{"2":"Namespace","4":"Enumeration","16":"Enumeration member","32":"Variable","64":"Function","128":"Class","256":"Interface","512":"Constructor","1024":"Property","2048":"Method","65536":"Type literal","262144":"Accessor","4194304":"Type alias"},"rows":[{"id":0,"kind":2,"name":"CommandHandler","url":"modules/CommandHandler.html","classes":"tsd-kind-namespace"},{"id":1,"kind":64,"name":"emit","url":"modules/CommandHandler.html#emit","classes":"tsd-kind-function tsd-parent-kind-namespace tsd-has-type-parameter","parent":"CommandHandler"},{"id":2,"kind":64,"name":"on","url":"modules/CommandHandler.html#on","classes":"tsd-kind-function tsd-parent-kind-namespace tsd-has-type-parameter","parent":"CommandHandler"},{"id":3,"kind":64,"name":"once","url":"modules/CommandHandler.html#once","classes":"tsd-kind-function tsd-parent-kind-namespace tsd-has-type-parameter","parent":"CommandHandler"},{"id":4,"kind":64,"name":"getCommandAliasesAndNames","url":"modules/CommandHandler.html#getCommandAliasesAndNames","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":5,"kind":64,"name":"findCommand","url":"modules/CommandHandler.html#findCommand","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":6,"kind":64,"name":"useDefaultEvents","url":"modules/CommandHandler.html#useDefaultEvents","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":7,"kind":64,"name":"useDefaultCommands","url":"modules/CommandHandler.html#useDefaultCommands","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":8,"kind":64,"name":"create","url":"modules/CommandHandler.html#create-1","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":9,"kind":64,"name":"launch","url":"modules/CommandHandler.html#launch-1","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":10,"kind":64,"name":"getPrefixFromMessage","url":"modules/CommandHandler.html#getPrefixFromMessage","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":11,"kind":64,"name":"loadCommand","url":"modules/CommandHandler.html#loadCommand-1","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":12,"kind":64,"name":"loadCommands","url":"modules/CommandHandler.html#loadCommands","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":13,"kind":64,"name":"loadEvent","url":"modules/CommandHandler.html#loadEvent-1","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":14,"kind":64,"name":"loadEvents","url":"modules/CommandHandler.html#loadEvents","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":15,"kind":64,"name":"unloadEvent","url":"modules/CommandHandler.html#unloadEvent","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":16,"kind":64,"name":"unloadCommand","url":"modules/CommandHandler.html#unloadCommand","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":17,"kind":256,"name":"HelpOptions","url":"interfaces/CommandHandler.HelpOptions.html","classes":"tsd-kind-interface tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":18,"kind":1024,"name":"deleteMessageAfterDelay","url":"interfaces/CommandHandler.HelpOptions.html#deleteMessageAfterDelay","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.HelpOptions"},{"id":19,"kind":1024,"name":"globalMenuExcludeCommands","url":"interfaces/CommandHandler.HelpOptions.html#globalMenuExcludeCommands","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.HelpOptions"},{"id":20,"kind":1024,"name":"globalMenuUseList","url":"interfaces/CommandHandler.HelpOptions.html#globalMenuUseList","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.HelpOptions"},{"id":21,"kind":256,"name":"MessageCreateOptions","url":"interfaces/CommandHandler.MessageCreateOptions.html","classes":"tsd-kind-interface tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":22,"kind":1024,"name":"excludeBots","url":"interfaces/CommandHandler.MessageCreateOptions.html#excludeBots","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.MessageCreateOptions"},{"id":23,"kind":1024,"name":"globalTags","url":"interfaces/CommandHandler.MessageCreateOptions.html#globalTags","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.MessageCreateOptions"},{"id":24,"kind":1024,"name":"sendCodeError","url":"interfaces/CommandHandler.MessageCreateOptions.html#sendCodeError","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.MessageCreateOptions"},{"id":25,"kind":1024,"name":"sendCodeErrorOnlyToOwners","url":"interfaces/CommandHandler.MessageCreateOptions.html#sendCodeErrorOnlyToOwners","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.MessageCreateOptions"},{"id":26,"kind":1024,"name":"sendWhenError","url":"interfaces/CommandHandler.MessageCreateOptions.html#sendWhenError","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.MessageCreateOptions"},{"id":27,"kind":256,"name":"CreateCommandHandlerOptions","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html","classes":"tsd-kind-interface tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":28,"kind":1024,"name":"commandsDir","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#commandsDir","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":29,"kind":1024,"name":"eventsDir","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#eventsDir","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":30,"kind":1024,"name":"owners","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#owners","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":31,"kind":1024,"name":"prefixes","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#prefixes","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":32,"kind":1024,"name":"saveLogsInFile","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#saveLogsInFile","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":33,"kind":1024,"name":"useMentionAsPrefix","url":"interfaces/CommandHandler.CreateCommandHandlerOptions.html#useMentionAsPrefix","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CreateCommandHandlerOptions"},{"id":34,"kind":256,"name":"CommandCooldown","url":"interfaces/CommandHandler.CommandCooldown.html","classes":"tsd-kind-interface tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":35,"kind":1024,"name":"cooldown","url":"interfaces/CommandHandler.CommandCooldown.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CommandCooldown"},{"id":36,"kind":1024,"name":"executedAt","url":"interfaces/CommandHandler.CommandCooldown.html#executedAt","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.CommandCooldown"},{"id":37,"kind":4194304,"name":"CooldownUser","url":"modules/CommandHandler.html#CooldownUser","classes":"tsd-kind-type-alias tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":38,"kind":65536,"name":"__type","url":"modules/CommandHandler.html#CooldownUser.__type-1","classes":"tsd-kind-type-literal tsd-parent-kind-type-alias","parent":"CommandHandler.CooldownUser"},{"id":39,"kind":256,"name":"LaunchCommandHandlerOptions","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html","classes":"tsd-kind-interface tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":40,"kind":1024,"name":"addBotAndTeamOwnersToOwners","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#addBotAndTeamOwnersToOwners","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":41,"kind":1024,"name":"clientOptions","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#clientOptions","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":42,"kind":1024,"name":"cycleBetweenPresences","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#cycleBetweenPresences","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":43,"kind":1024,"name":"cycleDuration","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#cycleDuration","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":44,"kind":1024,"name":"presence","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#presence","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":45,"kind":1024,"name":"presences","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#presences","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":46,"kind":1024,"name":"token","url":"interfaces/CommandHandler.LaunchCommandHandlerOptions.html#token","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandHandler.LaunchCommandHandlerOptions"},{"id":47,"kind":4194304,"name":"CommandHandlerEvents","url":"modules/CommandHandler.html#CommandHandlerEvents","classes":"tsd-kind-type-alias tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":48,"kind":65536,"name":"__type","url":"modules/CommandHandler.html#CommandHandlerEvents.__type","classes":"tsd-kind-type-literal tsd-parent-kind-type-alias","parent":"CommandHandler.CommandHandlerEvents"},{"id":49,"kind":1024,"name":"create","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.create","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":50,"kind":1024,"name":"error","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.error","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":51,"kind":1024,"name":"launch","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.launch","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":52,"kind":1024,"name":"loadCommand","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.loadCommand","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":53,"kind":1024,"name":"loadEvent","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.loadEvent","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":54,"kind":1024,"name":"launched","url":"modules/CommandHandler.html#CommandHandlerEvents.__type.launched","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"CommandHandler.CommandHandlerEvents.__type"},{"id":55,"kind":32,"name":"version","url":"modules/CommandHandler.html#version","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":56,"kind":32,"name":"emitter","url":"modules/CommandHandler.html#emitter","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":57,"kind":32,"name":"commands","url":"modules/CommandHandler.html#commands","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":58,"kind":32,"name":"cooldowns","url":"modules/CommandHandler.html#cooldowns","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":59,"kind":32,"name":"events","url":"modules/CommandHandler.html#events","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":60,"kind":32,"name":"commandsDir","url":"modules/CommandHandler.html#commandsDir","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":61,"kind":32,"name":"eventsDir","url":"modules/CommandHandler.html#eventsDir","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":62,"kind":32,"name":"owners","url":"modules/CommandHandler.html#owners","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":63,"kind":32,"name":"prefixes","url":"modules/CommandHandler.html#prefixes","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":64,"kind":32,"name":"client","url":"modules/CommandHandler.html#client","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":65,"kind":32,"name":"presencesInterval","url":"modules/CommandHandler.html#presencesInterval","classes":"tsd-kind-variable tsd-parent-kind-namespace","parent":"CommandHandler"},{"id":66,"kind":128,"name":"AdvancedClient","url":"classes/AdvancedClient.html","classes":"tsd-kind-class"},{"id":67,"kind":512,"name":"constructor","url":"classes/AdvancedClient.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"AdvancedClient"},{"id":68,"kind":262144,"name":"id","url":"classes/AdvancedClient.html#id","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"AdvancedClient"},{"id":69,"kind":262144,"name":"mention","url":"classes/AdvancedClient.html#mention","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"AdvancedClient"},{"id":70,"kind":262144,"name":"ping","url":"classes/AdvancedClient.html#ping","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"AdvancedClient"},{"id":71,"kind":262144,"name":"tag","url":"classes/AdvancedClient.html#tag","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"AdvancedClient"},{"id":72,"kind":262144,"name":"username","url":"classes/AdvancedClient.html#username","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"AdvancedClient"},{"id":73,"kind":4194304,"name":"ArgumentFunction","url":"modules.html#ArgumentFunction","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":74,"kind":65536,"name":"__type","url":"modules.html#ArgumentFunction.__type","classes":"tsd-kind-type-literal tsd-parent-kind-type-alias","parent":"ArgumentFunction"},{"id":75,"kind":4,"name":"ArgumentType","url":"enums/ArgumentType.html","classes":"tsd-kind-enum"},{"id":76,"kind":16,"name":"BOOLEAN","url":"enums/ArgumentType.html#BOOLEAN","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":77,"kind":16,"name":"CHANNEL","url":"enums/ArgumentType.html#CHANNEL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":78,"kind":16,"name":"COMMAND","url":"enums/ArgumentType.html#COMMAND","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":79,"kind":16,"name":"CHOICE","url":"enums/ArgumentType.html#CHOICE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":80,"kind":16,"name":"EMOJI","url":"enums/ArgumentType.html#EMOJI","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":81,"kind":16,"name":"ENUM","url":"enums/ArgumentType.html#ENUM","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":82,"kind":16,"name":"EVENT","url":"enums/ArgumentType.html#EVENT","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":83,"kind":16,"name":"FLOAT","url":"enums/ArgumentType.html#FLOAT","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":84,"kind":16,"name":"GUILD","url":"enums/ArgumentType.html#GUILD","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":85,"kind":16,"name":"GUILD_MEMBER","url":"enums/ArgumentType.html#GUILD_MEMBER","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":86,"kind":16,"name":"INTEGER","url":"enums/ArgumentType.html#INTEGER","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":87,"kind":16,"name":"MESSAGE","url":"enums/ArgumentType.html#MESSAGE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":88,"kind":16,"name":"REGEX","url":"enums/ArgumentType.html#REGEX","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":89,"kind":16,"name":"ROLE","url":"enums/ArgumentType.html#ROLE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":90,"kind":16,"name":"SNOWFLAKE","url":"enums/ArgumentType.html#SNOWFLAKE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":91,"kind":16,"name":"STRING","url":"enums/ArgumentType.html#STRING","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":92,"kind":16,"name":"TEXT_CHANNEL","url":"enums/ArgumentType.html#TEXT_CHANNEL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":93,"kind":16,"name":"USER","url":"enums/ArgumentType.html#USER","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"ArgumentType"},{"id":94,"kind":4194304,"name":"ArgumentBuilder","url":"modules.html#ArgumentBuilder","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":95,"kind":256,"name":"ArgumentOptions","url":"interfaces/ArgumentOptions.html","classes":"tsd-kind-interface tsd-has-type-parameter"},{"id":96,"kind":1024,"name":"coalescing","url":"interfaces/ArgumentOptions.html#coalescing","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ArgumentOptions"},{"id":97,"kind":1024,"name":"defaultValue","url":"interfaces/ArgumentOptions.html#defaultValue","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ArgumentOptions"},{"id":98,"kind":1024,"name":"description","url":"interfaces/ArgumentOptions.html#description","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ArgumentOptions"},{"id":99,"kind":1024,"name":"optional","url":"interfaces/ArgumentOptions.html#optional","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ArgumentOptions"},{"id":100,"kind":128,"name":"Argument","url":"classes/Argument.html","classes":"tsd-kind-class tsd-has-type-parameter"},{"id":101,"kind":512,"name":"constructor","url":"classes/Argument.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-has-type-parameter","parent":"Argument"},{"id":102,"kind":1024,"name":"type","url":"classes/Argument.html#type","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Argument"},{"id":103,"kind":1024,"name":"options","url":"classes/Argument.html#options","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Argument"},{"id":104,"kind":1024,"name":"validator","url":"classes/Argument.html#validator","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Argument"},{"id":105,"kind":1024,"name":"parser","url":"classes/Argument.html#parser","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Argument"},{"id":106,"kind":128,"name":"CommandArgument","url":"classes/CommandArgument.html","classes":"tsd-kind-class tsd-has-type-parameter"},{"id":107,"kind":512,"name":"constructor","url":"classes/CommandArgument.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-has-type-parameter","parent":"CommandArgument"},{"id":108,"kind":1024,"name":"coalescing","url":"classes/CommandArgument.html#coalescing","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":109,"kind":1024,"name":"defaultValue","url":"classes/CommandArgument.html#defaultValue","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":110,"kind":1024,"name":"description","url":"classes/CommandArgument.html#description","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":111,"kind":1024,"name":"optional","url":"classes/CommandArgument.html#optional","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":112,"kind":1024,"name":"parse","url":"classes/CommandArgument.html#parse","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":113,"kind":1024,"name":"type","url":"classes/CommandArgument.html#type","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":114,"kind":1024,"name":"validate","url":"classes/CommandArgument.html#validate","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":115,"kind":1024,"name":"name","url":"classes/CommandArgument.html#name","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":116,"kind":1024,"name":"index","url":"classes/CommandArgument.html#index","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandArgument"},{"id":117,"kind":262144,"name":"isSimple","url":"classes/CommandArgument.html#isSimple","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandArgument"},{"id":118,"kind":262144,"name":"isSkipable","url":"classes/CommandArgument.html#isSkipable","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandArgument"},{"id":119,"kind":4194304,"name":"MapArguments","url":"modules.html#MapArguments","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":120,"kind":4194304,"name":"ArgumentResolved","url":"modules.html#ArgumentResolved","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":121,"kind":128,"name":"ArgumentParser","url":"classes/ArgumentParser.html","classes":"tsd-kind-class"},{"id":122,"kind":1024,"name":"errors","url":"classes/ArgumentParser.html#errors","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-static","parent":"ArgumentParser"},{"id":123,"kind":65536,"name":"__type","url":"classes/ArgumentParser.html#__type","classes":"tsd-kind-type-literal tsd-parent-kind-class","parent":"ArgumentParser"},{"id":124,"kind":1024,"name":"invalidArgument","url":"classes/ArgumentParser.html#__type.invalidArgument","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":125,"kind":65536,"name":"__type","url":"classes/ArgumentParser.html#__type.__type-4","classes":"tsd-kind-type-literal tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":126,"kind":1024,"name":"argumentNotFound","url":"classes/ArgumentParser.html#__type.argumentNotFound","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":127,"kind":65536,"name":"__type","url":"classes/ArgumentParser.html#__type.__type-1","classes":"tsd-kind-type-literal tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":128,"kind":1024,"name":"argumentRequiresOneValue","url":"classes/ArgumentParser.html#__type.argumentRequiresOneValue","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":129,"kind":65536,"name":"__type","url":"classes/ArgumentParser.html#__type.__type-2","classes":"tsd-kind-type-literal tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":130,"kind":1024,"name":"errorInArgument","url":"classes/ArgumentParser.html#__type.errorInArgument","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":131,"kind":65536,"name":"__type","url":"classes/ArgumentParser.html#__type.__type-3","classes":"tsd-kind-type-literal tsd-parent-kind-type-literal","parent":"ArgumentParser.__type"},{"id":132,"kind":2048,"name":"invalidArgumentError","url":"classes/ArgumentParser.html#invalidArgumentError","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"ArgumentParser"},{"id":133,"kind":2048,"name":"argumentNotFoundError","url":"classes/ArgumentParser.html#argumentNotFoundError","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"ArgumentParser"},{"id":134,"kind":2048,"name":"argumentRequiresOneValueError","url":"classes/ArgumentParser.html#argumentRequiresOneValueError","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"ArgumentParser"},{"id":135,"kind":2048,"name":"errorInArgumentError","url":"classes/ArgumentParser.html#errorInArgumentError","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"ArgumentParser"},{"id":136,"kind":512,"name":"constructor","url":"classes/ArgumentParser.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class","parent":"ArgumentParser"},{"id":137,"kind":1024,"name":"parsed","url":"classes/ArgumentParser.html#parsed","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentParser"},{"id":138,"kind":1024,"name":"parser","url":"classes/ArgumentParser.html#parser","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentParser"},{"id":139,"kind":1024,"name":"args","url":"classes/ArgumentParser.html#args","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentParser"},{"id":140,"kind":1024,"name":"rawArgs","url":"classes/ArgumentParser.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentParser"},{"id":141,"kind":2048,"name":"parseArguments","url":"classes/ArgumentParser.html#parseArguments","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"ArgumentParser"},{"id":142,"kind":2048,"name":"resolveArgument","url":"classes/ArgumentParser.html#resolveArgument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"ArgumentParser"},{"id":143,"kind":2048,"name":"resolveArguments","url":"classes/ArgumentParser.html#resolveArguments","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"ArgumentParser"},{"id":144,"kind":64,"name":"booleanArgument","url":"modules.html#booleanArgument","classes":"tsd-kind-function"},{"id":145,"kind":64,"name":"channelArgument","url":"modules.html#channelArgument","classes":"tsd-kind-function"},{"id":146,"kind":64,"name":"choiceArgument","url":"modules.html#choiceArgument","classes":"tsd-kind-function"},{"id":147,"kind":64,"name":"commandArgument","url":"modules.html#commandArgument","classes":"tsd-kind-function"},{"id":148,"kind":64,"name":"emojiArgument","url":"modules.html#emojiArgument","classes":"tsd-kind-function"},{"id":149,"kind":64,"name":"enumArgument","url":"modules.html#enumArgument","classes":"tsd-kind-function tsd-has-type-parameter"},{"id":150,"kind":64,"name":"eventArgument","url":"modules.html#eventArgument","classes":"tsd-kind-function"},{"id":151,"kind":64,"name":"floatArgument","url":"modules.html#floatArgument","classes":"tsd-kind-function"},{"id":152,"kind":64,"name":"guildArgument","url":"modules.html#guildArgument","classes":"tsd-kind-function"},{"id":153,"kind":64,"name":"guildMemberArgument","url":"modules.html#guildMemberArgument","classes":"tsd-kind-function"},{"id":154,"kind":64,"name":"intArgument","url":"modules.html#intArgument","classes":"tsd-kind-function"},{"id":155,"kind":64,"name":"messageArgument","url":"modules.html#messageArgument","classes":"tsd-kind-function"},{"id":156,"kind":64,"name":"snowflakeArgument","url":"modules.html#snowflakeArgument","classes":"tsd-kind-function"},{"id":157,"kind":64,"name":"stringArgument","url":"modules.html#stringArgument","classes":"tsd-kind-function"},{"id":158,"kind":64,"name":"regexArgument","url":"modules.html#regexArgument","classes":"tsd-kind-function"},{"id":159,"kind":64,"name":"textChannelArgument","url":"modules.html#textChannelArgument","classes":"tsd-kind-function"},{"id":160,"kind":64,"name":"userArgument","url":"modules.html#userArgument","classes":"tsd-kind-function"},{"id":161,"kind":4,"name":"Tag","url":"enums/Tag.html","classes":"tsd-kind-enum"},{"id":162,"kind":16,"name":"channelOnly","url":"enums/Tag.html#channelOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":163,"kind":16,"name":"dmOnly","url":"enums/Tag.html#dmOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":164,"kind":16,"name":"guildOnly","url":"enums/Tag.html#guildOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":165,"kind":16,"name":"guildOwnerOnly","url":"enums/Tag.html#guildOwnerOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":166,"kind":16,"name":"ownerOnly","url":"enums/Tag.html#ownerOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":167,"kind":16,"name":"nsfw","url":"enums/Tag.html#nsfw","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":168,"kind":16,"name":"threadOnly","url":"enums/Tag.html#threadOnly","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"Tag"},{"id":169,"kind":2,"name":"Tag","url":"modules/Tag.html","classes":"tsd-kind-namespace"},{"id":170,"kind":64,"name":"check","url":"modules/Tag.html#check","classes":"tsd-kind-function tsd-parent-kind-namespace","parent":"Tag"},{"id":171,"kind":256,"name":"Cooldown","url":"interfaces/Cooldown.html","classes":"tsd-kind-interface"},{"id":172,"kind":1024,"name":"waitMore","url":"interfaces/Cooldown.html#waitMore","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"Cooldown"},{"id":173,"kind":1024,"name":"cooldown","url":"interfaces/Cooldown.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"Cooldown"},{"id":174,"kind":1024,"name":"executedAt","url":"interfaces/Cooldown.html#executedAt","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"Cooldown"},{"id":175,"kind":256,"name":"DeleteMessageOptions","url":"interfaces/DeleteMessageOptions.html","classes":"tsd-kind-interface"},{"id":176,"kind":1024,"name":"message","url":"interfaces/DeleteMessageOptions.html#message","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"DeleteMessageOptions"},{"id":177,"kind":1024,"name":"timeout","url":"interfaces/DeleteMessageOptions.html#timeout","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"DeleteMessageOptions"},{"id":178,"kind":256,"name":"MissingPermissions","url":"interfaces/MissingPermissions.html","classes":"tsd-kind-interface"},{"id":179,"kind":1024,"name":"client","url":"interfaces/MissingPermissions.html#client","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"MissingPermissions"},{"id":180,"kind":1024,"name":"user","url":"interfaces/MissingPermissions.html#user","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"MissingPermissions"},{"id":181,"kind":128,"name":"Command","url":"classes/Command.html","classes":"tsd-kind-class"},{"id":182,"kind":2048,"name":"getSnowflake","url":"classes/Command.html#getSnowflake","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"Command"},{"id":183,"kind":512,"name":"constructor","url":"classes/Command.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class","parent":"Command"},{"id":184,"kind":2048,"name":"registerSubCommands","url":"classes/Command.html#registerSubCommands","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":185,"kind":1024,"name":"aliases","url":"classes/Command.html#aliases","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":186,"kind":1024,"name":"arguments","url":"classes/Command.html#arguments","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":187,"kind":1024,"name":"category","url":"classes/Command.html#category","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":188,"kind":1024,"name":"channels","url":"classes/Command.html#channels","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":189,"kind":1024,"name":"clientPermissions","url":"classes/Command.html#clientPermissions","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":190,"kind":1024,"name":"cooldown","url":"classes/Command.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":191,"kind":1024,"name":"description","url":"classes/Command.html#description","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":192,"kind":1024,"name":"name","url":"classes/Command.html#name","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":193,"kind":1024,"name":"subCommands","url":"classes/Command.html#subCommands","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":194,"kind":1024,"name":"tags","url":"classes/Command.html#tags","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":195,"kind":1024,"name":"usage","url":"classes/Command.html#usage","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":196,"kind":1024,"name":"userPermissions","url":"classes/Command.html#userPermissions","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Command"},{"id":197,"kind":262144,"name":"nameAndAliases","url":"classes/Command.html#nameAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"Command"},{"id":198,"kind":262144,"name":"subCommandsNamesAndAliases","url":"classes/Command.html#subCommandsNamesAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"Command"},{"id":199,"kind":2048,"name":"deleteMessage","url":"classes/Command.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":200,"kind":2048,"name":"execute","url":"classes/Command.html#execute","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":201,"kind":2048,"name":"getCooldown","url":"classes/Command.html#getCooldown","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":202,"kind":2048,"name":"getInvalidPermissions","url":"classes/Command.html#getInvalidPermissions","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":203,"kind":2048,"name":"getMissingPermissions","url":"classes/Command.html#getMissingPermissions","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":204,"kind":2048,"name":"getMissingTags","url":"classes/Command.html#getMissingTags","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":205,"kind":2048,"name":"isInCooldown","url":"classes/Command.html#isInCooldown","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":206,"kind":2048,"name":"isInRightChannel","url":"classes/Command.html#isInRightChannel","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":207,"kind":2048,"name":"run","url":"classes/Command.html#run","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":208,"kind":2048,"name":"setCooldown","url":"classes/Command.html#setCooldown","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":209,"kind":2048,"name":"signature","url":"classes/Command.html#signature","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":210,"kind":2048,"name":"signatures","url":"classes/Command.html#signatures","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":211,"kind":2048,"name":"validate","url":"classes/Command.html#validate","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Command"},{"id":212,"kind":2048,"name":"subCommand","url":"classes/Command.html#subCommand","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-protected","parent":"Command"},{"id":213,"kind":256,"name":"CommandSignatureOptions","url":"interfaces/CommandSignatureOptions.html","classes":"tsd-kind-interface"},{"id":214,"kind":1024,"name":"showDefaultValues","url":"interfaces/CommandSignatureOptions.html#showDefaultValues","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandSignatureOptions"},{"id":215,"kind":1024,"name":"showTypes","url":"interfaces/CommandSignatureOptions.html#showTypes","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandSignatureOptions"},{"id":216,"kind":128,"name":"SubCommand","url":"classes/SubCommand.html","classes":"tsd-kind-class"},{"id":217,"kind":512,"name":"constructor","url":"classes/SubCommand.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"SubCommand"},{"id":218,"kind":1024,"name":"name","url":"classes/SubCommand.html#name","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-overwrite","parent":"SubCommand"},{"id":219,"kind":2048,"name":"run","url":"classes/SubCommand.html#run","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-overwrite","parent":"SubCommand"},{"id":220,"kind":1024,"name":"runFunction","url":"classes/SubCommand.html#runFunction","classes":"tsd-kind-property tsd-parent-kind-class","parent":"SubCommand"},{"id":221,"kind":2048,"name":"registerSubCommands","url":"classes/SubCommand.html#registerSubCommands","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":222,"kind":1024,"name":"aliases","url":"classes/SubCommand.html#aliases","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":223,"kind":1024,"name":"arguments","url":"classes/SubCommand.html#arguments","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":224,"kind":1024,"name":"category","url":"classes/SubCommand.html#category","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":225,"kind":1024,"name":"channels","url":"classes/SubCommand.html#channels","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":226,"kind":1024,"name":"clientPermissions","url":"classes/SubCommand.html#clientPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":227,"kind":1024,"name":"cooldown","url":"classes/SubCommand.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":228,"kind":1024,"name":"description","url":"classes/SubCommand.html#description","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":229,"kind":1024,"name":"subCommands","url":"classes/SubCommand.html#subCommands","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":230,"kind":1024,"name":"tags","url":"classes/SubCommand.html#tags","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":231,"kind":1024,"name":"usage","url":"classes/SubCommand.html#usage","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":232,"kind":1024,"name":"userPermissions","url":"classes/SubCommand.html#userPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":233,"kind":262144,"name":"nameAndAliases","url":"classes/SubCommand.html#nameAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":234,"kind":262144,"name":"subCommandsNamesAndAliases","url":"classes/SubCommand.html#subCommandsNamesAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":235,"kind":2048,"name":"deleteMessage","url":"classes/SubCommand.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":236,"kind":2048,"name":"execute","url":"classes/SubCommand.html#execute","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":237,"kind":2048,"name":"getCooldown","url":"classes/SubCommand.html#getCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":238,"kind":2048,"name":"getInvalidPermissions","url":"classes/SubCommand.html#getInvalidPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":239,"kind":2048,"name":"getMissingPermissions","url":"classes/SubCommand.html#getMissingPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":240,"kind":2048,"name":"getMissingTags","url":"classes/SubCommand.html#getMissingTags","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":241,"kind":2048,"name":"isInCooldown","url":"classes/SubCommand.html#isInCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":242,"kind":2048,"name":"isInRightChannel","url":"classes/SubCommand.html#isInRightChannel","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":243,"kind":2048,"name":"setCooldown","url":"classes/SubCommand.html#setCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":244,"kind":2048,"name":"signature","url":"classes/SubCommand.html#signature","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":245,"kind":2048,"name":"signatures","url":"classes/SubCommand.html#signatures","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":246,"kind":2048,"name":"validate","url":"classes/SubCommand.html#validate","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommand"},{"id":247,"kind":2048,"name":"subCommand","url":"classes/SubCommand.html#subCommand","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited tsd-is-protected","parent":"SubCommand"},{"id":248,"kind":256,"name":"ImageEmbedOptions","url":"interfaces/ImageEmbedOptions.html","classes":"tsd-kind-interface"},{"id":249,"kind":1024,"name":"channel","url":"interfaces/ImageEmbedOptions.html#channel","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedOptions"},{"id":250,"kind":1024,"name":"description","url":"interfaces/ImageEmbedOptions.html#description","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedOptions"},{"id":251,"kind":1024,"name":"link","url":"interfaces/ImageEmbedOptions.html#link","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedOptions"},{"id":252,"kind":1024,"name":"path","url":"interfaces/ImageEmbedOptions.html#path","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedOptions"},{"id":253,"kind":1024,"name":"title","url":"interfaces/ImageEmbedOptions.html#title","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedOptions"},{"id":254,"kind":256,"name":"ImageEmbedContextOptions","url":"interfaces/ImageEmbedContextOptions.html","classes":"tsd-kind-interface"},{"id":255,"kind":1024,"name":"ctx","url":"interfaces/ImageEmbedContextOptions.html#ctx","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageEmbedContextOptions"},{"id":256,"kind":1024,"name":"title","url":"interfaces/ImageEmbedContextOptions.html#title","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageEmbedContextOptions"},{"id":257,"kind":1024,"name":"description","url":"interfaces/ImageEmbedContextOptions.html#description","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageEmbedContextOptions"},{"id":258,"kind":1024,"name":"link","url":"interfaces/ImageEmbedContextOptions.html#link","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageEmbedContextOptions"},{"id":259,"kind":1024,"name":"path","url":"interfaces/ImageEmbedContextOptions.html#path","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageEmbedContextOptions"},{"id":260,"kind":256,"name":"ImageLocalOptions","url":"interfaces/ImageLocalOptions.html","classes":"tsd-kind-interface"},{"id":261,"kind":1024,"name":"channel","url":"interfaces/ImageLocalOptions.html#channel","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageLocalOptions"},{"id":262,"kind":1024,"name":"content","url":"interfaces/ImageLocalOptions.html#content","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageLocalOptions"},{"id":263,"kind":1024,"name":"path","url":"interfaces/ImageLocalOptions.html#path","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageLocalOptions"},{"id":264,"kind":256,"name":"ImageLocalContextOptions","url":"interfaces/ImageLocalContextOptions.html","classes":"tsd-kind-interface"},{"id":265,"kind":1024,"name":"ctx","url":"interfaces/ImageLocalContextOptions.html#ctx","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"ImageLocalContextOptions"},{"id":266,"kind":1024,"name":"path","url":"interfaces/ImageLocalContextOptions.html#path","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageLocalContextOptions"},{"id":267,"kind":1024,"name":"content","url":"interfaces/ImageLocalContextOptions.html#content","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"ImageLocalContextOptions"},{"id":268,"kind":128,"name":"ImageCommand","url":"classes/ImageCommand.html","classes":"tsd-kind-class"},{"id":269,"kind":512,"name":"constructor","url":"classes/ImageCommand.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":270,"kind":2048,"name":"sendImageEmbed","url":"classes/ImageCommand.html#sendImageEmbed","classes":"tsd-kind-method tsd-parent-kind-class","parent":"ImageCommand"},{"id":271,"kind":2048,"name":"sendLocalImage","url":"classes/ImageCommand.html#sendLocalImage","classes":"tsd-kind-method tsd-parent-kind-class","parent":"ImageCommand"},{"id":272,"kind":2048,"name":"registerSubCommands","url":"classes/ImageCommand.html#registerSubCommands","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":273,"kind":1024,"name":"aliases","url":"classes/ImageCommand.html#aliases","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":274,"kind":1024,"name":"arguments","url":"classes/ImageCommand.html#arguments","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":275,"kind":1024,"name":"category","url":"classes/ImageCommand.html#category","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":276,"kind":1024,"name":"channels","url":"classes/ImageCommand.html#channels","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":277,"kind":1024,"name":"clientPermissions","url":"classes/ImageCommand.html#clientPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":278,"kind":1024,"name":"cooldown","url":"classes/ImageCommand.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":279,"kind":1024,"name":"description","url":"classes/ImageCommand.html#description","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":280,"kind":1024,"name":"name","url":"classes/ImageCommand.html#name","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":281,"kind":1024,"name":"subCommands","url":"classes/ImageCommand.html#subCommands","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":282,"kind":1024,"name":"tags","url":"classes/ImageCommand.html#tags","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":283,"kind":1024,"name":"usage","url":"classes/ImageCommand.html#usage","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":284,"kind":1024,"name":"userPermissions","url":"classes/ImageCommand.html#userPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":285,"kind":262144,"name":"nameAndAliases","url":"classes/ImageCommand.html#nameAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":286,"kind":262144,"name":"subCommandsNamesAndAliases","url":"classes/ImageCommand.html#subCommandsNamesAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":287,"kind":2048,"name":"deleteMessage","url":"classes/ImageCommand.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":288,"kind":2048,"name":"execute","url":"classes/ImageCommand.html#execute","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":289,"kind":2048,"name":"getCooldown","url":"classes/ImageCommand.html#getCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":290,"kind":2048,"name":"getInvalidPermissions","url":"classes/ImageCommand.html#getInvalidPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":291,"kind":2048,"name":"getMissingPermissions","url":"classes/ImageCommand.html#getMissingPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":292,"kind":2048,"name":"getMissingTags","url":"classes/ImageCommand.html#getMissingTags","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":293,"kind":2048,"name":"isInCooldown","url":"classes/ImageCommand.html#isInCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":294,"kind":2048,"name":"isInRightChannel","url":"classes/ImageCommand.html#isInRightChannel","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":295,"kind":2048,"name":"run","url":"classes/ImageCommand.html#run","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":296,"kind":2048,"name":"setCooldown","url":"classes/ImageCommand.html#setCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":297,"kind":2048,"name":"signature","url":"classes/ImageCommand.html#signature","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":298,"kind":2048,"name":"signatures","url":"classes/ImageCommand.html#signatures","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":299,"kind":2048,"name":"validate","url":"classes/ImageCommand.html#validate","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ImageCommand"},{"id":300,"kind":2048,"name":"subCommand","url":"classes/ImageCommand.html#subCommand","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited tsd-is-protected","parent":"ImageCommand"},{"id":301,"kind":128,"name":"SlowCommand","url":"classes/SlowCommand.html","classes":"tsd-kind-class"},{"id":302,"kind":512,"name":"constructor","url":"classes/SlowCommand.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":303,"kind":1024,"name":"waitEmoji","url":"classes/SlowCommand.html#waitEmoji","classes":"tsd-kind-property tsd-parent-kind-class","parent":"SlowCommand"},{"id":304,"kind":2048,"name":"startWait","url":"classes/SlowCommand.html#startWait","classes":"tsd-kind-method tsd-parent-kind-class","parent":"SlowCommand"},{"id":305,"kind":2048,"name":"stopWait","url":"classes/SlowCommand.html#stopWait","classes":"tsd-kind-method tsd-parent-kind-class","parent":"SlowCommand"},{"id":306,"kind":2048,"name":"registerSubCommands","url":"classes/SlowCommand.html#registerSubCommands","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":307,"kind":1024,"name":"aliases","url":"classes/SlowCommand.html#aliases","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":308,"kind":1024,"name":"arguments","url":"classes/SlowCommand.html#arguments","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":309,"kind":1024,"name":"category","url":"classes/SlowCommand.html#category","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":310,"kind":1024,"name":"channels","url":"classes/SlowCommand.html#channels","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":311,"kind":1024,"name":"clientPermissions","url":"classes/SlowCommand.html#clientPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":312,"kind":1024,"name":"cooldown","url":"classes/SlowCommand.html#cooldown","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":313,"kind":1024,"name":"description","url":"classes/SlowCommand.html#description","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":314,"kind":1024,"name":"name","url":"classes/SlowCommand.html#name","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":315,"kind":1024,"name":"subCommands","url":"classes/SlowCommand.html#subCommands","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":316,"kind":1024,"name":"tags","url":"classes/SlowCommand.html#tags","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":317,"kind":1024,"name":"usage","url":"classes/SlowCommand.html#usage","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":318,"kind":1024,"name":"userPermissions","url":"classes/SlowCommand.html#userPermissions","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":319,"kind":262144,"name":"nameAndAliases","url":"classes/SlowCommand.html#nameAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":320,"kind":262144,"name":"subCommandsNamesAndAliases","url":"classes/SlowCommand.html#subCommandsNamesAndAliases","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":321,"kind":2048,"name":"deleteMessage","url":"classes/SlowCommand.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":322,"kind":2048,"name":"execute","url":"classes/SlowCommand.html#execute","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":323,"kind":2048,"name":"getCooldown","url":"classes/SlowCommand.html#getCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":324,"kind":2048,"name":"getInvalidPermissions","url":"classes/SlowCommand.html#getInvalidPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":325,"kind":2048,"name":"getMissingPermissions","url":"classes/SlowCommand.html#getMissingPermissions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":326,"kind":2048,"name":"getMissingTags","url":"classes/SlowCommand.html#getMissingTags","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":327,"kind":2048,"name":"isInCooldown","url":"classes/SlowCommand.html#isInCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":328,"kind":2048,"name":"isInRightChannel","url":"classes/SlowCommand.html#isInRightChannel","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":329,"kind":2048,"name":"run","url":"classes/SlowCommand.html#run","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":330,"kind":2048,"name":"setCooldown","url":"classes/SlowCommand.html#setCooldown","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":331,"kind":2048,"name":"signature","url":"classes/SlowCommand.html#signature","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":332,"kind":2048,"name":"signatures","url":"classes/SlowCommand.html#signatures","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":333,"kind":2048,"name":"validate","url":"classes/SlowCommand.html#validate","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SlowCommand"},{"id":334,"kind":2048,"name":"subCommand","url":"classes/SlowCommand.html#subCommand","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited tsd-is-protected","parent":"SlowCommand"},{"id":335,"kind":4194304,"name":"RunSubCommandFunction","url":"modules.html#RunSubCommandFunction","classes":"tsd-kind-type-alias"},{"id":336,"kind":65536,"name":"__type","url":"modules.html#RunSubCommandFunction.__type","classes":"tsd-kind-type-literal tsd-parent-kind-type-alias","parent":"RunSubCommandFunction"},{"id":337,"kind":256,"name":"SubCommandOptions","url":"interfaces/SubCommandOptions.html","classes":"tsd-kind-interface"},{"id":338,"kind":1024,"name":"aliases","url":"interfaces/SubCommandOptions.html#aliases","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":339,"kind":1024,"name":"arguments","url":"interfaces/SubCommandOptions.html#arguments","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":340,"kind":1024,"name":"channels","url":"interfaces/SubCommandOptions.html#channels","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":341,"kind":1024,"name":"description","url":"interfaces/SubCommandOptions.html#description","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":342,"kind":1024,"name":"tags","url":"interfaces/SubCommandOptions.html#tags","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":343,"kind":1024,"name":"usage","url":"interfaces/SubCommandOptions.html#usage","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandOptions"},{"id":344,"kind":128,"name":"Event","url":"classes/Event.html","classes":"tsd-kind-class"},{"id":345,"kind":512,"name":"constructor","url":"classes/Event.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class","parent":"Event"},{"id":346,"kind":1024,"name":"name","url":"classes/Event.html#name","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Event"},{"id":347,"kind":1024,"name":"once","url":"classes/Event.html#once","classes":"tsd-kind-property tsd-parent-kind-class","parent":"Event"},{"id":348,"kind":2048,"name":"run","url":"classes/Event.html#run","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Event"},{"id":349,"kind":2048,"name":"bind","url":"classes/Event.html#bind","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Event"},{"id":350,"kind":2048,"name":"unbind","url":"classes/Event.html#unbind","classes":"tsd-kind-method tsd-parent-kind-class","parent":"Event"},{"id":351,"kind":128,"name":"ArgumentContext","url":"classes/ArgumentContext.html","classes":"tsd-kind-class"},{"id":352,"kind":512,"name":"constructor","url":"classes/ArgumentContext.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"ArgumentContext"},{"id":353,"kind":1024,"name":"currentArgument","url":"classes/ArgumentContext.html#currentArgument","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentContext"},{"id":354,"kind":1024,"name":"index","url":"classes/ArgumentContext.html#index","classes":"tsd-kind-property tsd-parent-kind-class","parent":"ArgumentContext"},{"id":355,"kind":1024,"name":"argumentParser","url":"classes/ArgumentContext.html#argumentParser","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":356,"kind":1024,"name":"command","url":"classes/ArgumentContext.html#command","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":357,"kind":1024,"name":"handler","url":"classes/ArgumentContext.html#handler","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":358,"kind":1024,"name":"message","url":"classes/ArgumentContext.html#message","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":359,"kind":1024,"name":"rawArgs","url":"classes/ArgumentContext.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":360,"kind":262144,"name":"args","url":"classes/ArgumentContext.html#args","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":361,"kind":262144,"name":"argsString","url":"classes/ArgumentContext.html#argsString","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":362,"kind":262144,"name":"arguments","url":"classes/ArgumentContext.html#arguments","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":363,"kind":262144,"name":"channel","url":"classes/ArgumentContext.html#channel","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":364,"kind":262144,"name":"client","url":"classes/ArgumentContext.html#client","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":365,"kind":262144,"name":"commandName","url":"classes/ArgumentContext.html#commandName","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":366,"kind":262144,"name":"content","url":"classes/ArgumentContext.html#content","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":367,"kind":262144,"name":"guild","url":"classes/ArgumentContext.html#guild","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":368,"kind":262144,"name":"isCallingASubCommand","url":"classes/ArgumentContext.html#isCallingASubCommand","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":369,"kind":262144,"name":"member","url":"classes/ArgumentContext.html#member","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":370,"kind":262144,"name":"prefix","url":"classes/ArgumentContext.html#prefix","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":371,"kind":262144,"name":"textChannel","url":"classes/ArgumentContext.html#textChannel","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":372,"kind":262144,"name":"thread","url":"classes/ArgumentContext.html#thread","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":373,"kind":262144,"name":"user","url":"classes/ArgumentContext.html#user","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":374,"kind":2048,"name":"argument","url":"classes/ArgumentContext.html#argument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-inherited","parent":"ArgumentContext"},{"id":375,"kind":2048,"name":"bulkDeleteInChannel","url":"classes/ArgumentContext.html#bulkDeleteInChannel","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":376,"kind":2048,"name":"createThread","url":"classes/ArgumentContext.html#createThread","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":377,"kind":2048,"name":"deleteMessage","url":"classes/ArgumentContext.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":378,"kind":2048,"name":"react","url":"classes/ArgumentContext.html#react","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":379,"kind":2048,"name":"removeAllReactions","url":"classes/ArgumentContext.html#removeAllReactions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":380,"kind":2048,"name":"removeReaction","url":"classes/ArgumentContext.html#removeReaction","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":381,"kind":2048,"name":"removeSelfReaction","url":"classes/ArgumentContext.html#removeSelfReaction","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":382,"kind":2048,"name":"reply","url":"classes/ArgumentContext.html#reply","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":383,"kind":2048,"name":"resolveArgument","url":"classes/ArgumentContext.html#resolveArgument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-inherited","parent":"ArgumentContext"},{"id":384,"kind":2048,"name":"resolveArguments","url":"classes/ArgumentContext.html#resolveArguments","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-inherited","parent":"ArgumentContext"},{"id":385,"kind":2048,"name":"send","url":"classes/ArgumentContext.html#send","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":386,"kind":2048,"name":"sendGlobalHelpMessage","url":"classes/ArgumentContext.html#sendGlobalHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":387,"kind":2048,"name":"sendHelpMessage","url":"classes/ArgumentContext.html#sendHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"ArgumentContext"},{"id":388,"kind":256,"name":"CommandContextBuilder","url":"interfaces/CommandContextBuilder.html","classes":"tsd-kind-interface"},{"id":389,"kind":1024,"name":"command","url":"interfaces/CommandContextBuilder.html#command","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandContextBuilder"},{"id":390,"kind":1024,"name":"handler","url":"interfaces/CommandContextBuilder.html#handler","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandContextBuilder"},{"id":391,"kind":1024,"name":"message","url":"interfaces/CommandContextBuilder.html#message","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandContextBuilder"},{"id":392,"kind":1024,"name":"rawArgs","url":"interfaces/CommandContextBuilder.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandContextBuilder"},{"id":393,"kind":128,"name":"CommandContext","url":"classes/CommandContext.html","classes":"tsd-kind-class"},{"id":394,"kind":512,"name":"constructor","url":"classes/CommandContext.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class","parent":"CommandContext"},{"id":395,"kind":1024,"name":"argumentParser","url":"classes/CommandContext.html#argumentParser","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandContext"},{"id":396,"kind":1024,"name":"command","url":"classes/CommandContext.html#command","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandContext"},{"id":397,"kind":1024,"name":"handler","url":"classes/CommandContext.html#handler","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandContext"},{"id":398,"kind":1024,"name":"message","url":"classes/CommandContext.html#message","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandContext"},{"id":399,"kind":1024,"name":"rawArgs","url":"classes/CommandContext.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandContext"},{"id":400,"kind":262144,"name":"args","url":"classes/CommandContext.html#args","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":401,"kind":262144,"name":"argsString","url":"classes/CommandContext.html#argsString","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":402,"kind":262144,"name":"arguments","url":"classes/CommandContext.html#arguments","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":403,"kind":262144,"name":"channel","url":"classes/CommandContext.html#channel","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":404,"kind":262144,"name":"client","url":"classes/CommandContext.html#client","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":405,"kind":262144,"name":"commandName","url":"classes/CommandContext.html#commandName","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":406,"kind":262144,"name":"content","url":"classes/CommandContext.html#content","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":407,"kind":262144,"name":"guild","url":"classes/CommandContext.html#guild","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":408,"kind":262144,"name":"isCallingASubCommand","url":"classes/CommandContext.html#isCallingASubCommand","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":409,"kind":262144,"name":"member","url":"classes/CommandContext.html#member","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":410,"kind":262144,"name":"prefix","url":"classes/CommandContext.html#prefix","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":411,"kind":262144,"name":"textChannel","url":"classes/CommandContext.html#textChannel","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":412,"kind":262144,"name":"thread","url":"classes/CommandContext.html#thread","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":413,"kind":262144,"name":"user","url":"classes/CommandContext.html#user","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"CommandContext"},{"id":414,"kind":2048,"name":"argument","url":"classes/CommandContext.html#argument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"CommandContext"},{"id":415,"kind":2048,"name":"bulkDeleteInChannel","url":"classes/CommandContext.html#bulkDeleteInChannel","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":416,"kind":2048,"name":"createThread","url":"classes/CommandContext.html#createThread","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":417,"kind":2048,"name":"deleteMessage","url":"classes/CommandContext.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":418,"kind":2048,"name":"react","url":"classes/CommandContext.html#react","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":419,"kind":2048,"name":"removeAllReactions","url":"classes/CommandContext.html#removeAllReactions","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":420,"kind":2048,"name":"removeReaction","url":"classes/CommandContext.html#removeReaction","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":421,"kind":2048,"name":"removeSelfReaction","url":"classes/CommandContext.html#removeSelfReaction","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":422,"kind":2048,"name":"reply","url":"classes/CommandContext.html#reply","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":423,"kind":2048,"name":"resolveArgument","url":"classes/CommandContext.html#resolveArgument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"CommandContext"},{"id":424,"kind":2048,"name":"resolveArguments","url":"classes/CommandContext.html#resolveArguments","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter","parent":"CommandContext"},{"id":425,"kind":2048,"name":"send","url":"classes/CommandContext.html#send","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":426,"kind":2048,"name":"sendGlobalHelpMessage","url":"classes/CommandContext.html#sendGlobalHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":427,"kind":2048,"name":"sendHelpMessage","url":"classes/CommandContext.html#sendHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class","parent":"CommandContext"},{"id":428,"kind":128,"name":"EventContext","url":"classes/EventContext.html","classes":"tsd-kind-class tsd-has-type-parameter"},{"id":429,"kind":512,"name":"constructor","url":"classes/EventContext.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-has-type-parameter","parent":"EventContext"},{"id":430,"kind":1024,"name":"event","url":"classes/EventContext.html#event","classes":"tsd-kind-property tsd-parent-kind-class","parent":"EventContext"},{"id":431,"kind":1024,"name":"handler","url":"classes/EventContext.html#handler","classes":"tsd-kind-property tsd-parent-kind-class","parent":"EventContext"},{"id":432,"kind":262144,"name":"client","url":"classes/EventContext.html#client","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"EventContext"},{"id":433,"kind":262144,"name":"eventName","url":"classes/EventContext.html#eventName","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"EventContext"},{"id":434,"kind":256,"name":"SubCommandContextBuilder","url":"interfaces/SubCommandContextBuilder.html","classes":"tsd-kind-interface"},{"id":435,"kind":1024,"name":"subCommand","url":"interfaces/SubCommandContextBuilder.html#subCommand","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"SubCommandContextBuilder"},{"id":436,"kind":1024,"name":"command","url":"interfaces/SubCommandContextBuilder.html#command","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"SubCommandContextBuilder"},{"id":437,"kind":1024,"name":"handler","url":"interfaces/SubCommandContextBuilder.html#handler","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"SubCommandContextBuilder"},{"id":438,"kind":1024,"name":"message","url":"interfaces/SubCommandContextBuilder.html#message","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"SubCommandContextBuilder"},{"id":439,"kind":1024,"name":"rawArgs","url":"interfaces/SubCommandContextBuilder.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-interface tsd-is-inherited","parent":"SubCommandContextBuilder"},{"id":440,"kind":128,"name":"SubCommandContext","url":"classes/SubCommandContext.html","classes":"tsd-kind-class"},{"id":441,"kind":512,"name":"constructor","url":"classes/SubCommandContext.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"SubCommandContext"},{"id":442,"kind":1024,"name":"subCommand","url":"classes/SubCommandContext.html#subCommand","classes":"tsd-kind-property tsd-parent-kind-class","parent":"SubCommandContext"},{"id":443,"kind":262144,"name":"arguments","url":"classes/SubCommandContext.html#arguments","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":444,"kind":2048,"name":"resolveArguments","url":"classes/SubCommandContext.html#resolveArguments","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-overwrite","parent":"SubCommandContext"},{"id":445,"kind":262144,"name":"subCommandName","url":"classes/SubCommandContext.html#subCommandName","classes":"tsd-kind-get-signature tsd-parent-kind-class","parent":"SubCommandContext"},{"id":446,"kind":1024,"name":"argumentParser","url":"classes/SubCommandContext.html#argumentParser","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":447,"kind":1024,"name":"command","url":"classes/SubCommandContext.html#command","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":448,"kind":1024,"name":"handler","url":"classes/SubCommandContext.html#handler","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":449,"kind":1024,"name":"message","url":"classes/SubCommandContext.html#message","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":450,"kind":1024,"name":"rawArgs","url":"classes/SubCommandContext.html#rawArgs","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":451,"kind":262144,"name":"args","url":"classes/SubCommandContext.html#args","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":452,"kind":262144,"name":"argsString","url":"classes/SubCommandContext.html#argsString","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":453,"kind":262144,"name":"channel","url":"classes/SubCommandContext.html#channel","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":454,"kind":262144,"name":"client","url":"classes/SubCommandContext.html#client","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":455,"kind":262144,"name":"commandName","url":"classes/SubCommandContext.html#commandName","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":456,"kind":262144,"name":"content","url":"classes/SubCommandContext.html#content","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":457,"kind":262144,"name":"guild","url":"classes/SubCommandContext.html#guild","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":458,"kind":262144,"name":"isCallingASubCommand","url":"classes/SubCommandContext.html#isCallingASubCommand","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":459,"kind":262144,"name":"member","url":"classes/SubCommandContext.html#member","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":460,"kind":262144,"name":"prefix","url":"classes/SubCommandContext.html#prefix","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":461,"kind":262144,"name":"textChannel","url":"classes/SubCommandContext.html#textChannel","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":462,"kind":262144,"name":"thread","url":"classes/SubCommandContext.html#thread","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":463,"kind":262144,"name":"user","url":"classes/SubCommandContext.html#user","classes":"tsd-kind-get-signature tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":464,"kind":2048,"name":"argument","url":"classes/SubCommandContext.html#argument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-inherited","parent":"SubCommandContext"},{"id":465,"kind":2048,"name":"bulkDeleteInChannel","url":"classes/SubCommandContext.html#bulkDeleteInChannel","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":466,"kind":2048,"name":"createThread","url":"classes/SubCommandContext.html#createThread","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":467,"kind":2048,"name":"deleteMessage","url":"classes/SubCommandContext.html#deleteMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":468,"kind":2048,"name":"react","url":"classes/SubCommandContext.html#react","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":469,"kind":2048,"name":"removeAllReactions","url":"classes/SubCommandContext.html#removeAllReactions","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":470,"kind":2048,"name":"removeReaction","url":"classes/SubCommandContext.html#removeReaction","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":471,"kind":2048,"name":"removeSelfReaction","url":"classes/SubCommandContext.html#removeSelfReaction","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":472,"kind":2048,"name":"reply","url":"classes/SubCommandContext.html#reply","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":473,"kind":2048,"name":"resolveArgument","url":"classes/SubCommandContext.html#resolveArgument","classes":"tsd-kind-method tsd-parent-kind-class tsd-has-type-parameter tsd-is-inherited","parent":"SubCommandContext"},{"id":474,"kind":2048,"name":"send","url":"classes/SubCommandContext.html#send","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":475,"kind":2048,"name":"sendGlobalHelpMessage","url":"classes/SubCommandContext.html#sendGlobalHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":476,"kind":2048,"name":"sendHelpMessage","url":"classes/SubCommandContext.html#sendHelpMessage","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-inherited","parent":"SubCommandContext"},{"id":477,"kind":4,"name":"CommandErrorType","url":"enums/CommandErrorType.html","classes":"tsd-kind-enum"},{"id":478,"kind":16,"name":"ARGUMENT_NOT_FOUND","url":"enums/CommandErrorType.html#ARGUMENT_NOT_FOUND","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":479,"kind":16,"name":"CLIENT_MISSING_PERMISSIONS","url":"enums/CommandErrorType.html#CLIENT_MISSING_PERMISSIONS","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":480,"kind":16,"name":"COOLDOWN","url":"enums/CommandErrorType.html#COOLDOWN","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":481,"kind":16,"name":"ERROR","url":"enums/CommandErrorType.html#ERROR","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":482,"kind":16,"name":"INVALID_ARGUMENT","url":"enums/CommandErrorType.html#INVALID_ARGUMENT","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":483,"kind":16,"name":"MISSING_TAGS","url":"enums/CommandErrorType.html#MISSING_TAGS","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":484,"kind":16,"name":"USER_MISSING_PERMISSIONS","url":"enums/CommandErrorType.html#USER_MISSING_PERMISSIONS","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":485,"kind":16,"name":"WRONG_CHANNEL","url":"enums/CommandErrorType.html#WRONG_CHANNEL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"CommandErrorType"},{"id":486,"kind":256,"name":"CommandErrorBuilder","url":"interfaces/CommandErrorBuilder.html","classes":"tsd-kind-interface"},{"id":487,"kind":1024,"name":"data","url":"interfaces/CommandErrorBuilder.html#data","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandErrorBuilder"},{"id":488,"kind":1024,"name":"message","url":"interfaces/CommandErrorBuilder.html#message","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandErrorBuilder"},{"id":489,"kind":1024,"name":"type","url":"interfaces/CommandErrorBuilder.html#type","classes":"tsd-kind-property tsd-parent-kind-interface","parent":"CommandErrorBuilder"},{"id":490,"kind":128,"name":"CommandError","url":"classes/CommandError.html","classes":"tsd-kind-class"},{"id":491,"kind":65536,"name":"__type","url":"classes/CommandError.html#__type","classes":"tsd-kind-type-literal tsd-parent-kind-class","parent":"CommandError"},{"id":492,"kind":512,"name":"constructor","url":"classes/CommandError.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"CommandError"},{"id":493,"kind":1024,"name":"data","url":"classes/CommandError.html#data","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandError"},{"id":494,"kind":1024,"name":"type","url":"classes/CommandError.html#type","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandError"},{"id":495,"kind":1024,"name":"date","url":"classes/CommandError.html#date","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"CommandError"},{"id":496,"kind":1024,"name":"where","url":"classes/CommandError.html#where","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-inherited","parent":"CommandError"},{"id":497,"kind":128,"name":"CommandHandlerError","url":"classes/CommandHandlerError.html","classes":"tsd-kind-class"},{"id":498,"kind":65536,"name":"__type","url":"classes/CommandHandlerError.html#__type","classes":"tsd-kind-type-literal tsd-parent-kind-class","parent":"CommandHandlerError"},{"id":499,"kind":512,"name":"constructor","url":"classes/CommandHandlerError.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-overwrite","parent":"CommandHandlerError"},{"id":500,"kind":1024,"name":"date","url":"classes/CommandHandlerError.html#date","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandHandlerError"},{"id":501,"kind":1024,"name":"where","url":"classes/CommandHandlerError.html#where","classes":"tsd-kind-property tsd-parent-kind-class","parent":"CommandHandlerError"},{"id":502,"kind":4194304,"name":"Constructor","url":"modules.html#Constructor","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":503,"kind":512,"name":"__type","url":"modules.html#Constructor.__type","classes":"tsd-kind-constructor tsd-parent-kind-type-alias","parent":"Constructor"},{"id":504,"kind":4194304,"name":"MaybeCommand","url":"modules.html#MaybeCommand","classes":"tsd-kind-type-alias"},{"id":505,"kind":4194304,"name":"MaybeEvent","url":"modules.html#MaybeEvent","classes":"tsd-kind-type-alias"},{"id":506,"kind":4194304,"name":"TextChannelLike","url":"modules.html#TextChannelLike","classes":"tsd-kind-type-alias"},{"id":507,"kind":4194304,"name":"MaybePromise","url":"modules.html#MaybePromise","classes":"tsd-kind-type-alias tsd-has-type-parameter"},{"id":508,"kind":64,"name":"argError","url":"modules.html#argError","classes":"tsd-kind-function"},{"id":509,"kind":64,"name":"codeError","url":"modules.html#codeError","classes":"tsd-kind-function"},{"id":510,"kind":64,"name":"getThing","url":"modules.html#getThing","classes":"tsd-kind-function"},{"id":511,"kind":4,"name":"DataType","url":"enums/DataType.html","classes":"tsd-kind-enum"},{"id":512,"kind":16,"name":"CHANNEL","url":"enums/DataType.html#CHANNEL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":513,"kind":16,"name":"COMMAND","url":"enums/DataType.html#COMMAND","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":514,"kind":16,"name":"EMOTE","url":"enums/DataType.html#EMOTE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":515,"kind":16,"name":"GUILD","url":"enums/DataType.html#GUILD","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":516,"kind":16,"name":"MEMBER","url":"enums/DataType.html#MEMBER","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":517,"kind":16,"name":"MESSAGE","url":"enums/DataType.html#MESSAGE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":518,"kind":16,"name":"ROLE","url":"enums/DataType.html#ROLE","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":519,"kind":16,"name":"TEXT_CHANNEL","url":"enums/DataType.html#TEXT_CHANNEL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":520,"kind":16,"name":"USER","url":"enums/DataType.html#USER","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"DataType"},{"id":521,"kind":64,"name":"saveJSON","url":"modules.html#saveJSON","classes":"tsd-kind-function"},{"id":522,"kind":64,"name":"readJSON","url":"modules.html#readJSON","classes":"tsd-kind-function"},{"id":523,"kind":4194304,"name":"JSONLike","url":"modules.html#JSONLike","classes":"tsd-kind-type-alias"},{"id":524,"kind":4,"name":"LogLevel","url":"enums/LogLevel.html","classes":"tsd-kind-enum"},{"id":525,"kind":16,"name":"OFF","url":"enums/LogLevel.html#OFF","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":526,"kind":16,"name":"ERROR","url":"enums/LogLevel.html#ERROR","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":527,"kind":16,"name":"WARNING","url":"enums/LogLevel.html#WARNING","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":528,"kind":16,"name":"INFO","url":"enums/LogLevel.html#INFO","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":529,"kind":16,"name":"EVENT","url":"enums/LogLevel.html#EVENT","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":530,"kind":16,"name":"LOG","url":"enums/LogLevel.html#LOG","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":531,"kind":16,"name":"DEBUG","url":"enums/LogLevel.html#DEBUG","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":532,"kind":16,"name":"COMMENT","url":"enums/LogLevel.html#COMMENT","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":533,"kind":16,"name":"ALL","url":"enums/LogLevel.html#ALL","classes":"tsd-kind-enum-member tsd-parent-kind-enum","parent":"LogLevel"},{"id":534,"kind":32,"name":"LogType","url":"modules.html#LogType","classes":"tsd-kind-variable"},{"id":535,"kind":65536,"name":"__type","url":"modules.html#LogType.__type","classes":"tsd-kind-type-literal tsd-parent-kind-variable","parent":"LogType"},{"id":536,"kind":1024,"name":"error","url":"modules.html#LogType.__type.error","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":537,"kind":1024,"name":"warn","url":"modules.html#LogType.__type.warn","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":538,"kind":1024,"name":"info","url":"modules.html#LogType.__type.info","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":539,"kind":1024,"name":"event","url":"modules.html#LogType.__type.event","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":540,"kind":1024,"name":"log","url":"modules.html#LogType.__type.log","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":541,"kind":1024,"name":"debug","url":"modules.html#LogType.__type.debug","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":542,"kind":1024,"name":"comment","url":"modules.html#LogType.__type.comment","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"LogType.__type"},{"id":543,"kind":32,"name":"colors","url":"modules.html#colors","classes":"tsd-kind-variable"},{"id":544,"kind":65536,"name":"__type","url":"modules.html#colors.__type","classes":"tsd-kind-type-literal tsd-parent-kind-variable","parent":"colors"},{"id":545,"kind":1024,"name":"red","url":"modules.html#colors.__type.red","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":546,"kind":1024,"name":"orange","url":"modules.html#colors.__type.orange","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":547,"kind":1024,"name":"gold","url":"modules.html#colors.__type.gold","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":548,"kind":1024,"name":"yellow","url":"modules.html#colors.__type.yellow","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":549,"kind":1024,"name":"green","url":"modules.html#colors.__type.green","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":550,"kind":1024,"name":"teal","url":"modules.html#colors.__type.teal","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":551,"kind":1024,"name":"blue","url":"modules.html#colors.__type.blue","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":552,"kind":1024,"name":"indigo","url":"modules.html#colors.__type.indigo","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":553,"kind":1024,"name":"violet","url":"modules.html#colors.__type.violet","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":554,"kind":1024,"name":"magenta","url":"modules.html#colors.__type.magenta","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":555,"kind":1024,"name":"pink","url":"modules.html#colors.__type.pink","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":556,"kind":1024,"name":"brown","url":"modules.html#colors.__type.brown","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":557,"kind":1024,"name":"black","url":"modules.html#colors.__type.black","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":558,"kind":1024,"name":"grey","url":"modules.html#colors.__type.grey","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":559,"kind":1024,"name":"white","url":"modules.html#colors.__type.white","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":560,"kind":1024,"name":"default","url":"modules.html#colors.__type.default","classes":"tsd-kind-property tsd-parent-kind-type-literal","parent":"colors.__type"},{"id":561,"kind":4194304,"name":"ColorResolvable","url":"modules.html#ColorResolvable","classes":"tsd-kind-type-alias"},{"id":562,"kind":4194304,"name":"LoggerIgnore","url":"modules.html#LoggerIgnore","classes":"tsd-kind-type-alias"},{"id":563,"kind":128,"name":"Logger","url":"classes/Logger.html","classes":"tsd-kind-class"},{"id":564,"kind":1024,"name":"LEVEL","url":"classes/Logger.html#LEVEL","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":565,"kind":1024,"name":"ignores","url":"classes/Logger.html#ignores","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":566,"kind":1024,"name":"savingFiles","url":"classes/Logger.html#savingFiles","classes":"tsd-kind-property tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":567,"kind":2048,"name":"saveInFile","url":"classes/Logger.html#saveInFile","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":568,"kind":2048,"name":"comment","url":"classes/Logger.html#comment","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":569,"kind":2048,"name":"error","url":"classes/Logger.html#error","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":570,"kind":2048,"name":"event","url":"classes/Logger.html#event","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":571,"kind":2048,"name":"info","url":"classes/Logger.html#info","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":572,"kind":2048,"name":"log","url":"classes/Logger.html#log","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":573,"kind":2048,"name":"setColor","url":"classes/Logger.html#setColor","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":574,"kind":2048,"name":"debug","url":"classes/Logger.html#debug","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":575,"kind":2048,"name":"warn","url":"classes/Logger.html#warn","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":576,"kind":2048,"name":"isIgnored","url":"classes/Logger.html#isIgnored","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-static","parent":"Logger"},{"id":577,"kind":2048,"name":"process","url":"classes/Logger.html#process","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-protected tsd-is-static","parent":"Logger"},{"id":578,"kind":2048,"name":"getColorFromColorResolvable","url":"classes/Logger.html#getColorFromColorResolvable","classes":"tsd-kind-method tsd-parent-kind-class tsd-is-private tsd-is-static","parent":"Logger"},{"id":579,"kind":512,"name":"constructor","url":"classes/Logger.html#constructor","classes":"tsd-kind-constructor tsd-parent-kind-class tsd-is-private","parent":"Logger"},{"id":580,"kind":64,"name":"permissionsError","url":"modules.html#permissionsError","classes":"tsd-kind-function"},{"id":581,"kind":64,"name":"isPermission","url":"modules.html#isPermission","classes":"tsd-kind-function"},{"id":582,"kind":64,"name":"cutIfTooLong","url":"modules.html#cutIfTooLong","classes":"tsd-kind-function"},{"id":583,"kind":64,"name":"getKeyByValue","url":"modules.html#getKeyByValue","classes":"tsd-kind-function tsd-has-type-parameter"},{"id":584,"kind":64,"name":"isOwner","url":"modules.html#isOwner","classes":"tsd-kind-function"},{"id":585,"kind":64,"name":"isSnowflake","url":"modules.html#isSnowflake","classes":"tsd-kind-function"},{"id":586,"kind":64,"name":"isTextChannelLike","url":"modules.html#isTextChannelLike","classes":"tsd-kind-function"},{"id":587,"kind":64,"name":"random","url":"modules.html#random","classes":"tsd-kind-function tsd-has-type-parameter"}],"index":{"version":"2.3.9","fields":["name","parent"],"fieldVectors":[["name/0",[0,28.089]],["parent/0",[]],["name/1",[1,59.73]],["parent/1",[0,2.637]],["name/2",[2,59.73]],["parent/2",[0,2.637]],["name/3",[3,54.621]],["parent/3",[0,2.637]],["name/4",[4,59.73]],["parent/4",[0,2.637]],["name/5",[5,59.73]],["parent/5",[0,2.637]],["name/6",[6,59.73]],["parent/6",[0,2.637]],["name/7",[7,59.73]],["parent/7",[0,2.637]],["name/8",[8,54.621]],["parent/8",[0,2.637]],["name/9",[9,54.621]],["parent/9",[0,2.637]],["name/10",[10,59.73]],["parent/10",[0,2.637]],["name/11",[11,54.621]],["parent/11",[0,2.637]],["name/12",[12,59.73]],["parent/12",[0,2.637]],["name/13",[13,54.621]],["parent/13",[0,2.637]],["name/14",[14,59.73]],["parent/14",[0,2.637]],["name/15",[15,59.73]],["parent/15",[0,2.637]],["name/16",[16,59.73]],["parent/16",[0,2.637]],["name/17",[17,59.73]],["parent/17",[0,2.637]],["name/18",[18,59.73]],["parent/18",[19,4.811]],["name/19",[20,59.73]],["parent/19",[19,4.811]],["name/20",[21,59.73]],["parent/20",[19,4.811]],["name/21",[22,59.73]],["parent/21",[0,2.637]],["name/22",[23,59.73]],["parent/22",[24,4.387]],["name/23",[25,59.73]],["parent/23",[24,4.387]],["name/24",[26,59.73]],["parent/24",[24,4.387]],["name/25",[27,59.73]],["parent/25",[24,4.387]],["name/26",[28,59.73]],["parent/26",[24,4.387]],["name/27",[29,59.73]],["parent/27",[0,2.637]],["name/28",[30,54.621]],["parent/28",[31,4.23]],["name/29",[32,54.621]],["parent/29",[31,4.23]],["name/30",[33,54.621]],["parent/30",[31,4.23]],["name/31",[34,54.621]],["parent/31",[31,4.23]],["name/32",[35,59.73]],["parent/32",[31,4.23]],["name/33",[36,59.73]],["parent/33",[31,4.23]],["name/34",[37,59.73]],["parent/34",[0,2.637]],["name/35",[38,39.361]],["parent/35",[39,5.127]],["name/36",[40,54.621]],["parent/36",[39,5.127]],["name/37",[41,59.73]],["parent/37",[0,2.637]],["name/38",[42,37.043]],["parent/38",[43,5.607]],["name/39",[44,59.73]],["parent/39",[0,2.637]],["name/40",[45,59.73]],["parent/40",[46,4.096]],["name/41",[47,59.73]],["parent/41",[46,4.096]],["name/42",[48,59.73]],["parent/42",[46,4.096]],["name/43",[49,59.73]],["parent/43",[46,4.096]],["name/44",[50,59.73]],["parent/44",[46,4.096]],["name/45",[51,59.73]],["parent/45",[46,4.096]],["name/46",[52,59.73]],["parent/46",[46,4.096]],["name/47",[53,59.73]],["parent/47",[0,2.637]],["name/48",[42,37.043]],["parent/48",[54,5.607]],["name/49",[8,54.621]],["parent/49",[55,4.23]],["name/50",[56,46.737]],["parent/50",[55,4.23]],["name/51",[9,54.621]],["parent/51",[55,4.23]],["name/52",[11,54.621]],["parent/52",[55,4.23]],["name/53",[13,54.621]],["parent/53",[55,4.23]],["name/54",[57,59.73]],["parent/54",[55,4.23]],["name/55",[58,59.73]],["parent/55",[0,2.637]],["name/56",[59,59.73]],["parent/56",[0,2.637]],["name/57",[60,59.73]],["parent/57",[0,2.637]],["name/58",[61,59.73]],["parent/58",[0,2.637]],["name/59",[62,59.73]],["parent/59",[0,2.637]],["name/60",[30,54.621]],["parent/60",[0,2.637]],["name/61",[32,54.621]],["parent/61",[0,2.637]],["name/62",[33,54.621]],["parent/62",[0,2.637]],["name/63",[34,54.621]],["parent/63",[0,2.637]],["name/64",[63,45.066]],["parent/64",[0,2.637]],["name/65",[64,59.73]],["parent/65",[0,2.637]],["name/66",[65,43.635]],["parent/66",[]],["name/67",[66,34.607]],["parent/67",[65,4.096]],["name/68",[67,59.73]],["parent/68",[65,4.096]],["name/69",[68,59.73]],["parent/69",[65,4.096]],["name/70",[69,59.73]],["parent/70",[65,4.096]],["name/71",[70,39.361]],["parent/71",[65,4.096]],["name/72",[71,59.73]],["parent/72",[65,4.096]],["name/73",[72,54.621]],["parent/73",[]],["name/74",[42,37.043]],["parent/74",[72,5.127]],["name/75",[73,34.08]],["parent/75",[]],["name/76",[74,59.73]],["parent/76",[73,3.199]],["name/77",[75,43.635]],["parent/77",[73,3.199]],["name/78",[76,27.021]],["parent/78",[73,3.199]],["name/79",[77,59.73]],["parent/79",[73,3.199]],["name/80",[78,59.73]],["parent/80",[73,3.199]],["name/81",[79,59.73]],["parent/81",[73,3.199]],["name/82",[80,38.527]],["parent/82",[73,3.199]],["name/83",[81,59.73]],["parent/83",[73,3.199]],["name/84",[82,46.737]],["parent/84",[73,3.199]],["name/85",[83,59.73]],["parent/85",[73,3.199]],["name/86",[84,59.73]],["parent/86",[73,3.199]],["name/87",[85,41.271]],["parent/87",[73,3.199]],["name/88",[86,59.73]],["parent/88",[73,3.199]],["name/89",[87,54.621]],["parent/89",[73,3.199]],["name/90",[88,59.73]],["parent/90",[73,3.199]],["name/91",[89,59.73]],["parent/91",[73,3.199]],["name/92",[90,54.621]],["parent/92",[73,3.199]],["name/93",[91,45.066]],["parent/93",[73,3.199]],["name/94",[92,59.73]],["parent/94",[]],["name/95",[93,46.737]],["parent/95",[]],["name/96",[94,54.621]],["parent/96",[93,4.387]],["name/97",[95,54.621]],["parent/97",[93,4.387]],["name/98",[96,41.271]],["parent/98",[93,4.387]],["name/99",[97,54.621]],["parent/99",[93,4.387]],["name/100",[98,41.271]],["parent/100",[]],["name/101",[66,34.607]],["parent/101",[98,3.874]],["name/102",[99,48.743]],["parent/102",[98,3.874]],["name/103",[100,59.73]],["parent/103",[98,3.874]],["name/104",[101,59.73]],["parent/104",[98,3.874]],["name/105",[102,54.621]],["parent/105",[98,3.874]],["name/106",[103,37.043]],["parent/106",[]],["name/107",[66,34.607]],["parent/107",[103,3.477]],["name/108",[94,54.621]],["parent/108",[103,3.477]],["name/109",[95,54.621]],["parent/109",[103,3.477]],["name/110",[96,41.271]],["parent/110",[103,3.477]],["name/111",[97,54.621]],["parent/111",[103,3.477]],["name/112",[104,59.73]],["parent/112",[103,3.477]],["name/113",[99,48.743]],["parent/113",[103,3.477]],["name/114",[105,46.737]],["parent/114",[103,3.477]],["name/115",[106,45.066]],["parent/115",[103,3.477]],["name/116",[107,54.621]],["parent/116",[103,3.477]],["name/117",[108,59.73]],["parent/117",[103,3.477]],["name/118",[109,59.73]],["parent/118",[103,3.477]],["name/119",[110,59.73]],["parent/119",[]],["name/120",[111,59.73]],["parent/120",[]],["name/121",[112,34.607]],["parent/121",[]],["name/122",[113,59.73]],["parent/122",[112,3.248]],["name/123",[42,37.043]],["parent/123",[112,3.248]],["name/124",[114,59.73]],["parent/124",[115,3.978]],["name/125",[42,37.043]],["parent/125",[115,3.978]],["name/126",[116,59.73]],["parent/126",[115,3.978]],["name/127",[42,37.043]],["parent/127",[115,3.978]],["name/128",[117,59.73]],["parent/128",[115,3.978]],["name/129",[42,37.043]],["parent/129",[115,3.978]],["name/130",[118,59.73]],["parent/130",[115,3.978]],["name/131",[42,37.043]],["parent/131",[115,3.978]],["name/132",[119,59.73]],["parent/132",[112,3.248]],["name/133",[120,59.73]],["parent/133",[112,3.248]],["name/134",[121,59.73]],["parent/134",[112,3.248]],["name/135",[122,59.73]],["parent/135",[112,3.248]],["name/136",[66,34.607]],["parent/136",[112,3.248]],["name/137",[123,59.73]],["parent/137",[112,3.248]],["name/138",[102,54.621]],["parent/138",[112,3.248]],["name/139",[124,48.743]],["parent/139",[112,3.248]],["name/140",[125,45.066]],["parent/140",[112,3.248]],["name/141",[126,59.73]],["parent/141",[112,3.248]],["name/142",[127,48.743]],["parent/142",[112,3.248]],["name/143",[128,48.743]],["parent/143",[112,3.248]],["name/144",[129,59.73]],["parent/144",[]],["name/145",[130,59.73]],["parent/145",[]],["name/146",[131,59.73]],["parent/146",[]],["name/147",[103,37.043]],["parent/147",[]],["name/148",[132,59.73]],["parent/148",[]],["name/149",[133,59.73]],["parent/149",[]],["name/150",[134,59.73]],["parent/150",[]],["name/151",[135,59.73]],["parent/151",[]],["name/152",[136,59.73]],["parent/152",[]],["name/153",[137,59.73]],["parent/153",[]],["name/154",[138,59.73]],["parent/154",[]],["name/155",[139,59.73]],["parent/155",[]],["name/156",[140,59.73]],["parent/156",[]],["name/157",[141,59.73]],["parent/157",[]],["name/158",[142,59.73]],["parent/158",[]],["name/159",[143,59.73]],["parent/159",[]],["name/160",[144,59.73]],["parent/160",[]],["name/161",[70,39.361]],["parent/161",[]],["name/162",[145,59.73]],["parent/162",[70,3.695]],["name/163",[146,59.73]],["parent/163",[70,3.695]],["name/164",[147,59.73]],["parent/164",[70,3.695]],["name/165",[148,59.73]],["parent/165",[70,3.695]],["name/166",[149,59.73]],["parent/166",[70,3.695]],["name/167",[150,59.73]],["parent/167",[70,3.695]],["name/168",[151,59.73]],["parent/168",[70,3.695]],["name/169",[70,39.361]],["parent/169",[]],["name/170",[152,59.73]],["parent/170",[70,3.695]],["name/171",[38,39.361]],["parent/171",[]],["name/172",[153,59.73]],["parent/172",[38,3.695]],["name/173",[38,39.361]],["parent/173",[38,3.695]],["name/174",[40,54.621]],["parent/174",[38,3.695]],["name/175",[154,51.257]],["parent/175",[]],["name/176",[85,41.271]],["parent/176",[154,4.811]],["name/177",[155,59.73]],["parent/177",[154,4.811]],["name/178",[156,51.257]],["parent/178",[]],["name/179",[63,45.066]],["parent/179",[156,4.811]],["name/180",[91,45.066]],["parent/180",[156,4.811]],["name/181",[76,27.021]],["parent/181",[]],["name/182",[157,59.73]],["parent/182",[76,2.536]],["name/183",[66,34.607]],["parent/183",[76,2.536]],["name/184",[158,48.743]],["parent/184",[76,2.536]],["name/185",[159,46.737]],["parent/185",[76,2.536]],["name/186",[160,42.384]],["parent/186",[76,2.536]],["name/187",[161,48.743]],["parent/187",[76,2.536]],["name/188",[162,46.737]],["parent/188",[76,2.536]],["name/189",[163,48.743]],["parent/189",[76,2.536]],["name/190",[38,39.361]],["parent/190",[76,2.536]],["name/191",[96,41.271]],["parent/191",[76,2.536]],["name/192",[106,45.066]],["parent/192",[76,2.536]],["name/193",[164,48.743]],["parent/193",[76,2.536]],["name/194",[165,46.737]],["parent/194",[76,2.536]],["name/195",[166,46.737]],["parent/195",[76,2.536]],["name/196",[167,48.743]],["parent/196",[76,2.536]],["name/197",[168,48.743]],["parent/197",[76,2.536]],["name/198",[169,48.743]],["parent/198",[76,2.536]],["name/199",[170,43.635]],["parent/199",[76,2.536]],["name/200",[171,48.743]],["parent/200",[76,2.536]],["name/201",[172,48.743]],["parent/201",[76,2.536]],["name/202",[173,48.743]],["parent/202",[76,2.536]],["name/203",[174,48.743]],["parent/203",[76,2.536]],["name/204",[175,48.743]],["parent/204",[76,2.536]],["name/205",[176,48.743]],["parent/205",[76,2.536]],["name/206",[177,48.743]],["parent/206",[76,2.536]],["name/207",[178,46.737]],["parent/207",[76,2.536]],["name/208",[179,48.743]],["parent/208",[76,2.536]],["name/209",[180,48.743]],["parent/209",[76,2.536]],["name/210",[181,48.743]],["parent/210",[76,2.536]],["name/211",[105,46.737]],["parent/211",[76,2.536]],["name/212",[182,27.278]],["parent/212",[76,2.536]],["name/213",[183,51.257]],["parent/213",[]],["name/214",[184,59.73]],["parent/214",[183,4.811]],["name/215",[185,59.73]],["parent/215",[183,4.811]],["name/216",[182,27.278]],["parent/216",[]],["name/217",[66,34.607]],["parent/217",[182,2.56]],["name/218",[106,45.066]],["parent/218",[182,2.56]],["name/219",[178,46.737]],["parent/219",[182,2.56]],["name/220",[186,59.73]],["parent/220",[182,2.56]],["name/221",[158,48.743]],["parent/221",[182,2.56]],["name/222",[159,46.737]],["parent/222",[182,2.56]],["name/223",[160,42.384]],["parent/223",[182,2.56]],["name/224",[161,48.743]],["parent/224",[182,2.56]],["name/225",[162,46.737]],["parent/225",[182,2.56]],["name/226",[163,48.743]],["parent/226",[182,2.56]],["name/227",[38,39.361]],["parent/227",[182,2.56]],["name/228",[96,41.271]],["parent/228",[182,2.56]],["name/229",[164,48.743]],["parent/229",[182,2.56]],["name/230",[165,46.737]],["parent/230",[182,2.56]],["name/231",[166,46.737]],["parent/231",[182,2.56]],["name/232",[167,48.743]],["parent/232",[182,2.56]],["name/233",[168,48.743]],["parent/233",[182,2.56]],["name/234",[169,48.743]],["parent/234",[182,2.56]],["name/235",[170,43.635]],["parent/235",[182,2.56]],["name/236",[171,48.743]],["parent/236",[182,2.56]],["name/237",[172,48.743]],["parent/237",[182,2.56]],["name/238",[173,48.743]],["parent/238",[182,2.56]],["name/239",[174,48.743]],["parent/239",[182,2.56]],["name/240",[175,48.743]],["parent/240",[182,2.56]],["name/241",[176,48.743]],["parent/241",[182,2.56]],["name/242",[177,48.743]],["parent/242",[182,2.56]],["name/243",[179,48.743]],["parent/243",[182,2.56]],["name/244",[180,48.743]],["parent/244",[182,2.56]],["name/245",[181,48.743]],["parent/245",[182,2.56]],["name/246",[105,46.737]],["parent/246",[182,2.56]],["name/247",[182,27.278]],["parent/247",[182,2.56]],["name/248",[187,45.066]],["parent/248",[]],["name/249",[75,43.635]],["parent/249",[187,4.23]],["name/250",[96,41.271]],["parent/250",[187,4.23]],["name/251",[188,54.621]],["parent/251",[187,4.23]],["name/252",[189,48.743]],["parent/252",[187,4.23]],["name/253",[190,54.621]],["parent/253",[187,4.23]],["name/254",[191,45.066]],["parent/254",[]],["name/255",[192,54.621]],["parent/255",[191,4.23]],["name/256",[190,54.621]],["parent/256",[191,4.23]],["name/257",[96,41.271]],["parent/257",[191,4.23]],["name/258",[188,54.621]],["parent/258",[191,4.23]],["name/259",[189,48.743]],["parent/259",[191,4.23]],["name/260",[193,48.743]],["parent/260",[]],["name/261",[75,43.635]],["parent/261",[193,4.575]],["name/262",[194,46.737]],["parent/262",[193,4.575]],["name/263",[189,48.743]],["parent/263",[193,4.575]],["name/264",[195,48.743]],["parent/264",[]],["name/265",[192,54.621]],["parent/265",[195,4.575]],["name/266",[189,48.743]],["parent/266",[195,4.575]],["name/267",[194,46.737]],["parent/267",[195,4.575]],["name/268",[196,28.669]],["parent/268",[]],["name/269",[66,34.607]],["parent/269",[196,2.691]],["name/270",[197,59.73]],["parent/270",[196,2.691]],["name/271",[198,59.73]],["parent/271",[196,2.691]],["name/272",[158,48.743]],["parent/272",[196,2.691]],["name/273",[159,46.737]],["parent/273",[196,2.691]],["name/274",[160,42.384]],["parent/274",[196,2.691]],["name/275",[161,48.743]],["parent/275",[196,2.691]],["name/276",[162,46.737]],["parent/276",[196,2.691]],["name/277",[163,48.743]],["parent/277",[196,2.691]],["name/278",[38,39.361]],["parent/278",[196,2.691]],["name/279",[96,41.271]],["parent/279",[196,2.691]],["name/280",[106,45.066]],["parent/280",[196,2.691]],["name/281",[164,48.743]],["parent/281",[196,2.691]],["name/282",[165,46.737]],["parent/282",[196,2.691]],["name/283",[166,46.737]],["parent/283",[196,2.691]],["name/284",[167,48.743]],["parent/284",[196,2.691]],["name/285",[168,48.743]],["parent/285",[196,2.691]],["name/286",[169,48.743]],["parent/286",[196,2.691]],["name/287",[170,43.635]],["parent/287",[196,2.691]],["name/288",[171,48.743]],["parent/288",[196,2.691]],["name/289",[172,48.743]],["parent/289",[196,2.691]],["name/290",[173,48.743]],["parent/290",[196,2.691]],["name/291",[174,48.743]],["parent/291",[196,2.691]],["name/292",[175,48.743]],["parent/292",[196,2.691]],["name/293",[176,48.743]],["parent/293",[196,2.691]],["name/294",[177,48.743]],["parent/294",[196,2.691]],["name/295",[178,46.737]],["parent/295",[196,2.691]],["name/296",[179,48.743]],["parent/296",[196,2.691]],["name/297",[180,48.743]],["parent/297",[196,2.691]],["name/298",[181,48.743]],["parent/298",[196,2.691]],["name/299",[105,46.737]],["parent/299",[196,2.691]],["name/300",[182,27.278]],["parent/300",[196,2.691]],["name/301",[199,28.375]],["parent/301",[]],["name/302",[66,34.607]],["parent/302",[199,2.663]],["name/303",[200,59.73]],["parent/303",[199,2.663]],["name/304",[201,59.73]],["parent/304",[199,2.663]],["name/305",[202,59.73]],["parent/305",[199,2.663]],["name/306",[158,48.743]],["parent/306",[199,2.663]],["name/307",[159,46.737]],["parent/307",[199,2.663]],["name/308",[160,42.384]],["parent/308",[199,2.663]],["name/309",[161,48.743]],["parent/309",[199,2.663]],["name/310",[162,46.737]],["parent/310",[199,2.663]],["name/311",[163,48.743]],["parent/311",[199,2.663]],["name/312",[38,39.361]],["parent/312",[199,2.663]],["name/313",[96,41.271]],["parent/313",[199,2.663]],["name/314",[106,45.066]],["parent/314",[199,2.663]],["name/315",[164,48.743]],["parent/315",[199,2.663]],["name/316",[165,46.737]],["parent/316",[199,2.663]],["name/317",[166,46.737]],["parent/317",[199,2.663]],["name/318",[167,48.743]],["parent/318",[199,2.663]],["name/319",[168,48.743]],["parent/319",[199,2.663]],["name/320",[169,48.743]],["parent/320",[199,2.663]],["name/321",[170,43.635]],["parent/321",[199,2.663]],["name/322",[171,48.743]],["parent/322",[199,2.663]],["name/323",[172,48.743]],["parent/323",[199,2.663]],["name/324",[173,48.743]],["parent/324",[199,2.663]],["name/325",[174,48.743]],["parent/325",[199,2.663]],["name/326",[175,48.743]],["parent/326",[199,2.663]],["name/327",[176,48.743]],["parent/327",[199,2.663]],["name/328",[177,48.743]],["parent/328",[199,2.663]],["name/329",[178,46.737]],["parent/329",[199,2.663]],["name/330",[179,48.743]],["parent/330",[199,2.663]],["name/331",[180,48.743]],["parent/331",[199,2.663]],["name/332",[181,48.743]],["parent/332",[199,2.663]],["name/333",[105,46.737]],["parent/333",[199,2.663]],["name/334",[182,27.278]],["parent/334",[199,2.663]],["name/335",[203,54.621]],["parent/335",[]],["name/336",[42,37.043]],["parent/336",[203,5.127]],["name/337",[204,43.635]],["parent/337",[]],["name/338",[159,46.737]],["parent/338",[204,4.096]],["name/339",[160,42.384]],["parent/339",[204,4.096]],["name/340",[162,46.737]],["parent/340",[204,4.096]],["name/341",[96,41.271]],["parent/341",[204,4.096]],["name/342",[165,46.737]],["parent/342",[204,4.096]],["name/343",[166,46.737]],["parent/343",[204,4.096]],["name/344",[80,38.527]],["parent/344",[]],["name/345",[66,34.607]],["parent/345",[80,3.616]],["name/346",[106,45.066]],["parent/346",[80,3.616]],["name/347",[3,54.621]],["parent/347",[80,3.616]],["name/348",[178,46.737]],["parent/348",[80,3.616]],["name/349",[205,59.73]],["parent/349",[80,3.616]],["name/350",[206,59.73]],["parent/350",[80,3.616]],["name/351",[207,27.541]],["parent/351",[]],["name/352",[66,34.607]],["parent/352",[207,2.585]],["name/353",[208,59.73]],["parent/353",[207,2.585]],["name/354",[107,54.621]],["parent/354",[207,2.585]],["name/355",[112,34.607]],["parent/355",[207,2.585]],["name/356",[76,27.021]],["parent/356",[207,2.585]],["name/357",[209,45.066]],["parent/357",[207,2.585]],["name/358",[85,41.271]],["parent/358",[207,2.585]],["name/359",[125,45.066]],["parent/359",[207,2.585]],["name/360",[124,48.743]],["parent/360",[207,2.585]],["name/361",[210,51.257]],["parent/361",[207,2.585]],["name/362",[160,42.384]],["parent/362",[207,2.585]],["name/363",[75,43.635]],["parent/363",[207,2.585]],["name/364",[63,45.066]],["parent/364",[207,2.585]],["name/365",[211,51.257]],["parent/365",[207,2.585]],["name/366",[194,46.737]],["parent/366",[207,2.585]],["name/367",[82,46.737]],["parent/367",[207,2.585]],["name/368",[212,51.257]],["parent/368",[207,2.585]],["name/369",[213,48.743]],["parent/369",[207,2.585]],["name/370",[214,51.257]],["parent/370",[207,2.585]],["name/371",[215,51.257]],["parent/371",[207,2.585]],["name/372",[216,51.257]],["parent/372",[207,2.585]],["name/373",[91,45.066]],["parent/373",[207,2.585]],["name/374",[98,41.271]],["parent/374",[207,2.585]],["name/375",[217,51.257]],["parent/375",[207,2.585]],["name/376",[218,51.257]],["parent/376",[207,2.585]],["name/377",[170,43.635]],["parent/377",[207,2.585]],["name/378",[219,51.257]],["parent/378",[207,2.585]],["name/379",[220,51.257]],["parent/379",[207,2.585]],["name/380",[221,51.257]],["parent/380",[207,2.585]],["name/381",[222,51.257]],["parent/381",[207,2.585]],["name/382",[223,51.257]],["parent/382",[207,2.585]],["name/383",[127,48.743]],["parent/383",[207,2.585]],["name/384",[128,48.743]],["parent/384",[207,2.585]],["name/385",[224,51.257]],["parent/385",[207,2.585]],["name/386",[225,51.257]],["parent/386",[207,2.585]],["name/387",[226,51.257]],["parent/387",[207,2.585]],["name/388",[227,46.737]],["parent/388",[]],["name/389",[76,27.021]],["parent/389",[227,4.387]],["name/390",[209,45.066]],["parent/390",[227,4.387]],["name/391",[85,41.271]],["parent/391",[227,4.387]],["name/392",[125,45.066]],["parent/392",[227,4.387]],["name/393",[228,28.089]],["parent/393",[]],["name/394",[66,34.607]],["parent/394",[228,2.637]],["name/395",[112,34.607]],["parent/395",[228,2.637]],["name/396",[76,27.021]],["parent/396",[228,2.637]],["name/397",[209,45.066]],["parent/397",[228,2.637]],["name/398",[85,41.271]],["parent/398",[228,2.637]],["name/399",[125,45.066]],["parent/399",[228,2.637]],["name/400",[124,48.743]],["parent/400",[228,2.637]],["name/401",[210,51.257]],["parent/401",[228,2.637]],["name/402",[160,42.384]],["parent/402",[228,2.637]],["name/403",[75,43.635]],["parent/403",[228,2.637]],["name/404",[63,45.066]],["parent/404",[228,2.637]],["name/405",[211,51.257]],["parent/405",[228,2.637]],["name/406",[194,46.737]],["parent/406",[228,2.637]],["name/407",[82,46.737]],["parent/407",[228,2.637]],["name/408",[212,51.257]],["parent/408",[228,2.637]],["name/409",[213,48.743]],["parent/409",[228,2.637]],["name/410",[214,51.257]],["parent/410",[228,2.637]],["name/411",[215,51.257]],["parent/411",[228,2.637]],["name/412",[216,51.257]],["parent/412",[228,2.637]],["name/413",[91,45.066]],["parent/413",[228,2.637]],["name/414",[98,41.271]],["parent/414",[228,2.637]],["name/415",[217,51.257]],["parent/415",[228,2.637]],["name/416",[218,51.257]],["parent/416",[228,2.637]],["name/417",[170,43.635]],["parent/417",[228,2.637]],["name/418",[219,51.257]],["parent/418",[228,2.637]],["name/419",[220,51.257]],["parent/419",[228,2.637]],["name/420",[221,51.257]],["parent/420",[228,2.637]],["name/421",[222,51.257]],["parent/421",[228,2.637]],["name/422",[223,51.257]],["parent/422",[228,2.637]],["name/423",[127,48.743]],["parent/423",[228,2.637]],["name/424",[128,48.743]],["parent/424",[228,2.637]],["name/425",[224,51.257]],["parent/425",[228,2.637]],["name/426",[225,51.257]],["parent/426",[228,2.637]],["name/427",[226,51.257]],["parent/427",[228,2.637]],["name/428",[229,45.066]],["parent/428",[]],["name/429",[66,34.607]],["parent/429",[229,4.23]],["name/430",[80,38.527]],["parent/430",[229,4.23]],["name/431",[209,45.066]],["parent/431",[229,4.23]],["name/432",[63,45.066]],["parent/432",[229,4.23]],["name/433",[230,59.73]],["parent/433",[229,4.23]],["name/434",[231,45.066]],["parent/434",[]],["name/435",[182,27.278]],["parent/435",[231,4.23]],["name/436",[76,27.021]],["parent/436",[231,4.23]],["name/437",[209,45.066]],["parent/437",[231,4.23]],["name/438",[85,41.271]],["parent/438",[231,4.23]],["name/439",[125,45.066]],["parent/439",[231,4.23]],["name/440",[232,27.541]],["parent/440",[]],["name/441",[66,34.607]],["parent/441",[232,2.585]],["name/442",[182,27.278]],["parent/442",[232,2.585]],["name/443",[160,42.384]],["parent/443",[232,2.585]],["name/444",[128,48.743]],["parent/444",[232,2.585]],["name/445",[233,59.73]],["parent/445",[232,2.585]],["name/446",[112,34.607]],["parent/446",[232,2.585]],["name/447",[76,27.021]],["parent/447",[232,2.585]],["name/448",[209,45.066]],["parent/448",[232,2.585]],["name/449",[85,41.271]],["parent/449",[232,2.585]],["name/450",[125,45.066]],["parent/450",[232,2.585]],["name/451",[124,48.743]],["parent/451",[232,2.585]],["name/452",[210,51.257]],["parent/452",[232,2.585]],["name/453",[75,43.635]],["parent/453",[232,2.585]],["name/454",[63,45.066]],["parent/454",[232,2.585]],["name/455",[211,51.257]],["parent/455",[232,2.585]],["name/456",[194,46.737]],["parent/456",[232,2.585]],["name/457",[82,46.737]],["parent/457",[232,2.585]],["name/458",[212,51.257]],["parent/458",[232,2.585]],["name/459",[213,48.743]],["parent/459",[232,2.585]],["name/460",[214,51.257]],["parent/460",[232,2.585]],["name/461",[215,51.257]],["parent/461",[232,2.585]],["name/462",[216,51.257]],["parent/462",[232,2.585]],["name/463",[91,45.066]],["parent/463",[232,2.585]],["name/464",[98,41.271]],["parent/464",[232,2.585]],["name/465",[217,51.257]],["parent/465",[232,2.585]],["name/466",[218,51.257]],["parent/466",[232,2.585]],["name/467",[170,43.635]],["parent/467",[232,2.585]],["name/468",[219,51.257]],["parent/468",[232,2.585]],["name/469",[220,51.257]],["parent/469",[232,2.585]],["name/470",[221,51.257]],["parent/470",[232,2.585]],["name/471",[222,51.257]],["parent/471",[232,2.585]],["name/472",[223,51.257]],["parent/472",[232,2.585]],["name/473",[127,48.743]],["parent/473",[232,2.585]],["name/474",[224,51.257]],["parent/474",[232,2.585]],["name/475",[225,51.257]],["parent/475",[232,2.585]],["name/476",[226,51.257]],["parent/476",[232,2.585]],["name/477",[234,41.271]],["parent/477",[]],["name/478",[235,59.73]],["parent/478",[234,3.874]],["name/479",[236,59.73]],["parent/479",[234,3.874]],["name/480",[38,39.361]],["parent/480",[234,3.874]],["name/481",[56,46.737]],["parent/481",[234,3.874]],["name/482",[237,59.73]],["parent/482",[234,3.874]],["name/483",[238,59.73]],["parent/483",[234,3.874]],["name/484",[239,59.73]],["parent/484",[234,3.874]],["name/485",[240,59.73]],["parent/485",[234,3.874]],["name/486",[241,48.743]],["parent/486",[]],["name/487",[242,54.621]],["parent/487",[241,4.575]],["name/488",[85,41.271]],["parent/488",[241,4.575]],["name/489",[99,48.743]],["parent/489",[241,4.575]],["name/490",[243,43.635]],["parent/490",[]],["name/491",[42,37.043]],["parent/491",[243,4.096]],["name/492",[66,34.607]],["parent/492",[243,4.096]],["name/493",[242,54.621]],["parent/493",[243,4.096]],["name/494",[99,48.743]],["parent/494",[243,4.096]],["name/495",[244,54.621]],["parent/495",[243,4.096]],["name/496",[245,54.621]],["parent/496",[243,4.096]],["name/497",[246,46.737]],["parent/497",[]],["name/498",[42,37.043]],["parent/498",[246,4.387]],["name/499",[66,34.607]],["parent/499",[246,4.387]],["name/500",[244,54.621]],["parent/500",[246,4.387]],["name/501",[245,54.621]],["parent/501",[246,4.387]],["name/502",[66,34.607]],["parent/502",[]],["name/503",[42,37.043]],["parent/503",[66,3.248]],["name/504",[247,59.73]],["parent/504",[]],["name/505",[248,59.73]],["parent/505",[]],["name/506",[249,59.73]],["parent/506",[]],["name/507",[250,59.73]],["parent/507",[]],["name/508",[251,59.73]],["parent/508",[]],["name/509",[252,59.73]],["parent/509",[]],["name/510",[253,59.73]],["parent/510",[]],["name/511",[254,40.271]],["parent/511",[]],["name/512",[75,43.635]],["parent/512",[254,3.78]],["name/513",[76,27.021]],["parent/513",[254,3.78]],["name/514",[255,59.73]],["parent/514",[254,3.78]],["name/515",[82,46.737]],["parent/515",[254,3.78]],["name/516",[213,48.743]],["parent/516",[254,3.78]],["name/517",[85,41.271]],["parent/517",[254,3.78]],["name/518",[87,54.621]],["parent/518",[254,3.78]],["name/519",[90,54.621]],["parent/519",[254,3.78]],["name/520",[91,45.066]],["parent/520",[254,3.78]],["name/521",[256,59.73]],["parent/521",[]],["name/522",[257,59.73]],["parent/522",[]],["name/523",[258,59.73]],["parent/523",[]],["name/524",[259,40.271]],["parent/524",[]],["name/525",[260,59.73]],["parent/525",[259,3.78]],["name/526",[56,46.737]],["parent/526",[259,3.78]],["name/527",[261,59.73]],["parent/527",[259,3.78]],["name/528",[262,51.257]],["parent/528",[259,3.78]],["name/529",[80,38.527]],["parent/529",[259,3.78]],["name/530",[263,51.257]],["parent/530",[259,3.78]],["name/531",[264,51.257]],["parent/531",[259,3.78]],["name/532",[265,51.257]],["parent/532",[259,3.78]],["name/533",[266,59.73]],["parent/533",[259,3.78]],["name/534",[267,54.621]],["parent/534",[]],["name/535",[42,37.043]],["parent/535",[267,5.127]],["name/536",[56,46.737]],["parent/536",[268,4.096]],["name/537",[269,54.621]],["parent/537",[268,4.096]],["name/538",[262,51.257]],["parent/538",[268,4.096]],["name/539",[80,38.527]],["parent/539",[268,4.096]],["name/540",[263,51.257]],["parent/540",[268,4.096]],["name/541",[264,51.257]],["parent/541",[268,4.096]],["name/542",[265,51.257]],["parent/542",[268,4.096]],["name/543",[270,54.621]],["parent/543",[]],["name/544",[42,37.043]],["parent/544",[270,5.127]],["name/545",[271,59.73]],["parent/545",[272,3.356]],["name/546",[273,59.73]],["parent/546",[272,3.356]],["name/547",[274,59.73]],["parent/547",[272,3.356]],["name/548",[275,59.73]],["parent/548",[272,3.356]],["name/549",[276,59.73]],["parent/549",[272,3.356]],["name/550",[277,59.73]],["parent/550",[272,3.356]],["name/551",[278,59.73]],["parent/551",[272,3.356]],["name/552",[279,59.73]],["parent/552",[272,3.356]],["name/553",[280,59.73]],["parent/553",[272,3.356]],["name/554",[281,59.73]],["parent/554",[272,3.356]],["name/555",[282,59.73]],["parent/555",[272,3.356]],["name/556",[283,59.73]],["parent/556",[272,3.356]],["name/557",[284,59.73]],["parent/557",[272,3.356]],["name/558",[285,59.73]],["parent/558",[272,3.356]],["name/559",[286,59.73]],["parent/559",[272,3.356]],["name/560",[287,59.73]],["parent/560",[272,3.356]],["name/561",[288,59.73]],["parent/561",[]],["name/562",[289,59.73]],["parent/562",[]],["name/563",[290,35.162]],["parent/563",[]],["name/564",[291,59.73]],["parent/564",[290,3.301]],["name/565",[292,59.73]],["parent/565",[290,3.301]],["name/566",[293,59.73]],["parent/566",[290,3.301]],["name/567",[294,59.73]],["parent/567",[290,3.301]],["name/568",[265,51.257]],["parent/568",[290,3.301]],["name/569",[56,46.737]],["parent/569",[290,3.301]],["name/570",[80,38.527]],["parent/570",[290,3.301]],["name/571",[262,51.257]],["parent/571",[290,3.301]],["name/572",[263,51.257]],["parent/572",[290,3.301]],["name/573",[295,59.73]],["parent/573",[290,3.301]],["name/574",[264,51.257]],["parent/574",[290,3.301]],["name/575",[269,54.621]],["parent/575",[290,3.301]],["name/576",[296,59.73]],["parent/576",[290,3.301]],["name/577",[297,59.73]],["parent/577",[290,3.301]],["name/578",[298,59.73]],["parent/578",[290,3.301]],["name/579",[66,34.607]],["parent/579",[290,3.301]],["name/580",[299,59.73]],["parent/580",[]],["name/581",[300,59.73]],["parent/581",[]],["name/582",[301,59.73]],["parent/582",[]],["name/583",[302,59.73]],["parent/583",[]],["name/584",[303,59.73]],["parent/584",[]],["name/585",[304,59.73]],["parent/585",[]],["name/586",[305,59.73]],["parent/586",[]],["name/587",[306,59.73]],["parent/587",[]]],"invertedIndex":[["__type",{"_index":42,"name":{"38":{},"48":{},"74":{},"123":{},"125":{},"127":{},"129":{},"131":{},"336":{},"491":{},"498":{},"503":{},"535":{},"544":{}},"parent":{}}],["addbotandteamownerstoowners",{"_index":45,"name":{"40":{}},"parent":{}}],["advancedclient",{"_index":65,"name":{"66":{}},"parent":{"67":{},"68":{},"69":{},"70":{},"71":{},"72":{}}}],["aliases",{"_index":159,"name":{"185":{},"222":{},"273":{},"307":{},"338":{}},"parent":{}}],["all",{"_index":266,"name":{"533":{}},"parent":{}}],["argerror",{"_index":251,"name":{"508":{}},"parent":{}}],["args",{"_index":124,"name":{"139":{},"360":{},"400":{},"451":{}},"parent":{}}],["argsstring",{"_index":210,"name":{"361":{},"401":{},"452":{}},"parent":{}}],["argument",{"_index":98,"name":{"100":{},"374":{},"414":{},"464":{}},"parent":{"101":{},"102":{},"103":{},"104":{},"105":{}}}],["argument_not_found",{"_index":235,"name":{"478":{}},"parent":{}}],["argumentbuilder",{"_index":92,"name":{"94":{}},"parent":{}}],["argumentcontext",{"_index":207,"name":{"351":{}},"parent":{"352":{},"353":{},"354":{},"355":{},"356":{},"357":{},"358":{},"359":{},"360":{},"361":{},"362":{},"363":{},"364":{},"365":{},"366":{},"367":{},"368":{},"369":{},"370":{},"371":{},"372":{},"373":{},"374":{},"375":{},"376":{},"377":{},"378":{},"379":{},"380":{},"381":{},"382":{},"383":{},"384":{},"385":{},"386":{},"387":{}}}],["argumentfunction",{"_index":72,"name":{"73":{}},"parent":{"74":{}}}],["argumentnotfound",{"_index":116,"name":{"126":{}},"parent":{}}],["argumentnotfounderror",{"_index":120,"name":{"133":{}},"parent":{}}],["argumentoptions",{"_index":93,"name":{"95":{}},"parent":{"96":{},"97":{},"98":{},"99":{}}}],["argumentparser",{"_index":112,"name":{"121":{},"355":{},"395":{},"446":{}},"parent":{"122":{},"123":{},"132":{},"133":{},"134":{},"135":{},"136":{},"137":{},"138":{},"139":{},"140":{},"141":{},"142":{},"143":{}}}],["argumentparser.__type",{"_index":115,"name":{},"parent":{"124":{},"125":{},"126":{},"127":{},"128":{},"129":{},"130":{},"131":{}}}],["argumentrequiresonevalue",{"_index":117,"name":{"128":{}},"parent":{}}],["argumentrequiresonevalueerror",{"_index":121,"name":{"134":{}},"parent":{}}],["argumentresolved",{"_index":111,"name":{"120":{}},"parent":{}}],["arguments",{"_index":160,"name":{"186":{},"223":{},"274":{},"308":{},"339":{},"362":{},"402":{},"443":{}},"parent":{}}],["argumenttype",{"_index":73,"name":{"75":{}},"parent":{"76":{},"77":{},"78":{},"79":{},"80":{},"81":{},"82":{},"83":{},"84":{},"85":{},"86":{},"87":{},"88":{},"89":{},"90":{},"91":{},"92":{},"93":{}}}],["bind",{"_index":205,"name":{"349":{}},"parent":{}}],["black",{"_index":284,"name":{"557":{}},"parent":{}}],["blue",{"_index":278,"name":{"551":{}},"parent":{}}],["boolean",{"_index":74,"name":{"76":{}},"parent":{}}],["booleanargument",{"_index":129,"name":{"144":{}},"parent":{}}],["brown",{"_index":283,"name":{"556":{}},"parent":{}}],["bulkdeleteinchannel",{"_index":217,"name":{"375":{},"415":{},"465":{}},"parent":{}}],["category",{"_index":161,"name":{"187":{},"224":{},"275":{},"309":{}},"parent":{}}],["channel",{"_index":75,"name":{"77":{},"249":{},"261":{},"363":{},"403":{},"453":{},"512":{}},"parent":{}}],["channelargument",{"_index":130,"name":{"145":{}},"parent":{}}],["channelonly",{"_index":145,"name":{"162":{}},"parent":{}}],["channels",{"_index":162,"name":{"188":{},"225":{},"276":{},"310":{},"340":{}},"parent":{}}],["check",{"_index":152,"name":{"170":{}},"parent":{}}],["choice",{"_index":77,"name":{"79":{}},"parent":{}}],["choiceargument",{"_index":131,"name":{"146":{}},"parent":{}}],["client",{"_index":63,"name":{"64":{},"179":{},"364":{},"404":{},"432":{},"454":{}},"parent":{}}],["client_missing_permissions",{"_index":236,"name":{"479":{}},"parent":{}}],["clientoptions",{"_index":47,"name":{"41":{}},"parent":{}}],["clientpermissions",{"_index":163,"name":{"189":{},"226":{},"277":{},"311":{}},"parent":{}}],["coalescing",{"_index":94,"name":{"96":{},"108":{}},"parent":{}}],["codeerror",{"_index":252,"name":{"509":{}},"parent":{}}],["colorresolvable",{"_index":288,"name":{"561":{}},"parent":{}}],["colors",{"_index":270,"name":{"543":{}},"parent":{"544":{}}}],["colors.__type",{"_index":272,"name":{},"parent":{"545":{},"546":{},"547":{},"548":{},"549":{},"550":{},"551":{},"552":{},"553":{},"554":{},"555":{},"556":{},"557":{},"558":{},"559":{},"560":{}}}],["command",{"_index":76,"name":{"78":{},"181":{},"356":{},"389":{},"396":{},"436":{},"447":{},"513":{}},"parent":{"182":{},"183":{},"184":{},"185":{},"186":{},"187":{},"188":{},"189":{},"190":{},"191":{},"192":{},"193":{},"194":{},"195":{},"196":{},"197":{},"198":{},"199":{},"200":{},"201":{},"202":{},"203":{},"204":{},"205":{},"206":{},"207":{},"208":{},"209":{},"210":{},"211":{},"212":{}}}],["commandargument",{"_index":103,"name":{"106":{},"147":{}},"parent":{"107":{},"108":{},"109":{},"110":{},"111":{},"112":{},"113":{},"114":{},"115":{},"116":{},"117":{},"118":{}}}],["commandcontext",{"_index":228,"name":{"393":{}},"parent":{"394":{},"395":{},"396":{},"397":{},"398":{},"399":{},"400":{},"401":{},"402":{},"403":{},"404":{},"405":{},"406":{},"407":{},"408":{},"409":{},"410":{},"411":{},"412":{},"413":{},"414":{},"415":{},"416":{},"417":{},"418":{},"419":{},"420":{},"421":{},"422":{},"423":{},"424":{},"425":{},"426":{},"427":{}}}],["commandcontextbuilder",{"_index":227,"name":{"388":{}},"parent":{"389":{},"390":{},"391":{},"392":{}}}],["commandcooldown",{"_index":37,"name":{"34":{}},"parent":{}}],["commanderror",{"_index":243,"name":{"490":{}},"parent":{"491":{},"492":{},"493":{},"494":{},"495":{},"496":{}}}],["commanderrorbuilder",{"_index":241,"name":{"486":{}},"parent":{"487":{},"488":{},"489":{}}}],["commanderrortype",{"_index":234,"name":{"477":{}},"parent":{"478":{},"479":{},"480":{},"481":{},"482":{},"483":{},"484":{},"485":{}}}],["commandhandler",{"_index":0,"name":{"0":{}},"parent":{"1":{},"2":{},"3":{},"4":{},"5":{},"6":{},"7":{},"8":{},"9":{},"10":{},"11":{},"12":{},"13":{},"14":{},"15":{},"16":{},"17":{},"21":{},"27":{},"34":{},"37":{},"39":{},"47":{},"55":{},"56":{},"57":{},"58":{},"59":{},"60":{},"61":{},"62":{},"63":{},"64":{},"65":{}}}],["commandhandler.commandcooldown",{"_index":39,"name":{},"parent":{"35":{},"36":{}}}],["commandhandler.commandhandlerevents",{"_index":54,"name":{},"parent":{"48":{}}}],["commandhandler.commandhandlerevents.__type",{"_index":55,"name":{},"parent":{"49":{},"50":{},"51":{},"52":{},"53":{},"54":{}}}],["commandhandler.cooldownuser",{"_index":43,"name":{},"parent":{"38":{}}}],["commandhandler.createcommandhandleroptions",{"_index":31,"name":{},"parent":{"28":{},"29":{},"30":{},"31":{},"32":{},"33":{}}}],["commandhandler.helpoptions",{"_index":19,"name":{},"parent":{"18":{},"19":{},"20":{}}}],["commandhandler.launchcommandhandleroptions",{"_index":46,"name":{},"parent":{"40":{},"41":{},"42":{},"43":{},"44":{},"45":{},"46":{}}}],["commandhandler.messagecreateoptions",{"_index":24,"name":{},"parent":{"22":{},"23":{},"24":{},"25":{},"26":{}}}],["commandhandlererror",{"_index":246,"name":{"497":{}},"parent":{"498":{},"499":{},"500":{},"501":{}}}],["commandhandlerevents",{"_index":53,"name":{"47":{}},"parent":{}}],["commandname",{"_index":211,"name":{"365":{},"405":{},"455":{}},"parent":{}}],["commands",{"_index":60,"name":{"57":{}},"parent":{}}],["commandsdir",{"_index":30,"name":{"28":{},"60":{}},"parent":{}}],["commandsignatureoptions",{"_index":183,"name":{"213":{}},"parent":{"214":{},"215":{}}}],["comment",{"_index":265,"name":{"532":{},"542":{},"568":{}},"parent":{}}],["constructor",{"_index":66,"name":{"67":{},"101":{},"107":{},"136":{},"183":{},"217":{},"269":{},"302":{},"345":{},"352":{},"394":{},"429":{},"441":{},"492":{},"499":{},"502":{},"579":{}},"parent":{"503":{}}}],["content",{"_index":194,"name":{"262":{},"267":{},"366":{},"406":{},"456":{}},"parent":{}}],["cooldown",{"_index":38,"name":{"35":{},"171":{},"173":{},"190":{},"227":{},"278":{},"312":{},"480":{}},"parent":{"172":{},"173":{},"174":{}}}],["cooldowns",{"_index":61,"name":{"58":{}},"parent":{}}],["cooldownuser",{"_index":41,"name":{"37":{}},"parent":{}}],["create",{"_index":8,"name":{"8":{},"49":{}},"parent":{}}],["createcommandhandleroptions",{"_index":29,"name":{"27":{}},"parent":{}}],["createthread",{"_index":218,"name":{"376":{},"416":{},"466":{}},"parent":{}}],["ctx",{"_index":192,"name":{"255":{},"265":{}},"parent":{}}],["currentargument",{"_index":208,"name":{"353":{}},"parent":{}}],["cutiftoolong",{"_index":301,"name":{"582":{}},"parent":{}}],["cyclebetweenpresences",{"_index":48,"name":{"42":{}},"parent":{}}],["cycleduration",{"_index":49,"name":{"43":{}},"parent":{}}],["data",{"_index":242,"name":{"487":{},"493":{}},"parent":{}}],["datatype",{"_index":254,"name":{"511":{}},"parent":{"512":{},"513":{},"514":{},"515":{},"516":{},"517":{},"518":{},"519":{},"520":{}}}],["date",{"_index":244,"name":{"495":{},"500":{}},"parent":{}}],["debug",{"_index":264,"name":{"531":{},"541":{},"574":{}},"parent":{}}],["default",{"_index":287,"name":{"560":{}},"parent":{}}],["defaultvalue",{"_index":95,"name":{"97":{},"109":{}},"parent":{}}],["deletemessage",{"_index":170,"name":{"199":{},"235":{},"287":{},"321":{},"377":{},"417":{},"467":{}},"parent":{}}],["deletemessageafterdelay",{"_index":18,"name":{"18":{}},"parent":{}}],["deletemessageoptions",{"_index":154,"name":{"175":{}},"parent":{"176":{},"177":{}}}],["description",{"_index":96,"name":{"98":{},"110":{},"191":{},"228":{},"250":{},"257":{},"279":{},"313":{},"341":{}},"parent":{}}],["dmonly",{"_index":146,"name":{"163":{}},"parent":{}}],["emit",{"_index":1,"name":{"1":{}},"parent":{}}],["emitter",{"_index":59,"name":{"56":{}},"parent":{}}],["emoji",{"_index":78,"name":{"80":{}},"parent":{}}],["emojiargument",{"_index":132,"name":{"148":{}},"parent":{}}],["emote",{"_index":255,"name":{"514":{}},"parent":{}}],["enum",{"_index":79,"name":{"81":{}},"parent":{}}],["enumargument",{"_index":133,"name":{"149":{}},"parent":{}}],["error",{"_index":56,"name":{"50":{},"481":{},"526":{},"536":{},"569":{}},"parent":{}}],["errorinargument",{"_index":118,"name":{"130":{}},"parent":{}}],["errorinargumenterror",{"_index":122,"name":{"135":{}},"parent":{}}],["errors",{"_index":113,"name":{"122":{}},"parent":{}}],["event",{"_index":80,"name":{"82":{},"344":{},"430":{},"529":{},"539":{},"570":{}},"parent":{"345":{},"346":{},"347":{},"348":{},"349":{},"350":{}}}],["eventargument",{"_index":134,"name":{"150":{}},"parent":{}}],["eventcontext",{"_index":229,"name":{"428":{}},"parent":{"429":{},"430":{},"431":{},"432":{},"433":{}}}],["eventname",{"_index":230,"name":{"433":{}},"parent":{}}],["events",{"_index":62,"name":{"59":{}},"parent":{}}],["eventsdir",{"_index":32,"name":{"29":{},"61":{}},"parent":{}}],["excludebots",{"_index":23,"name":{"22":{}},"parent":{}}],["execute",{"_index":171,"name":{"200":{},"236":{},"288":{},"322":{}},"parent":{}}],["executedat",{"_index":40,"name":{"36":{},"174":{}},"parent":{}}],["findcommand",{"_index":5,"name":{"5":{}},"parent":{}}],["float",{"_index":81,"name":{"83":{}},"parent":{}}],["floatargument",{"_index":135,"name":{"151":{}},"parent":{}}],["getcolorfromcolorresolvable",{"_index":298,"name":{"578":{}},"parent":{}}],["getcommandaliasesandnames",{"_index":4,"name":{"4":{}},"parent":{}}],["getcooldown",{"_index":172,"name":{"201":{},"237":{},"289":{},"323":{}},"parent":{}}],["getinvalidpermissions",{"_index":173,"name":{"202":{},"238":{},"290":{},"324":{}},"parent":{}}],["getkeybyvalue",{"_index":302,"name":{"583":{}},"parent":{}}],["getmissingpermissions",{"_index":174,"name":{"203":{},"239":{},"291":{},"325":{}},"parent":{}}],["getmissingtags",{"_index":175,"name":{"204":{},"240":{},"292":{},"326":{}},"parent":{}}],["getprefixfrommessage",{"_index":10,"name":{"10":{}},"parent":{}}],["getsnowflake",{"_index":157,"name":{"182":{}},"parent":{}}],["getthing",{"_index":253,"name":{"510":{}},"parent":{}}],["globalmenuexcludecommands",{"_index":20,"name":{"19":{}},"parent":{}}],["globalmenuuselist",{"_index":21,"name":{"20":{}},"parent":{}}],["globaltags",{"_index":25,"name":{"23":{}},"parent":{}}],["gold",{"_index":274,"name":{"547":{}},"parent":{}}],["green",{"_index":276,"name":{"549":{}},"parent":{}}],["grey",{"_index":285,"name":{"558":{}},"parent":{}}],["guild",{"_index":82,"name":{"84":{},"367":{},"407":{},"457":{},"515":{}},"parent":{}}],["guild_member",{"_index":83,"name":{"85":{}},"parent":{}}],["guildargument",{"_index":136,"name":{"152":{}},"parent":{}}],["guildmemberargument",{"_index":137,"name":{"153":{}},"parent":{}}],["guildonly",{"_index":147,"name":{"164":{}},"parent":{}}],["guildowneronly",{"_index":148,"name":{"165":{}},"parent":{}}],["handler",{"_index":209,"name":{"357":{},"390":{},"397":{},"431":{},"437":{},"448":{}},"parent":{}}],["helpoptions",{"_index":17,"name":{"17":{}},"parent":{}}],["id",{"_index":67,"name":{"68":{}},"parent":{}}],["ignores",{"_index":292,"name":{"565":{}},"parent":{}}],["imagecommand",{"_index":196,"name":{"268":{}},"parent":{"269":{},"270":{},"271":{},"272":{},"273":{},"274":{},"275":{},"276":{},"277":{},"278":{},"279":{},"280":{},"281":{},"282":{},"283":{},"284":{},"285":{},"286":{},"287":{},"288":{},"289":{},"290":{},"291":{},"292":{},"293":{},"294":{},"295":{},"296":{},"297":{},"298":{},"299":{},"300":{}}}],["imageembedcontextoptions",{"_index":191,"name":{"254":{}},"parent":{"255":{},"256":{},"257":{},"258":{},"259":{}}}],["imageembedoptions",{"_index":187,"name":{"248":{}},"parent":{"249":{},"250":{},"251":{},"252":{},"253":{}}}],["imagelocalcontextoptions",{"_index":195,"name":{"264":{}},"parent":{"265":{},"266":{},"267":{}}}],["imagelocaloptions",{"_index":193,"name":{"260":{}},"parent":{"261":{},"262":{},"263":{}}}],["index",{"_index":107,"name":{"116":{},"354":{}},"parent":{}}],["indigo",{"_index":279,"name":{"552":{}},"parent":{}}],["info",{"_index":262,"name":{"528":{},"538":{},"571":{}},"parent":{}}],["intargument",{"_index":138,"name":{"154":{}},"parent":{}}],["integer",{"_index":84,"name":{"86":{}},"parent":{}}],["invalid_argument",{"_index":237,"name":{"482":{}},"parent":{}}],["invalidargument",{"_index":114,"name":{"124":{}},"parent":{}}],["invalidargumenterror",{"_index":119,"name":{"132":{}},"parent":{}}],["iscallingasubcommand",{"_index":212,"name":{"368":{},"408":{},"458":{}},"parent":{}}],["isignored",{"_index":296,"name":{"576":{}},"parent":{}}],["isincooldown",{"_index":176,"name":{"205":{},"241":{},"293":{},"327":{}},"parent":{}}],["isinrightchannel",{"_index":177,"name":{"206":{},"242":{},"294":{},"328":{}},"parent":{}}],["isowner",{"_index":303,"name":{"584":{}},"parent":{}}],["ispermission",{"_index":300,"name":{"581":{}},"parent":{}}],["issimple",{"_index":108,"name":{"117":{}},"parent":{}}],["isskipable",{"_index":109,"name":{"118":{}},"parent":{}}],["issnowflake",{"_index":304,"name":{"585":{}},"parent":{}}],["istextchannellike",{"_index":305,"name":{"586":{}},"parent":{}}],["jsonlike",{"_index":258,"name":{"523":{}},"parent":{}}],["launch",{"_index":9,"name":{"9":{},"51":{}},"parent":{}}],["launchcommandhandleroptions",{"_index":44,"name":{"39":{}},"parent":{}}],["launched",{"_index":57,"name":{"54":{}},"parent":{}}],["level",{"_index":291,"name":{"564":{}},"parent":{}}],["link",{"_index":188,"name":{"251":{},"258":{}},"parent":{}}],["loadcommand",{"_index":11,"name":{"11":{},"52":{}},"parent":{}}],["loadcommands",{"_index":12,"name":{"12":{}},"parent":{}}],["loadevent",{"_index":13,"name":{"13":{},"53":{}},"parent":{}}],["loadevents",{"_index":14,"name":{"14":{}},"parent":{}}],["log",{"_index":263,"name":{"530":{},"540":{},"572":{}},"parent":{}}],["logger",{"_index":290,"name":{"563":{}},"parent":{"564":{},"565":{},"566":{},"567":{},"568":{},"569":{},"570":{},"571":{},"572":{},"573":{},"574":{},"575":{},"576":{},"577":{},"578":{},"579":{}}}],["loggerignore",{"_index":289,"name":{"562":{}},"parent":{}}],["loglevel",{"_index":259,"name":{"524":{}},"parent":{"525":{},"526":{},"527":{},"528":{},"529":{},"530":{},"531":{},"532":{},"533":{}}}],["logtype",{"_index":267,"name":{"534":{}},"parent":{"535":{}}}],["logtype.__type",{"_index":268,"name":{},"parent":{"536":{},"537":{},"538":{},"539":{},"540":{},"541":{},"542":{}}}],["magenta",{"_index":281,"name":{"554":{}},"parent":{}}],["maparguments",{"_index":110,"name":{"119":{}},"parent":{}}],["maybecommand",{"_index":247,"name":{"504":{}},"parent":{}}],["maybeevent",{"_index":248,"name":{"505":{}},"parent":{}}],["maybepromise",{"_index":250,"name":{"507":{}},"parent":{}}],["member",{"_index":213,"name":{"369":{},"409":{},"459":{},"516":{}},"parent":{}}],["mention",{"_index":68,"name":{"69":{}},"parent":{}}],["message",{"_index":85,"name":{"87":{},"176":{},"358":{},"391":{},"398":{},"438":{},"449":{},"488":{},"517":{}},"parent":{}}],["messageargument",{"_index":139,"name":{"155":{}},"parent":{}}],["messagecreateoptions",{"_index":22,"name":{"21":{}},"parent":{}}],["missing_tags",{"_index":238,"name":{"483":{}},"parent":{}}],["missingpermissions",{"_index":156,"name":{"178":{}},"parent":{"179":{},"180":{}}}],["name",{"_index":106,"name":{"115":{},"192":{},"218":{},"280":{},"314":{},"346":{}},"parent":{}}],["nameandaliases",{"_index":168,"name":{"197":{},"233":{},"285":{},"319":{}},"parent":{}}],["nsfw",{"_index":150,"name":{"167":{}},"parent":{}}],["off",{"_index":260,"name":{"525":{}},"parent":{}}],["on",{"_index":2,"name":{"2":{}},"parent":{}}],["once",{"_index":3,"name":{"3":{},"347":{}},"parent":{}}],["optional",{"_index":97,"name":{"99":{},"111":{}},"parent":{}}],["options",{"_index":100,"name":{"103":{}},"parent":{}}],["orange",{"_index":273,"name":{"546":{}},"parent":{}}],["owneronly",{"_index":149,"name":{"166":{}},"parent":{}}],["owners",{"_index":33,"name":{"30":{},"62":{}},"parent":{}}],["parse",{"_index":104,"name":{"112":{}},"parent":{}}],["parsearguments",{"_index":126,"name":{"141":{}},"parent":{}}],["parsed",{"_index":123,"name":{"137":{}},"parent":{}}],["parser",{"_index":102,"name":{"105":{},"138":{}},"parent":{}}],["path",{"_index":189,"name":{"252":{},"259":{},"263":{},"266":{}},"parent":{}}],["permissionserror",{"_index":299,"name":{"580":{}},"parent":{}}],["ping",{"_index":69,"name":{"70":{}},"parent":{}}],["pink",{"_index":282,"name":{"555":{}},"parent":{}}],["prefix",{"_index":214,"name":{"370":{},"410":{},"460":{}},"parent":{}}],["prefixes",{"_index":34,"name":{"31":{},"63":{}},"parent":{}}],["presence",{"_index":50,"name":{"44":{}},"parent":{}}],["presences",{"_index":51,"name":{"45":{}},"parent":{}}],["presencesinterval",{"_index":64,"name":{"65":{}},"parent":{}}],["process",{"_index":297,"name":{"577":{}},"parent":{}}],["random",{"_index":306,"name":{"587":{}},"parent":{}}],["rawargs",{"_index":125,"name":{"140":{},"359":{},"392":{},"399":{},"439":{},"450":{}},"parent":{}}],["react",{"_index":219,"name":{"378":{},"418":{},"468":{}},"parent":{}}],["readjson",{"_index":257,"name":{"522":{}},"parent":{}}],["red",{"_index":271,"name":{"545":{}},"parent":{}}],["regex",{"_index":86,"name":{"88":{}},"parent":{}}],["regexargument",{"_index":142,"name":{"158":{}},"parent":{}}],["registersubcommands",{"_index":158,"name":{"184":{},"221":{},"272":{},"306":{}},"parent":{}}],["removeallreactions",{"_index":220,"name":{"379":{},"419":{},"469":{}},"parent":{}}],["removereaction",{"_index":221,"name":{"380":{},"420":{},"470":{}},"parent":{}}],["removeselfreaction",{"_index":222,"name":{"381":{},"421":{},"471":{}},"parent":{}}],["reply",{"_index":223,"name":{"382":{},"422":{},"472":{}},"parent":{}}],["resolveargument",{"_index":127,"name":{"142":{},"383":{},"423":{},"473":{}},"parent":{}}],["resolvearguments",{"_index":128,"name":{"143":{},"384":{},"424":{},"444":{}},"parent":{}}],["role",{"_index":87,"name":{"89":{},"518":{}},"parent":{}}],["run",{"_index":178,"name":{"207":{},"219":{},"295":{},"329":{},"348":{}},"parent":{}}],["runfunction",{"_index":186,"name":{"220":{}},"parent":{}}],["runsubcommandfunction",{"_index":203,"name":{"335":{}},"parent":{"336":{}}}],["saveinfile",{"_index":294,"name":{"567":{}},"parent":{}}],["savejson",{"_index":256,"name":{"521":{}},"parent":{}}],["savelogsinfile",{"_index":35,"name":{"32":{}},"parent":{}}],["savingfiles",{"_index":293,"name":{"566":{}},"parent":{}}],["send",{"_index":224,"name":{"385":{},"425":{},"474":{}},"parent":{}}],["sendcodeerror",{"_index":26,"name":{"24":{}},"parent":{}}],["sendcodeerroronlytoowners",{"_index":27,"name":{"25":{}},"parent":{}}],["sendglobalhelpmessage",{"_index":225,"name":{"386":{},"426":{},"475":{}},"parent":{}}],["sendhelpmessage",{"_index":226,"name":{"387":{},"427":{},"476":{}},"parent":{}}],["sendimageembed",{"_index":197,"name":{"270":{}},"parent":{}}],["sendlocalimage",{"_index":198,"name":{"271":{}},"parent":{}}],["sendwhenerror",{"_index":28,"name":{"26":{}},"parent":{}}],["setcolor",{"_index":295,"name":{"573":{}},"parent":{}}],["setcooldown",{"_index":179,"name":{"208":{},"243":{},"296":{},"330":{}},"parent":{}}],["showdefaultvalues",{"_index":184,"name":{"214":{}},"parent":{}}],["showtypes",{"_index":185,"name":{"215":{}},"parent":{}}],["signature",{"_index":180,"name":{"209":{},"244":{},"297":{},"331":{}},"parent":{}}],["signatures",{"_index":181,"name":{"210":{},"245":{},"298":{},"332":{}},"parent":{}}],["slowcommand",{"_index":199,"name":{"301":{}},"parent":{"302":{},"303":{},"304":{},"305":{},"306":{},"307":{},"308":{},"309":{},"310":{},"311":{},"312":{},"313":{},"314":{},"315":{},"316":{},"317":{},"318":{},"319":{},"320":{},"321":{},"322":{},"323":{},"324":{},"325":{},"326":{},"327":{},"328":{},"329":{},"330":{},"331":{},"332":{},"333":{},"334":{}}}],["snowflake",{"_index":88,"name":{"90":{}},"parent":{}}],["snowflakeargument",{"_index":140,"name":{"156":{}},"parent":{}}],["startwait",{"_index":201,"name":{"304":{}},"parent":{}}],["stopwait",{"_index":202,"name":{"305":{}},"parent":{}}],["string",{"_index":89,"name":{"91":{}},"parent":{}}],["stringargument",{"_index":141,"name":{"157":{}},"parent":{}}],["subcommand",{"_index":182,"name":{"212":{},"216":{},"247":{},"300":{},"334":{},"435":{},"442":{}},"parent":{"217":{},"218":{},"219":{},"220":{},"221":{},"222":{},"223":{},"224":{},"225":{},"226":{},"227":{},"228":{},"229":{},"230":{},"231":{},"232":{},"233":{},"234":{},"235":{},"236":{},"237":{},"238":{},"239":{},"240":{},"241":{},"242":{},"243":{},"244":{},"245":{},"246":{},"247":{}}}],["subcommandcontext",{"_index":232,"name":{"440":{}},"parent":{"441":{},"442":{},"443":{},"444":{},"445":{},"446":{},"447":{},"448":{},"449":{},"450":{},"451":{},"452":{},"453":{},"454":{},"455":{},"456":{},"457":{},"458":{},"459":{},"460":{},"461":{},"462":{},"463":{},"464":{},"465":{},"466":{},"467":{},"468":{},"469":{},"470":{},"471":{},"472":{},"473":{},"474":{},"475":{},"476":{}}}],["subcommandcontextbuilder",{"_index":231,"name":{"434":{}},"parent":{"435":{},"436":{},"437":{},"438":{},"439":{}}}],["subcommandname",{"_index":233,"name":{"445":{}},"parent":{}}],["subcommandoptions",{"_index":204,"name":{"337":{}},"parent":{"338":{},"339":{},"340":{},"341":{},"342":{},"343":{}}}],["subcommands",{"_index":164,"name":{"193":{},"229":{},"281":{},"315":{}},"parent":{}}],["subcommandsnamesandaliases",{"_index":169,"name":{"198":{},"234":{},"286":{},"320":{}},"parent":{}}],["tag",{"_index":70,"name":{"71":{},"161":{},"169":{}},"parent":{"162":{},"163":{},"164":{},"165":{},"166":{},"167":{},"168":{},"170":{}}}],["tags",{"_index":165,"name":{"194":{},"230":{},"282":{},"316":{},"342":{}},"parent":{}}],["teal",{"_index":277,"name":{"550":{}},"parent":{}}],["text_channel",{"_index":90,"name":{"92":{},"519":{}},"parent":{}}],["textchannel",{"_index":215,"name":{"371":{},"411":{},"461":{}},"parent":{}}],["textchannelargument",{"_index":143,"name":{"159":{}},"parent":{}}],["textchannellike",{"_index":249,"name":{"506":{}},"parent":{}}],["thread",{"_index":216,"name":{"372":{},"412":{},"462":{}},"parent":{}}],["threadonly",{"_index":151,"name":{"168":{}},"parent":{}}],["timeout",{"_index":155,"name":{"177":{}},"parent":{}}],["title",{"_index":190,"name":{"253":{},"256":{}},"parent":{}}],["token",{"_index":52,"name":{"46":{}},"parent":{}}],["type",{"_index":99,"name":{"102":{},"113":{},"489":{},"494":{}},"parent":{}}],["unbind",{"_index":206,"name":{"350":{}},"parent":{}}],["unloadcommand",{"_index":16,"name":{"16":{}},"parent":{}}],["unloadevent",{"_index":15,"name":{"15":{}},"parent":{}}],["usage",{"_index":166,"name":{"195":{},"231":{},"283":{},"317":{},"343":{}},"parent":{}}],["usedefaultcommands",{"_index":7,"name":{"7":{}},"parent":{}}],["usedefaultevents",{"_index":6,"name":{"6":{}},"parent":{}}],["usementionasprefix",{"_index":36,"name":{"33":{}},"parent":{}}],["user",{"_index":91,"name":{"93":{},"180":{},"373":{},"413":{},"463":{},"520":{}},"parent":{}}],["user_missing_permissions",{"_index":239,"name":{"484":{}},"parent":{}}],["userargument",{"_index":144,"name":{"160":{}},"parent":{}}],["username",{"_index":71,"name":{"72":{}},"parent":{}}],["userpermissions",{"_index":167,"name":{"196":{},"232":{},"284":{},"318":{}},"parent":{}}],["validate",{"_index":105,"name":{"114":{},"211":{},"246":{},"299":{},"333":{}},"parent":{}}],["validator",{"_index":101,"name":{"104":{}},"parent":{}}],["version",{"_index":58,"name":{"55":{}},"parent":{}}],["violet",{"_index":280,"name":{"553":{}},"parent":{}}],["waitemoji",{"_index":200,"name":{"303":{}},"parent":{}}],["waitmore",{"_index":153,"name":{"172":{}},"parent":{}}],["warn",{"_index":269,"name":{"537":{},"575":{}},"parent":{}}],["warning",{"_index":261,"name":{"527":{}},"parent":{}}],["where",{"_index":245,"name":{"496":{},"501":{}},"parent":{}}],["white",{"_index":286,"name":{"559":{}},"parent":{}}],["wrong_channel",{"_index":240,"name":{"485":{}},"parent":{}}],["yellow",{"_index":275,"name":{"548":{}},"parent":{}}]],"pipeline":[]}} \ No newline at end of file diff --git a/docs-release/classes/AdvancedClient.html b/docs-release/classes/AdvancedClient.html new file mode 100644 index 0000000..fce6663 --- /dev/null +++ b/docs-release/classes/AdvancedClient.html @@ -0,0 +1,2429 @@ + + + + + + AdvancedClient + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class AdvancedClient

+
+
+
+
+
+
+
+

Hierarchy

+
    +
  • + Client +
      +
    • + AdvancedClient +
    • +
    +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Static Readonly captureRejectionSymbol

+
captureRejectionSymbol: typeof captureRejectionSymbol
+ +
+
+ +

Static captureRejections

+
captureRejections: boolean
+ +
+
+

Sets or gets the default captureRejection value for all emitters.

+
+
+
+
+ +

Static defaultMaxListeners

+
defaultMaxListeners: number
+ +
+
+ +

Static Readonly errorMonitor

+
errorMonitor: typeof errorMonitor
+ +
+
+

This symbol shall be used to install a listener for only monitoring 'error' + events. Listeners installed using this symbol are called before the regular + 'error' listeners are called.

+
+

Installing a listener using this symbol does not change the behavior once an + 'error' event is emitted, therefore the process will still crash if no + regular 'error' listener is installed.

+
+
+
+ +

application

+
application: null | ClientApplication
+ +
+
+ +

channels

+
channels: ChannelManager
+ +
+
+ +

Readonly emojis

+
emojis: BaseGuildEmojiManager
+ +
+
+ +

guilds

+
guilds: GuildManager
+ +
+
+ +

options

+
options: ClientOptions
+ +
+
+ +

readyAt

+
readyAt: null | Date
+ +
+
+ +

Readonly readyTimestamp

+
readyTimestamp: null | number
+ +
+
+ +

shard

+
shard: null | ShardClientUtil
+ +
+
+ +

token

+
token: null | string
+ +
+
+ +

uptime

+
uptime: null | number
+ +
+
+ +

user

+
user: null | ClientUser
+ +
+
+ +

users

+
users: UserManager
+ +
+
+ +

voice

+
voice: ClientVoiceManager
+ +
+
+ +

ws

+
ws: WebSocketManager
+ +
+
+
+

Methods

+
+ +

Static getEventListeners

+
    +
  • getEventListeners(emitter: EventEmitter | DOMEventTarget, name: string | symbol): Function[]
  • +
+
    +
  • + +
    +
    +

    Returns a copy of the array of listeners for the event named eventName.

    +
    +

    For EventEmitters this behaves exactly the same as calling .listeners on + the emitter.

    +

    For EventTargets this is the only way to get the event listeners for the + event target. This is useful for debugging and diagnostic purposes.

    +
    const { getEventListeners, EventEmitter } = require('events');
    +
    +{
    +  const ee = new EventEmitter();
    +  const listener = () => console.log('Events are fun');
    +  ee.on('foo', listener);
    +  getEventListeners(ee, 'foo'); // [listener]
    +}
    +{
    +  const et = new EventTarget();
    +  const listener = () => console.log('Events are fun');
    +  et.addEventListener('foo', listener);
    +  getEventListeners(et, 'foo'); // [listener]
    +}
    +
    +
    +
    since
    +

    v15.2.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      emitter: EventEmitter | DOMEventTarget
      +
    • +
    • +
      name: string | symbol
      +
    • +
    +

    Returns Function[]

    +
  • +
+
+
+ +

Static listenerCount

+
    +
  • listenerCount(emitter: EventEmitter, eventName: string | symbol): number
  • +
+
    +
  • + +
    +
    +

    A class method that returns the number of listeners for the given eventNameregistered on the given emitter.

    +
    +
    const { EventEmitter, listenerCount } = require('events');
    +const myEmitter = new EventEmitter();
    +myEmitter.on('event', () => {});
    +myEmitter.on('event', () => {});
    +console.log(listenerCount(myEmitter, 'event'));
    +// Prints: 2
    +
    +
    +
    since
    +

    v0.9.12

    +
    +
    deprecated
    +

    Since v3.2.0 - Use listenerCount instead.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      emitter: EventEmitter
      +
      +

      The emitter to query

      +
      +
    • +
    • +
      eventName: string | symbol
      +
      +

      The event name

      +
      +
    • +
    +

    Returns number

    +
  • +
+
+
+ +

Static on

+
    +
  • on(emitter: EventEmitter, eventName: string, options?: StaticEventEmitterOptions): AsyncIterableIterator<any>
  • +
+
    +
  • + +
    +
    +

    ```js + const { on, EventEmitter } = require('events');

    +
    +

    (async () => { + const ee = new EventEmitter();

    +

    // Emit later on + process.nextTick(() => { + ee.emit('foo', 'bar'); + ee.emit('foo', 42); + });

    +

    for await (const event of on(ee, 'foo')) { + // The execution of this inner block is synchronous and it + // processes one event at a time (even with await). Do not use + // if concurrent execution is required. + console.log(event); // prints ['bar'] [42] + } + // Unreachable here + })();

    +
    
    +Returns an `AsyncIterator` that iterates `eventName` events. It will throw
    +if the `EventEmitter` emits `'error'`. It removes all listeners when
    +exiting the loop. The `value` returned by each iteration is an array
    +composed of the emitted event arguments.
    +
    +An `AbortSignal` can be used to cancel waiting on events:
    +
    +```js
    +const { on, EventEmitter } = require('events');
    +const ac = new AbortController();
    +
    +(async () => {
    +  const ee = new EventEmitter();
    +
    +  // Emit later on
    +  process.nextTick(() => {
    +    ee.emit('foo', 'bar');
    +    ee.emit('foo', 42);
    +  });
    +
    +  for await (const event of on(ee, 'foo', { signal: ac.signal })) {
    +    // The execution of this inner block is synchronous and it
    +    // processes one event at a time (even with await). Do not use
    +    // if concurrent execution is required.
    +    console.log(event); // prints ['bar'] [42]
    +  }
    +  // Unreachable here
    +})();
    +
    +process.nextTick(() => ac.abort());
    +
    +
    +
    since
    +

    v13.6.0, v12.16.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      emitter: EventEmitter
      +
    • +
    • +
      eventName: string
      +
      +

      The name of the event being listened for

      +
      +
    • +
    • +
      Optional options: StaticEventEmitterOptions
      +
    • +
    +

    Returns AsyncIterableIterator<any>

    +

    that iterates eventName events emitted by the emitter

    +
  • +
+
+
+ +

Static once

+
    +
  • once(emitter: NodeEventTarget, eventName: string | symbol, options?: StaticEventEmitterOptions): Promise<any[]>
  • +
  • once(emitter: DOMEventTarget, eventName: string, options?: StaticEventEmitterOptions): Promise<any[]>
  • +
+
    +
  • + +
    +
    +

    Creates a Promise that is fulfilled when the EventEmitter emits the given + event or that is rejected if the EventEmitter emits 'error' while waiting. + The Promise will resolve with an array of all the arguments emitted to the + given event.

    +
    +

    This method is intentionally generic and works with the web platform EventTarget interface, which has no special'error' event + semantics and does not listen to the 'error' event.

    +
    const { once, EventEmitter } = require('events');
    +
    +async function run() {
    +  const ee = new EventEmitter();
    +
    +  process.nextTick(() => {
    +    ee.emit('myevent', 42);
    +  });
    +
    +  const [value] = await once(ee, 'myevent');
    +  console.log(value);
    +
    +  const err = new Error('kaboom');
    +  process.nextTick(() => {
    +    ee.emit('error', err);
    +  });
    +
    +  try {
    +    await once(ee, 'myevent');
    +  } catch (err) {
    +    console.log('error happened', err);
    +  }
    +}
    +
    +run();
    +
    +

    The special handling of the 'error' event is only used when events.once()is used to wait for another event. If events.once() is used to wait for the + 'error' event itself, then it is treated as any other kind of event without + special handling:

    +
    const { EventEmitter, once } = require('events');
    +
    +const ee = new EventEmitter();
    +
    +once(ee, 'error')
    +  .then(([err]) => console.log('ok', err.message))
    +  .catch((err) => console.log('error', err.message));
    +
    +ee.emit('error', new Error('boom'));
    +
    +// Prints: ok boom
    +
    +

    An AbortSignal can be used to cancel waiting for the event:

    +
    const { EventEmitter, once } = require('events');
    +
    +const ee = new EventEmitter();
    +const ac = new AbortController();
    +
    +async function foo(emitter, event, signal) {
    +  try {
    +    await once(emitter, event, { signal });
    +    console.log('event emitted!');
    +  } catch (error) {
    +    if (error.name === 'AbortError') {
    +      console.error('Waiting for the event was canceled!');
    +    } else {
    +      console.error('There was an error', error.message);
    +    }
    +  }
    +}
    +
    +foo(ee, 'foo', ac.signal);
    +ac.abort(); // Abort waiting for the event
    +ee.emit('foo'); // Prints: Waiting for the event was canceled!
    +
    +
    +
    since
    +

    v11.13.0, v10.16.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      emitter: NodeEventTarget
      +
    • +
    • +
      eventName: string | symbol
      +
    • +
    • +
      Optional options: StaticEventEmitterOptions
      +
    • +
    +

    Returns Promise<any[]>

    +
  • +
  • + +

    Parameters

    +
      +
    • +
      emitter: DOMEventTarget
      +
    • +
    • +
      eventName: string
      +
    • +
    • +
      Optional options: StaticEventEmitterOptions
      +
    • +
    +

    Returns Promise<any[]>

    +
  • +
+
+
+ +

addListener

+
    +
  • addListener(eventName: string | symbol, listener: (...args: any[]) => void): AdvancedClient
  • +
+
    +
  • + +
    +
    +

    Alias for emitter.on(eventName, listener).

    +
    +
    +
    since
    +

    v0.1.26

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
    • +
    • +
      listener: (...args: any[]) => void
      +
        +
      • +
          +
        • (...args: any[]): void
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns void

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

destroy

+
    +
  • destroy(): void
  • +
+
    +
  • + +

    Returns void

    +
  • +
+
+
+ +

emit

+
    +
  • emit<K>(event: K, ...args: ClientEvents[K]): boolean
  • +
  • emit<S>(event: Exclude<S, keyof ClientEvents>, ...args: unknown[]): boolean
  • +
+
    +
  • + +

    Type parameters

    +
      +
    • +

      K: keyof ClientEvents

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: K
      +
    • +
    • +
      Rest ...args: ClientEvents[K]
      +
    • +
    +

    Returns boolean

    +
  • +
  • + +

    Type parameters

    +
      +
    • +

      S: string | symbol

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: Exclude<S, keyof ClientEvents>
      +
    • +
    • +
      Rest ...args: unknown[]
      +
    • +
    +

    Returns boolean

    +
  • +
+
+
+ +

eventNames

+
    +
  • eventNames(): (string | symbol)[]
  • +
+
    +
  • + +
    +
    +

    Returns an array listing the events for which the emitter has registered + listeners. The values in the array are strings or Symbols.

    +
    +
    const EventEmitter = require('events');
    +const myEE = new EventEmitter();
    +myEE.on('foo', () => {});
    +myEE.on('bar', () => {});
    +
    +const sym = Symbol('symbol');
    +myEE.on(sym, () => {});
    +
    +console.log(myEE.eventNames());
    +// Prints: [ 'foo', 'bar', Symbol(symbol) ]
    +
    +
    +
    since
    +

    v6.0.0

    +
    +
    +
    +

    Returns (string | symbol)[]

    +
  • +
+
+
+ +

fetchGuildPreview

+
    +
  • fetchGuildPreview(guild: GuildResolvable): Promise<GuildPreview>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      guild: GuildResolvable
      +
    • +
    +

    Returns Promise<GuildPreview>

    +
  • +
+
+
+ +

fetchGuildTemplate

+
    +
  • fetchGuildTemplate(template: string): Promise<GuildTemplate>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      template: string
      +
    • +
    +

    Returns Promise<GuildTemplate>

    +
  • +
+
+
+ +

fetchGuildWidget

+
    +
  • fetchGuildWidget(guild: GuildResolvable): Promise<Widget>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      guild: GuildResolvable
      +
    • +
    +

    Returns Promise<Widget>

    +
  • +
+
+
+ +

fetchInvite

+
    +
  • fetchInvite(invite: string): Promise<Invite>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      invite: string
      +
    • +
    +

    Returns Promise<Invite>

    +
  • +
+
+
+ +

fetchPremiumStickerPacks

+
    +
  • fetchPremiumStickerPacks(): Promise<Collection<string, StickerPack>>
  • +
+
    +
  • + +

    Returns Promise<Collection<string, StickerPack>>

    +
  • +
+
+
+ +

fetchSticker

+
    +
  • fetchSticker(id: string): Promise<Sticker>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      id: string
      +
    • +
    +

    Returns Promise<Sticker>

    +
  • +
+
+
+ +

fetchVoiceRegions

+
    +
  • fetchVoiceRegions(): Promise<Collection<string, VoiceRegion>>
  • +
+
    +
  • + +

    Returns Promise<Collection<string, VoiceRegion>>

    +
  • +
+
+
+ +

fetchWebhook

+
    +
  • fetchWebhook(id: string, token?: string): Promise<Webhook>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      id: string
      +
    • +
    • +
      Optional token: string
      +
    • +
    +

    Returns Promise<Webhook>

    +
  • +
+
+
+ +

generateInvite

+
    +
  • generateInvite(options?: InviteGenerationOptions): string
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Optional options: InviteGenerationOptions
      +
    • +
    +

    Returns string

    +
  • +
+
+
+ +

getMaxListeners

+
    +
  • getMaxListeners(): number
  • +
+
    +
  • + +
    +
    +

    Returns the current max listener value for the EventEmitter which is either + set by emitter.setMaxListeners(n) or defaults to defaultMaxListeners.

    +
    +
    +
    since
    +

    v1.0.0

    +
    +
    +
    +

    Returns number

    +
  • +
+
+
+ +

isReady

+
    +
  • isReady(): this is Client<true>
  • +
+
    +
  • + +

    Returns this is Client<true>

    +
  • +
+
+
+ +

listenerCount

+
    +
  • listenerCount(eventName: string | symbol): number
  • +
+
    +
  • + +
    +
    +

    Returns the number of listeners listening to the event named eventName.

    +
    +
    +
    since
    +

    v3.2.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
      +

      The name of the event being listened for

      +
      +
    • +
    +

    Returns number

    +
  • +
+
+
+ +

listeners

+
    +
  • listeners(eventName: string | symbol): Function[]
  • +
+
    +
  • + +
    +
    +

    Returns a copy of the array of listeners for the event named eventName.

    +
    +
    server.on('connection', (stream) => {
    +  console.log('someone connected!');
    +});
    +console.log(util.inspect(server.listeners('connection')));
    +// Prints: [ [Function] ]
    +
    +
    +
    since
    +

    v0.1.26

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
    • +
    +

    Returns Function[]

    +
  • +
+
+
+ +

login

+
    +
  • login(token?: string): Promise<string>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Optional token: string
      +
    • +
    +

    Returns Promise<string>

    +
  • +
+
+
+ +

off

+
    +
  • off<K>(event: K, listener: (...args: ClientEvents[K]) => Awaited<void>): AdvancedClient
  • +
  • off<S>(event: Exclude<S, keyof ClientEvents>, listener: (...args: any[]) => Awaited<void>): AdvancedClient
  • +
+
    +
  • + +

    Type parameters

    +
      +
    • +

      K: keyof ClientEvents

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: K
      +
    • +
    • +
      listener: (...args: ClientEvents[K]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: ClientEvents[K]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: ClientEvents[K]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
  • + +

    Type parameters

    +
      +
    • +

      S: string | symbol

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: Exclude<S, keyof ClientEvents>
      +
    • +
    • +
      listener: (...args: any[]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: any[]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

on

+
    +
  • on<K>(event: K, listener: (...args: ClientEvents[K]) => Awaited<void>): AdvancedClient
  • +
  • on<S>(event: Exclude<S, keyof ClientEvents>, listener: (...args: any[]) => Awaited<void>): AdvancedClient
  • +
+
    +
  • + +

    Type parameters

    +
      +
    • +

      K: keyof ClientEvents

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: K
      +
    • +
    • +
      listener: (...args: ClientEvents[K]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: ClientEvents[K]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: ClientEvents[K]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
  • + +

    Type parameters

    +
      +
    • +

      S: string | symbol

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: Exclude<S, keyof ClientEvents>
      +
    • +
    • +
      listener: (...args: any[]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: any[]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

once

+
    +
  • once<K>(event: K, listener: (...args: ClientEvents[K]) => Awaited<void>): AdvancedClient
  • +
  • once<S>(event: Exclude<S, keyof ClientEvents>, listener: (...args: any[]) => Awaited<void>): AdvancedClient
  • +
+
    +
  • + +

    Type parameters

    +
      +
    • +

      K: keyof ClientEvents

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: K
      +
    • +
    • +
      listener: (...args: ClientEvents[K]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: ClientEvents[K]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: ClientEvents[K]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
  • + +

    Type parameters

    +
      +
    • +

      S: string | symbol

      +
    • +
    +

    Parameters

    +
      +
    • +
      event: Exclude<S, keyof ClientEvents>
      +
    • +
    • +
      listener: (...args: any[]) => Awaited<void>
      +
        +
      • +
          +
        • (...args: any[]): Awaited<void>
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns Awaited<void>

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

prependListener

+
    +
  • prependListener(eventName: string | symbol, listener: (...args: any[]) => void): AdvancedClient
  • +
+
    +
  • + +
    +
    +

    Adds the listener function to the beginning of the listeners array for the + event named eventName. No checks are made to see if the listener has + already been added. Multiple calls passing the same combination of eventNameand listener will result in the listener being added, and called, multiple + times.

    +
    +
    server.prependListener('connection', (stream) => {
    +  console.log('someone connected!');
    +});
    +
    +

    Returns a reference to the EventEmitter, so that calls can be chained.

    +
    +
    since
    +

    v6.0.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
      +

      The name of the event.

      +
      +
    • +
    • +
      listener: (...args: any[]) => void
      +
      +

      The callback function

      +
      +
        +
      • +
          +
        • (...args: any[]): void
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns void

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

prependOnceListener

+
    +
  • prependOnceListener(eventName: string | symbol, listener: (...args: any[]) => void): AdvancedClient
  • +
+
    +
  • + +
    +
    +

    Adds a one-timelistener function for the event named eventName to the_beginning_ of the listeners array. The next time eventName is triggered, this + listener is removed, and then invoked.

    +
    +
    server.prependOnceListener('connection', (stream) => {
    +  console.log('Ah, we have our first user!');
    +});
    +
    +

    Returns a reference to the EventEmitter, so that calls can be chained.

    +
    +
    since
    +

    v6.0.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
      +

      The name of the event.

      +
      +
    • +
    • +
      listener: (...args: any[]) => void
      +
      +

      The callback function

      +
      +
        +
      • +
          +
        • (...args: any[]): void
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns void

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

rawListeners

+
    +
  • rawListeners(eventName: string | symbol): Function[]
  • +
+
    +
  • + +
    +
    +

    Returns a copy of the array of listeners for the event named eventName, + including any wrappers (such as those created by .once()).

    +
    +
    const emitter = new EventEmitter();
    +emitter.once('log', () => console.log('log once'));
    +
    +// Returns a new Array with a function `onceWrapper` which has a property
    +// `listener` which contains the original listener bound above
    +const listeners = emitter.rawListeners('log');
    +const logFnWrapper = listeners[0];
    +
    +// Logs "log once" to the console and does not unbind the `once` event
    +logFnWrapper.listener();
    +
    +// Logs "log once" to the console and removes the listener
    +logFnWrapper();
    +
    +emitter.on('log', () => console.log('log persistently'));
    +// Will return a new Array with a single function bound by `.on()` above
    +const newListeners = emitter.rawListeners('log');
    +
    +// Logs "log persistently" twice
    +newListeners[0]();
    +emitter.emit('log');
    +
    +
    +
    since
    +

    v9.4.0

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
    • +
    +

    Returns Function[]

    +
  • +
+
+
+ +

removeAllListeners

+ +
    +
  • + +

    Type parameters

    +
      +
    • +

      K: keyof ClientEvents

      +
    • +
    +

    Parameters

    +
      +
    • +
      Optional event: K
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
  • + +

    Type parameters

    +
      +
    • +

      S: string | symbol

      +
    • +
    +

    Parameters

    +
      +
    • +
      Optional event: Exclude<S, keyof ClientEvents>
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

removeListener

+
    +
  • removeListener(eventName: string | symbol, listener: (...args: any[]) => void): AdvancedClient
  • +
+
    +
  • + +
    +
    +

    Removes the specified listener from the listener array for the event namedeventName.

    +
    +
    const callback = (stream) => {
    +  console.log('someone connected!');
    +};
    +server.on('connection', callback);
    +// ...
    +server.removeListener('connection', callback);
    +
    +

    removeListener() will remove, at most, one instance of a listener from the + listener array. If any single listener has been added multiple times to the + listener array for the specified eventName, then removeListener() must be + called multiple times to remove each instance.

    +

    Once an event is emitted, all listeners attached to it at the + time of emitting are called in order. This implies that anyremoveListener() or removeAllListeners() calls after emitting and_before_ the last listener finishes execution will + not remove them fromemit() in progress. Subsequent events behave as expected.

    +
    const myEmitter = new MyEmitter();
    +
    +const callbackA = () => {
    +  console.log('A');
    +  myEmitter.removeListener('event', callbackB);
    +};
    +
    +const callbackB = () => {
    +  console.log('B');
    +};
    +
    +myEmitter.on('event', callbackA);
    +
    +myEmitter.on('event', callbackB);
    +
    +// callbackA removes listener callbackB but it will still be called.
    +// Internal listener array at time of emit [callbackA, callbackB]
    +myEmitter.emit('event');
    +// Prints:
    +//   A
    +//   B
    +
    +// callbackB is now removed.
    +// Internal listener array [callbackA]
    +myEmitter.emit('event');
    +// Prints:
    +//   A
    +
    +

    Because listeners are managed using an internal array, calling this will + change the position indices of any listener registered after the listener + being removed. This will not impact the order in which listeners are called, + but it means that any copies of the listener array as returned by + the emitter.listeners() method will need to be recreated.

    +

    When a single function has been added as a handler multiple times for a single + event (as in the example below), removeListener() will remove the most + recently added instance. In the example the once('ping')listener is removed:

    +
    const ee = new EventEmitter();
    +
    +function pong() {
    +  console.log('pong');
    +}
    +
    +ee.on('ping', pong);
    +ee.once('ping', pong);
    +ee.removeListener('ping', pong);
    +
    +ee.emit('ping');
    +ee.emit('ping');
    +
    +

    Returns a reference to the EventEmitter, so that calls can be chained.

    +
    +
    since
    +

    v0.1.26

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      eventName: string | symbol
      +
    • +
    • +
      listener: (...args: any[]) => void
      +
        +
      • +
          +
        • (...args: any[]): void
        • +
        +
          +
        • +

          Parameters

          +
            +
          • +
            Rest ...args: any[]
            +
          • +
          +

          Returns void

          +
        • +
        +
      • +
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

setMaxListeners

+ +
    +
  • + +
    +
    +

    By default EventEmitters will print a warning if more than 10 listeners are + added for a particular event. This is a useful default that helps finding + memory leaks. The emitter.setMaxListeners() method allows the limit to be + modified for this specific EventEmitter instance. The value can be set toInfinity (or 0) to indicate an unlimited number of listeners.

    +
    +

    Returns a reference to the EventEmitter, so that calls can be chained.

    +
    +
    since
    +

    v0.3.5

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      n: number
      +
    • +
    +

    Returns AdvancedClient

    +
  • +
+
+
+ +

sweepMessages

+
    +
  • sweepMessages(lifetime?: number): number
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Optional lifetime: number
      +
    • +
    +

    Returns number

    +
  • +
+
+
+ +

toJSON

+
    +
  • toJSON(): unknown
  • +
+
    +
  • + +

    Returns unknown

    +
  • +
+
+
+
+

Constructors

+
+ +

constructor

+
    +
  • new AdvancedClient(token: string, options: ClientOptions): AdvancedClient
  • +
+ +
+
+
+

Accessors

+
+ +

id

+
    +
  • get id(): undefined | string
  • +
+ +
+
+ +

mention

+
    +
  • get mention(): `<@${string}>`
  • +
+ +
+
+ +

ping

+
    +
  • get ping(): number
  • +
+ +
+
+ +

tag

+
    +
  • get tag(): undefined | string
  • +
+ +
+
+ +

username

+
    +
  • get username(): undefined | string
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/Argument.html b/docs-release/classes/Argument.html new file mode 100644 index 0000000..65f93e4 --- /dev/null +++ b/docs-release/classes/Argument.html @@ -0,0 +1,268 @@ + + + + + + Argument + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class Argument<T>

+
+
+
+
+
+
+
+

Type parameters

+
    +
  • +

    T

    +
  • +
+
+
+

Hierarchy

+
    +
  • + Argument +
  • +
+
+
+

Index

+
+
+
+

Constructors

+ +
+
+

Properties

+ +
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Properties

+
+ +

options

+
options: ArgumentOptions<T>
+ +
+
+ +

parser

+
parser: ArgumentParser<T>
+ +
+
+ +

type

+ + +
+
+ +

validator

+
validator: ArgumentValidator
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/ArgumentContext.html b/docs-release/classes/ArgumentContext.html new file mode 100644 index 0000000..87d7efb --- /dev/null +++ b/docs-release/classes/ArgumentContext.html @@ -0,0 +1,1400 @@ + + + + + + ArgumentContext + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class ArgumentContext

+
+
+
+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+ +
+
+
+

Accessors

+
+ +

args

+
    +
  • get args(): string[]
  • +
+ +
+
+ +

argsString

+
    +
  • get argsString(): string
  • +
+ +
+
+ +

arguments

+ + +
+
+ +

channel

+
    +
  • get channel(): TextBasedChannels
  • +
+ +
+
+ +

client

+ + +
+
+ +

commandName

+
    +
  • get commandName(): string
  • +
+ +
+
+ +

content

+
    +
  • get content(): string
  • +
+ +
+
+ +

guild

+
    +
  • get guild(): null | Guild
  • +
+ +
+
+ +

isCallingASubCommand

+
    +
  • get isCallingASubCommand(): boolean
  • +
+ +
+
+ +

member

+
    +
  • get member(): null | GuildMember
  • +
+ +
+
+ +

prefix

+
    +
  • get prefix(): string
  • +
+ +
+
+ +

textChannel

+
    +
  • get textChannel(): undefined | TextChannel | NewsChannel
  • +
+ +
+
+ +

thread

+
    +
  • get thread(): undefined | ThreadChannel
  • +
+ +
+
+ +

user

+
    +
  • get user(): User
  • +
+ +
+
+
+

Methods

+
+ +

argument

+
    +
  • argument<T>(name: string): Promise<null | T>
  • +
+
    +
  • + +
    +
    +

    Returns an argument. + If the argument is errored or not found it will return null.

    +
    +
    +

    Type parameters

    +
      +
    • +

      T

      +
      +

      The type of the argument.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The name of the argument.

      +
      +
    • +
    +

    Returns Promise<null | T>

    +
      +
    • The argument in a promise or null if the argument is not found or errored or the command has no arguments.
    • +
    +
  • +
+
+
+ +

bulkDeleteInChannel

+
    +
  • bulkDeleteInChannel(number: number, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: Collection<string, Message>, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: readonly MessageResolvable[], filterOld?: boolean): Promise<Collection<string, Message>>
  • +
+ +
+
+ +

createThread

+
    +
  • createThread(options: StartThreadOptions): undefined | Promise<ThreadChannel>
  • +
+ +
+
+ +

deleteMessage

+
    +
  • deleteMessage(timeout?: number): Promise<Message>
  • +
+ +
+
+ +

react

+
    +
  • react(...emoji: EmojiIdentifierResolvable[]): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Add one or multiple reactions to a message.

    +
    +
    +
    remarks
    +

    React in the order of emoji used.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Rest ...emoji: EmojiIdentifierResolvable[]
      +
      +

      The emoji to react with, can be custom or native.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

removeAllReactions

+
    +
  • removeAllReactions(): Promise<void>
  • +
+ +
+
+ +

removeReaction

+
    +
  • removeReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+ +
+
+ +

removeSelfReaction

+
    +
  • removeSelfReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+ +
+
+ +

reply

+
    +
  • reply(options: ReplyOptions): Promise<Message>
  • +
  • reply(content: string): Promise<Message>
  • +
  • reply(content: string, options: ReplyOptions): Promise<Message>
  • +
+ +
+
+ +

resolveArgument

+ + +
+
+ +

resolveArguments

+
    +
  • resolveArguments<A>(): Promise<undefined | Map<string, ArgumentResolved<A[number]>>>
  • +
+ +
+
+ +

send

+
    +
  • send(options: SendOptions): Promise<Message>
  • +
  • send(content: string): Promise<Message>
  • +
  • send(content: string, options: SendOptions): Promise<Message>
  • +
+ +
+
+ +

sendGlobalHelpMessage

+
    +
  • sendGlobalHelpMessage(): Promise<Message>
  • +
+ +
+
+ +

sendHelpMessage

+
    +
  • sendHelpMessage(commandName?: string): Promise<undefined | Message>
  • +
+
    +
  • + +
    +
    +

    Sends the help menu of the command from the default HelpCommand command (even if you are not using it).

    +
    +
    +

    Parameters

    +
      +
    • +
      commandName: string = ...
      +
      +

      The name of the command to send the help menu.

      +
      +
    • +
    +

    Returns Promise<undefined | Message>

    +
      +
    • The message of the help menu of the command.
    • +
    +
  • +
+
+
+
+

Properties

+
+ +

Optional argumentParser

+
argumentParser: ArgumentParser
+ +
+
+

The argument parser of this context, if the command has no arguments it will be undefined.

+
+
+
+
+ +

command

+
command: Command
+ +
+
+

The command itself.

+
+
+
+
+ +

currentArgument

+
currentArgument: CommandArgument<any>
+ +
+
+

The current argument.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The handler.

+
+
+
+
+ +

index

+
index: number
+ +
+
+

The index of the current argument in the arguments of the command.

+
+
+
+
+ +

message

+
message: Message
+ +
+
+

The message that executed the command.

+
+
+
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+

The arguments in the message.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+
    +
  • new ArgumentContext(options: ArgumentContextBuilder): ArgumentContext
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/ArgumentParser.html b/docs-release/classes/ArgumentParser.html new file mode 100644 index 0000000..dea8939 --- /dev/null +++ b/docs-release/classes/ArgumentParser.html @@ -0,0 +1,583 @@ + + + + + + ArgumentParser + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class ArgumentParser

+
+
+
+
+
+
+
+

Hierarchy

+
    +
  • + ArgumentParser +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Static errors

+
errors: { argumentNotFound: (argumentName: string) => string; argumentRequiresOneValue: (argumentName: string) => string; errorInArgument: (argumentName: string) => string; invalidArgument: (argumentName: string) => string } = ...
+ +
+

Type declaration

+
    +
  • +
    argumentNotFound: (argumentName: string) => string
    +
      +
    • +
        +
      • (argumentName: string): string
      • +
      +
        +
      • +

        Parameters

        +
          +
        • +
          argumentName: string
          +
        • +
        +

        Returns string

        +
      • +
      +
    • +
    +
  • +
  • +
    argumentRequiresOneValue: (argumentName: string) => string
    +
      +
    • +
        +
      • (argumentName: string): string
      • +
      +
        +
      • +

        Parameters

        +
          +
        • +
          argumentName: string
          +
        • +
        +

        Returns string

        +
      • +
      +
    • +
    +
  • +
  • +
    errorInArgument: (argumentName: string) => string
    +
      +
    • +
        +
      • (argumentName: string): string
      • +
      +
        +
      • +

        Parameters

        +
          +
        • +
          argumentName: string
          +
        • +
        +

        Returns string

        +
      • +
      +
    • +
    +
  • +
  • +
    invalidArgument: (argumentName: string) => string
    +
      +
    • +
        +
      • (argumentName: string): string
      • +
      +
        +
      • +

        Parameters

        +
          +
        • +
          argumentName: string
          +
        • +
        +

        Returns string

        +
      • +
      +
    • +
    +
  • +
+
+
+
+ +

args

+
args: CommandArgument<any>[]
+ +
+
+ +

Optional parsed

+
parsed: Map<string, any>
+ +
+
+ +

parser

+
parser: Parser
+ +
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+
+

Methods

+
+ +

Static Private argumentNotFoundError

+ + +
+
+ +

Static Private argumentRequiresOneValueError

+ + +
+
+ +

Static Private errorInArgumentError

+ + +
+
+ +

Static Private invalidArgumentError

+ + +
+
+ +

parseArguments

+ + +
+
+ +

resolveArgument

+ + +
+
+ +

resolveArguments

+ + +
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/BetterEmbed.html b/docs-release/classes/BetterEmbed.html new file mode 100644 index 0000000..35f26a7 --- /dev/null +++ b/docs-release/classes/BetterEmbed.html @@ -0,0 +1,1257 @@ + + + + + + BetterEmbed + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class BetterEmbed

+
+
+
+
+
+
+
+

Hierarchy

+
    +
  • + MessageEmbed +
      +
    • + BetterEmbed +
    • +
    +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Static LENGTH_LIMITS

+
LENGTH_LIMITS: { author: { name: number }; description: number; fields: { name: number; size: number; value: number }; footer: { text: number }; title: number }
+ +
+

Type declaration

+
    +
  • +
    author: { name: number }
    +
      +
    • +
      name: number
      +
    • +
    +
  • +
  • +
    description: number
    +
  • +
  • +
    fields: { name: number; size: number; value: number }
    +
      +
    • +
      name: number
      +
    • +
    • +
      size: number
      +
    • +
    • +
      value: number
      +
    • +
    +
  • +
  • +
    footer: { text: number }
    +
      +
    • +
      text: number
      +
    • +
    +
  • +
  • +
    title: number
    +
  • +
+
+
+
+ +

Static TEMPLATES

+
TEMPLATES: TemplatesValues
+ +
+
+ +

author

+
author: null | MessageEmbedAuthor
+ +
+
+ +

color

+
color: null | number
+ +
+
+ +

Readonly createdAt

+
createdAt: null | Date
+ +
+
+ +

description

+
description: null | string
+ +
+
+ +

fields

+
fields: EmbedField[]
+ +
+
+ +

footer

+
footer: null | MessageEmbedFooter
+ +
+
+ +

Readonly hexColor

+
hexColor: null | `#${string}`
+ +
+
+ +

image

+
image: null | MessageEmbedImage
+ +
+
+ +

Readonly length

+
length: number
+ +
+
+ +

provider

+
provider: null | MessageEmbedProvider
+ +
+
+ +

thumbnail

+
thumbnail: null | MessageEmbedThumbnail
+ +
+
+ +

timestamp

+
timestamp: null | number
+ +
+
+ +

title

+
title: null | string
+ +
+
+ +

type

+
type: string
+ +
+
+
deprecated
+
+
+
+
+
+ +

url

+
url: null | string
+ +
+
+ +

Readonly video

+
video: null | MessageEmbedVideo
+ +
+
+
+

Methods

+
+ +

Static fromTemplate

+
    +
  • fromTemplate<T, V>(template: T, values?: V): BetterEmbed
  • +
+
    +
  • + +

    Type parameters

    + +

    Parameters

    +
      +
    • +
      template: T
      +
    • +
    • +
      Optional values: V
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

Static isTemplate

+
    +
  • isTemplate(key: string): key is string
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      key: string
      +
    • +
    +

    Returns key is string

    +
  • +
+
+
+ +

Static normalizeField

+
    +
  • normalizeField(name: string, value: string, inline?: boolean): Required<EmbedFieldData>
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      name: string
      +
    • +
    • +
      value: string
      +
    • +
    • +
      Optional inline: boolean
      +
    • +
    +

    Returns Required<EmbedFieldData>

    +
  • +
+
+
+ +

Static normalizeFields

+
    +
  • normalizeFields(...fields: EmbedFieldData[] | EmbedFieldData[][]): Required<EmbedFieldData>[]
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Rest ...fields: EmbedFieldData[] | EmbedFieldData[][]
      +
    • +
    +

    Returns Required<EmbedFieldData>[]

    +
  • +
+
+
+ +

addField

+
    +
  • addField(name: string, value: string, inline?: boolean): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      name: string
      +
    • +
    • +
      value: string
      +
    • +
    • +
      Optional inline: boolean
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

addFields

+
    +
  • addFields(...fields: EmbedFieldData[] | EmbedFieldData[][]): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Rest ...fields: EmbedFieldData[] | EmbedFieldData[][]
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

checkSize

+
    +
  • checkSize(field: "fields"): boolean | (({ index: number; limit: number } & { name: boolean }) & ({ index: number; limit: number } & { value: boolean }))
  • +
  • checkSize(field: keyof MessageEmbedOptions | "values"): boolean
  • +
  • checkSize(): {}
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      field: "fields"
      +
    • +
    +

    Returns boolean | (({ index: number; limit: number } & { name: boolean }) & ({ index: number; limit: number } & { value: boolean }))

    +
  • +
  • + +

    Parameters

    +
      +
    • +
      field: keyof MessageEmbedOptions | "values"
      +
    • +
    +

    Returns boolean

    +
  • +
  • + +

    Returns {}

    +
      +
    +
  • +
+
+
+ +

cutIfTooLong

+
    +
  • cutIfTooLong(): void
  • +
+
    +
  • + +

    Returns void

    +
  • +
+
+
+ +

setAuthor

+
    +
  • setAuthor(name: string, iconURL?: string, url?: string): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      name: string
      +
    • +
    • +
      Optional iconURL: string
      +
    • +
    • +
      Optional url: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setColor

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      color: ColorResolvable
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setDescription

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      description: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setFields

+
    +
  • setFields(...fields: EmbedFieldData[] | EmbedFieldData[][]): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Rest ...fields: EmbedFieldData[] | EmbedFieldData[][]
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setFooter

+
    +
  • setFooter(text: string, iconURL?: string): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      text: string
      +
    • +
    • +
      Optional iconURL: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setImage

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      url: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setImageFromFile

+
    +
  • setImageFromFile(attachment: MessageAttachment): void
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      attachment: MessageAttachment
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

setThumbnail

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      url: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setThumbnailFromFile

+
    +
  • setThumbnailFromFile(attachment: MessageAttachment): void
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      attachment: MessageAttachment
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

setTimestamp

+
    +
  • setTimestamp(timestamp?: number | Date): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      Optional timestamp: number | Date
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setTitle

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      title: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

setURL

+ +
    +
  • + +

    Parameters

    +
      +
    • +
      url: string
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

spliceFields

+
    +
  • spliceFields(index: number, deleteCount: number, ...fields: EmbedFieldData[] | EmbedFieldData[][]): BetterEmbed
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      index: number
      +
    • +
    • +
      deleteCount: number
      +
    • +
    • +
      Rest ...fields: EmbedFieldData[] | EmbedFieldData[][]
      +
    • +
    +

    Returns BetterEmbed

    +
  • +
+
+
+ +

throwIfTooLong

+
    +
  • throwIfTooLong(field: keyof MessageEmbedOptions | "values"): void
  • +
+
    +
  • + +

    Parameters

    +
      +
    • +
      field: keyof MessageEmbedOptions | "values"
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

toJSON

+
    +
  • toJSON(): unknown
  • +
+
    +
  • + +

    Returns unknown

    +
  • +
+
+
+
+

Constructors

+
+ +

constructor

+ +
    +
  • + +

    Parameters

    + +

    Returns BetterEmbed

    +
  • +
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/Command.html b/docs-release/classes/Command.html new file mode 100644 index 0000000..f19a73a --- /dev/null +++ b/docs-release/classes/Command.html @@ -0,0 +1,1218 @@ + + + + + + Command + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class Command

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+ +
+
+

Index

+
+ +
+
+
+

Methods

+
+ +

Static Private getSnowflake

+
    +
  • getSnowflake(from: string | Message | User | GuildMember): string
  • +
+
    +
  • + +
    +
    +

    Get a user ID from different sources, only here to simplify code.

    +
    +
    +
    internal
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      Where to get ID from.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The ID.
    • +
    +
  • +
+
+
+ +

deleteMessage

+ + +
+
+ +

execute

+ +
    +
  • + +
    +
    +

    Execute the run method, but perform validations before, prefer using this method in your custom Message Event.

    +
    +
    +

    Parameters

    + +

    Returns Promise<undefined | CommandError>

    +
      +
    • An error related to the command if any, for example : a tag not satisfied.
    • +
    +
  • +
+
+
+ +

getCooldown

+
    +
  • getCooldown(from: string | Message | User | GuildMember): Cooldown
  • +
+
    +
  • + +
    +
    +

    Get the actual cooldown of the user for this command plus when command has been executed and how many seconds to wait.

    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      Where to get the cooldown from, can be a user/guild/message, see types.

      +
      +
    • +
    +

    Returns Cooldown

    +
      +
    • The user's cooldown.
    • +
    +
  • +
+
+
+ +

getInvalidPermissions

+
    +
  • getInvalidPermissions(): { client: string[]; user: string[] }
  • +
+ +
+
+ +

getMissingPermissions

+ + +
+
+ +

getMissingTags

+ +
    +
  • + +
    +
    +

    Gives the tags of this command which are not validated by the context.
    + i.e. If a command is executed on a guild and the command has the dmOnly Tag, it will be returned.

    +
    +
    +

    Parameters

    + +

    Returns Tag[]

    +
      +
    • Tags that are not validated by the message.
    • +
    +
  • +
+
+
+ +

isInCooldown

+
    +
  • isInCooldown(from: string | Message | User | GuildMember): boolean
  • +
+
    +
  • + +
    +
    +

    Returns true if the user is in a cooldown for this command.

    +
    +
    +
    remarks
    +

    If cooldown not set, this will always return false.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      From where to test if user/guild/message is in a cooldown, see types.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • Is user in a cooldown.
    • +
    +
  • +
+
+
+ +

isInRightChannel

+ +
    +
  • + +
    +
    +

    Returns false if channels are defined for this command but the message doesn't come from one of it.

    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: CommandContext
      +
      +

      The context to test where it comes from.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • If it is on a channel required if used.
    • +
    +
  • +
+
+
+ +

Optional registerSubCommands

+
    +
  • registerSubCommands(): any
  • +
+ +
+
+ +

Abstract run

+ +
    +
  • + +
    +
    +

    The function to run when executing the command.

    +
    +
    +
    remarks
    +

    Use the {@link Command#execute} method if you want to have a validation before executing the run method.

    +
    +
    +
    +

    Parameters

    + +

    Returns any

    +
  • +
+
+
+ +

setCooldown

+
    +
  • setCooldown(from: string | Message | User | GuildMember): void
  • +
+
    +
  • + +
    +
    +

    Put all the required properties in CommandHandler.cooldowns plus the setTimeout to remove the user from the cooldowns.

    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      What to use to select the user to set the cooldown from, can be a guild/message/member.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

signature

+ +
    +
  • + +
    +
    +

    Get the signature of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument.

    +
    help [command]
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signature of this command or subCommand.
    • +
    +
  • +
+
+
+ +

signatures

+ +
    +
  • + +
    +
    +

    Returns the signature of the command plus the signature of the subCommands of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument and a all subCommand with no arguments.

    +
    help [command]
    +help all
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signatures of the command.
    • +
    +
  • +
+
+
+ +

validate

+ + +
+
+ +

Protected subCommand

+ + +
+
+
+

Properties

+
+ +

Optional aliases

+
aliases: string[]
+ +
+
+

The aliases of the command.

+
+
+
+
+ +

arguments

+
arguments: Record<string, Argument<any>> = {}
+ +
+
+

The arguments of the command. + You can put your own custom arguments but you must add the type to the argument types.

+
+
+
+
+ +

Optional category

+
category: string
+ +
+
+

The category of the command.

+
+
+
defaultvalue
+

The command parent directory.

+
+
+
+
+
+ +

Optional channels

+
channels: (string | TextChannel)[]
+ +
+
+

The channels where the command should only be executed if used (if using the default message event).

+
+
+
+
+ +

Optional clientPermissions

+
clientPermissions: string[]
+ +
+
+

The client permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+ +

Optional cooldown

+
cooldown: number
+ +
+
+

The cooldown of the command in seconds.

+
+
+
defaultvalue
+

0

+
+
remarks
+

Every cooldown should be saved in CommandHandler.cooldowns.

+
+
+
+
+
+ +

Optional description

+
description: string
+ +
+
+

The description of the command.

+
+
+
+
+ +

Readonly Abstract name

+
name: string
+ +
+
+

The name of the command.

+
+
+
+
+ +

subCommands

+
subCommands: SubCommand[] = []
+ +
+
+

The SubCommands of this command.

+
+
+
remarks
+

Register SubCommands using the {@link Command#registerSubCommands} method.

+
+
+
+
+
+ +

Optional tags

+
tags: string[]
+ +
+
+

The tags of the command.

+
+
+
remarks
+

How tags works ?

+
+
see
+

Tag

+
+
+
+
+
+ +

Optional usage

+
usage: string
+ +
+
+

The usage of the command.

+
+
+
example
+
userinfo
+userinfo me
+userinfo <ID/Username/Mention of User>
+
+
+
remarks
+

If no value is set, in most places it will use the result of the {@link Command#signatures} method.

+
+
+
+
+
+ +

Optional userPermissions

+
userPermissions: string[]
+ +
+
+

The user permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Accessors

+
+ +

nameAndAliases

+
    +
  • get nameAndAliases(): string[]
  • +
+ +
+
+ +

subCommandsNamesAndAliases

+
    +
  • get subCommandsNamesAndAliases(): string[]
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/CommandArgument.html b/docs-release/classes/CommandArgument.html new file mode 100644 index 0000000..859c052 --- /dev/null +++ b/docs-release/classes/CommandArgument.html @@ -0,0 +1,449 @@ + + + + + + CommandArgument + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class CommandArgument<T>

+
+
+
+
+
+
+
+

Type parameters

+
    +
  • +

    T

    +
  • +
+
+
+

Hierarchy

+
    +
  • + CommandArgument +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+

Constructors

+ +
+
+

Accessors

+ +
+
+
+
+
+

Properties

+
+ +

coalescing

+
coalescing: boolean
+ +
+
+

Does the argument can take multiple words.

+
+
+
+
+ +

defaultValue

+
defaultValue: undefined | T
+ +
+
+

The default value of the argument.

+
+
+
+
+ +

description

+
description: string
+ +
+
+

The description of the argument, currently not used anywhere.

+
+
+
+
+ +

index

+
index: number
+ +
+
+ +

name

+
name: string
+ +
+
+ +

optional

+
optional: boolean
+ +
+
+

Is the argument optional or not.

+
+
+
+
+ +

parse

+
parse: ArgumentParser<T>
+ +
+
+

The parse function of the argument.

+
+
+
+
+ +

type

+ + +
+
+

The type of the argument.

+
+
+
+
+ +

validate

+
validate: ArgumentValidator
+ +
+
+

The validate function of the argument.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Accessors

+
+ +

isSimple

+
    +
  • get isSimple(): boolean
  • +
+ +
+
+ +

isSkipable

+
    +
  • get isSkipable(): boolean
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/CommandContext.html b/docs-release/classes/CommandContext.html new file mode 100644 index 0000000..177020a --- /dev/null +++ b/docs-release/classes/CommandContext.html @@ -0,0 +1,1356 @@ + + + + + + CommandContext + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class CommandContext

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+ +
+
+

Implements

+ +
+
+

Index

+
+ +
+
+
+

Accessors

+
+ +

args

+
    +
  • get args(): string[]
  • +
+ +
+
+ +

argsString

+
    +
  • get argsString(): string
  • +
+ +
+
+ +

arguments

+ + +
+
+ +

channel

+
    +
  • get channel(): TextBasedChannels
  • +
+ +
+
+ +

client

+ + +
+
+ +

commandName

+
    +
  • get commandName(): string
  • +
+ +
+
+ +

content

+
    +
  • get content(): string
  • +
+ +
+
+ +

guild

+
    +
  • get guild(): null | Guild
  • +
+ +
+
+ +

isCallingASubCommand

+
    +
  • get isCallingASubCommand(): boolean
  • +
+ +
+
+ +

member

+
    +
  • get member(): null | GuildMember
  • +
+ +
+
+ +

prefix

+
    +
  • get prefix(): string
  • +
+ +
+
+ +

textChannel

+
    +
  • get textChannel(): undefined | TextChannel | NewsChannel
  • +
+ +
+
+ +

thread

+
    +
  • get thread(): undefined | ThreadChannel
  • +
+ +
+
+ +

user

+
    +
  • get user(): User
  • +
+ +
+
+
+

Methods

+
+ +

argument

+
    +
  • argument<T>(name: string): Promise<null | T>
  • +
+
    +
  • + +
    +
    +

    Returns an argument. + If the argument is errored or not found it will return null.

    +
    +
    +

    Type parameters

    +
      +
    • +

      T

      +
      +

      The type of the argument.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The name of the argument.

      +
      +
    • +
    +

    Returns Promise<null | T>

    +
      +
    • The argument in a promise or null if the argument is not found or errored or the command has no arguments.
    • +
    +
  • +
+
+
+ +

bulkDeleteInChannel

+
    +
  • bulkDeleteInChannel(number: number, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: Collection<string, Message>, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: readonly MessageResolvable[], filterOld?: boolean): Promise<Collection<string, Message>>
  • +
+ +
+
+ +

createThread

+
    +
  • createThread(options: StartThreadOptions): undefined | Promise<ThreadChannel>
  • +
+
    +
  • + +
    +
    +

    Create a Thread, returns undefined if already in a Thread.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: StartThreadOptions
      +
      +

      The options of the Thread.

      +
      +
    • +
    +

    Returns undefined | Promise<ThreadChannel>

    +
      +
    • The resulting Thread.
    • +
    +
  • +
+
+
+ +

deleteMessage

+
    +
  • deleteMessage(timeout?: number): Promise<Message>
  • +
+
    +
  • + +
    +
    +

    Deletes the message with an optional timeout.

    +
    +
    +

    Parameters

    +
      +
    • +
      timeout: number = 0
      +
      +

      The time to wait in milliseconds before deleting the message.

      +
      +
    • +
    +

    Returns Promise<Message>

    +
      +
    • The deleted message.
    • +
    +
  • +
+
+
+ +

react

+
    +
  • react(...emoji: EmojiIdentifierResolvable[]): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Add one or multiple reactions to a message.

    +
    +
    +
    remarks
    +

    React in the order of emoji used.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Rest ...emoji: EmojiIdentifierResolvable[]
      +
      +

      The emoji to react with, can be custom or native.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

removeAllReactions

+
    +
  • removeAllReactions(): Promise<void>
  • +
+ +
+
+ +

removeReaction

+
    +
  • removeReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Remove one or multiple reactions from emojis.

    +
    +
    +

    Parameters

    +
      +
    • +
      Rest ...emojis: EmojiIdentifierResolvable[]
      +
      +

      The list of emoji reactions to remove.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

removeSelfReaction

+
    +
  • removeSelfReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Remove one or multiple reactions from the bot.

    +
    +
    +

    Parameters

    +
      +
    • +
      Rest ...emojis: EmojiIdentifierResolvable[]
      +
      +

      The emojis the bot has to remove reaction from.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

reply

+
    +
  • reply(options: ReplyOptions): Promise<Message>
  • +
  • reply(content: string): Promise<Message>
  • +
  • reply(content: string, options: ReplyOptions): Promise<Message>
  • +
+ +
+
+ +

resolveArgument

+ +
    +
  • + +
    +
    +

    Resolves one of the argument. + If the argument is errored it will return a CommandError.

    +
    +
    +
    remarks
    +

    Internally it uses resolveArguments.

    +
    +
    +
    +

    Type parameters

    +
      +
    • +

      T

      +
      +

      The type of the argument.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The name of the argument.

      +
      +
    • +
    +

    Returns undefined | MaybePromise<ArgumentResolved<T>>

    +
      +
    • The result of the argument maybe in a promise or undefined if no arguments with this name exists or the command has no arguments.
    • +
    +
  • +
+
+
+ +

resolveArguments

+
    +
  • resolveArguments<A>(): Promise<undefined | Map<string, ArgumentResolved<A[number]>>>
  • +
+
    +
  • + +
    +
    +

    Resolves all of the arguments of the command. + If an argument has an error it will return a CommandError.

    +
    +
    +
    typeparam
    +

    The type of the arguments as an union.

    +
    +
    +
    +

    Type parameters

    +
      +
    • +

      A: any[]

      +
    • +
    +

    Returns Promise<undefined | Map<string, ArgumentResolved<A[number]>>>

    +
      +
    • A map of arguments or undefined if the command has no arguments.
    • +
    +
  • +
+
+
+ +

send

+
    +
  • send(options: SendOptions): Promise<Message>
  • +
  • send(content: string): Promise<Message>
  • +
  • send(content: string, options: SendOptions): Promise<Message>
  • +
+ +
+
+ +

sendGlobalHelpMessage

+
    +
  • sendGlobalHelpMessage(): Promise<Message>
  • +
+ +
+
+ +

sendHelpMessage

+
    +
  • sendHelpMessage(commandName?: string): Promise<undefined | Message>
  • +
+
    +
  • + +
    +
    +

    Sends the help menu of the command from the default HelpCommand command (even if you are not using it).

    +
    +
    +

    Parameters

    +
      +
    • +
      commandName: string = ...
      +
      +

      The name of the command to send the help menu.

      +
      +
    • +
    +

    Returns Promise<undefined | Message>

    +
      +
    • The message of the help menu of the command.
    • +
    +
  • +
+
+
+
+

Properties

+
+ +

Optional argumentParser

+
argumentParser: ArgumentParser
+ +
+
+

The argument parser of this context, if the command has no arguments it will be undefined.

+
+
+
+
+ +

command

+
command: Command
+ +
+
+

The command itself.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The handler.

+
+
+
+
+ +

message

+
message: Message
+ +
+
+

The message that executed the command.

+
+
+
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+

The arguments in the message.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/CommandError.html b/docs-release/classes/CommandError.html new file mode 100644 index 0000000..88c9e7a --- /dev/null +++ b/docs-release/classes/CommandError.html @@ -0,0 +1,467 @@ + + + + + + CommandError + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class CommandError

+
+
+
+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+
+
+

Methods

+ +
+
+

Properties

+ +
+
+

Constructors

+ +
+
+
+
+
+

Methods

+
+ +

Static captureStackTrace

+
    +
  • captureStackTrace(targetObject: object, constructorOpt?: Function): void
  • +
+
    +
  • + +
    +
    +

    Create .stack property on a target object

    +
    +
    +

    Parameters

    +
      +
    • +
      targetObject: object
      +
    • +
    • +
      Optional constructorOpt: Function
      +
    • +
    +

    Returns void

    +
  • +
+
+
+
+

Properties

+
+ +

Static Optional prepareStackTrace

+
prepareStackTrace: (err: Error, stackTraces: CallSite[]) => any
+ +
+
+

Optional override for formatting stack traces

+
+
+
+

Type declaration

+
    +
  • +
      +
    • (err: Error, stackTraces: CallSite[]): any
    • +
    +
      +
    • +
      +
      +

      Optional override for formatting stack traces

      +
      +
      +

      Parameters

      +
        +
      • +
        err: Error
        +
      • +
      • +
        stackTraces: CallSite[]
        +
      • +
      +

      Returns any

      +
    • +
    +
  • +
+
+
+
+ +

Static stackTraceLimit

+
stackTraceLimit: number
+ +
+
+ +

Readonly data

+
data: any
+ +
+
+

The data of the error, can be anything but should be related to the error type.

+
+
+
see
+

CommandErrorBuilder#type.

+
+
+
+
+
+ +

Readonly date

+
date: Date
+ +
+
+

When the error occurred.

+
+
+
+
+ +

message

+
message: string
+ +
+
+ +

name

+
name: string
+ +
+
+ +

Optional stack

+
stack: string
+ +
+
+ +

Readonly type

+ + +
+
+

The type of CommandError.

+
+
+
+
+ +

Readonly where

+
where: string
+ +
+
+

Where the error occurred.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/CommandHandlerError.html b/docs-release/classes/CommandHandlerError.html new file mode 100644 index 0000000..ec84f3e --- /dev/null +++ b/docs-release/classes/CommandHandlerError.html @@ -0,0 +1,415 @@ + + + + + + CommandHandlerError + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class CommandHandlerError

+
+
+
+
+
+
+
+

Hierarchy

+
    +
  • + Error + +
  • +
+
+
+

Index

+
+
+
+

Methods

+ +
+
+

Properties

+ +
+
+

Constructors

+ +
+
+
+
+
+

Methods

+
+ +

Static captureStackTrace

+
    +
  • captureStackTrace(targetObject: object, constructorOpt?: Function): void
  • +
+
    +
  • + +
    +
    +

    Create .stack property on a target object

    +
    +
    +

    Parameters

    +
      +
    • +
      targetObject: object
      +
    • +
    • +
      Optional constructorOpt: Function
      +
    • +
    +

    Returns void

    +
  • +
+
+
+
+

Properties

+
+ +

Static Optional prepareStackTrace

+
prepareStackTrace: (err: Error, stackTraces: CallSite[]) => any
+ +
+

Type declaration

+
    +
  • +
      +
    • (err: Error, stackTraces: CallSite[]): any
    • +
    +
      +
    • +
      +
      +

      Optional override for formatting stack traces

      +
      +
      +

      Parameters

      +
        +
      • +
        err: Error
        +
      • +
      • +
        stackTraces: CallSite[]
        +
      • +
      +

      Returns any

      +
    • +
    +
  • +
+
+
+
+ +

Static stackTraceLimit

+
stackTraceLimit: number
+ +
+
+ +

Readonly date

+
date: Date
+ +
+
+

When the error occurred.

+
+
+
+
+ +

message

+
message: string
+ +
+
+ +

name

+
name: string
+ +
+
+ +

Optional stack

+
stack: string
+ +
+
+ +

Readonly where

+
where: string
+ +
+
+

Where the error occurred.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/Event.html b/docs-release/classes/Event.html new file mode 100644 index 0000000..82c8ce6 --- /dev/null +++ b/docs-release/classes/Event.html @@ -0,0 +1,353 @@ + + + + + + Event + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class Event

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+
    +
  • + Event +
  • +
+
+
+

Index

+
+
+
+

Methods

+ +
+
+

Constructors

+ +
+
+

Properties

+ +
+
+
+
+
+

Methods

+
+ +

bind

+ +
    +
  • + +
    +
    +

    Bind the event to the client, when the something event from AdvancedClient will be fire, this event will be also fired.

    +
    +
    +

    Parameters

    +
      +
    • +
      client: AdvancedClient
      +
      +

      The client to bind the event from.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Abstract run

+
    +
  • run(ctx: EventContext<Event>, ...args: [] | undefined[] | [error: Error] | [command: ApplicationCommand<{}>] | [command: ApplicationCommand<{}>] | [oldCommand: null | ApplicationCommand<{}>, newCommand: ApplicationCommand<{}>] | [channel: GuildChannel] | [channel: GuildChannel | DMChannel] | [channel: TextBasedChannels, date: Date] | [oldChannel: GuildChannel | DMChannel, newChannel: GuildChannel | DMChannel] | [message: string] | [message: string] | [emoji: GuildEmoji] | [emoji: GuildEmoji] | [oldEmoji: GuildEmoji, newEmoji: GuildEmoji] | [ban: GuildBan] | [ban: GuildBan] | [guild: Guild] | [guild: Guild] | [guild: Guild] | [guild: Guild] | [member: GuildMember] | [member: GuildMember | PartialGuildMember] | [member: GuildMember | PartialGuildMember] | [members: Collection<string, GuildMember>, guild: Guild, data: { count: number; index: number; nonce: undefined | string }] | [oldMember: GuildMember | PartialGuildMember, newMember: GuildMember] | [oldGuild: Guild, newGuild: Guild] | [invite: Invite] | [invite: Invite] | [message: Message] | [message: Message] | [message: Message | PartialMessage] | [message: Message | PartialMessage] | [reaction: MessageReaction | PartialMessageReaction] | [messages: Collection<string, Message | PartialMessage>] | [reaction: MessageReaction | PartialMessageReaction, user: User | PartialUser] | [reaction: MessageReaction | PartialMessageReaction, user: User | PartialUser] | [oldMessage: Message | PartialMessage, newMessage: Message | PartialMessage] | [oldPresence: null | Presence, newPresence: Presence] | [rateLimitData: RateLimitData] | [invalidRequestWarningData: InvalidRequestWarningData] | [client: Client<true>] | [role: Role] | [role: Role] | [oldRole: Role, newRole: Role] | [thread: ThreadChannel] | [thread: ThreadChannel] | [threads: Collection<string, ThreadChannel>] | [oldMember: ThreadMember, newMember: ThreadMember] | [oldMembers: Collection<string, ThreadMember>, mewMembers: Collection<string, ThreadMember>] | [oldThread: ThreadChannel, newThread: ThreadChannel] | [typing: Typing] | [oldUser: User | PartialUser, newUser: User] | [oldState: VoiceState, newState: VoiceState] | [channel: TextChannel] | [interaction: Interaction] | [interaction: Interaction] | [closeEvent: CloseEvent, shardId: number] | [error: Error, shardId: number] | [shardId: number, unavailableGuilds: Set<string>] | [shardId: number] | [shardId: number, replayedEvents: number] | [stageInstance: StageInstance] | [oldStageInstance: null | StageInstance, newStageInstance: StageInstance] | [stageInstance: StageInstance] | [sticker: Sticker] | [sticker: Sticker] | [oldSticker: Sticker, newSticker: Sticker]): any
  • +
+
    +
  • + +
    +
    +

    The run function, executed when the event is fired.

    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: EventContext<Event>
      +
    • +
    • +
      Rest ...args: [] | undefined[] | [error: Error] | [command: ApplicationCommand<{}>] | [command: ApplicationCommand<{}>] | [oldCommand: null | ApplicationCommand<{}>, newCommand: ApplicationCommand<{}>] | [channel: GuildChannel] | [channel: GuildChannel | DMChannel] | [channel: TextBasedChannels, date: Date] | [oldChannel: GuildChannel | DMChannel, newChannel: GuildChannel | DMChannel] | [message: string] | [message: string] | [emoji: GuildEmoji] | [emoji: GuildEmoji] | [oldEmoji: GuildEmoji, newEmoji: GuildEmoji] | [ban: GuildBan] | [ban: GuildBan] | [guild: Guild] | [guild: Guild] | [guild: Guild] | [guild: Guild] | [member: GuildMember] | [member: GuildMember | PartialGuildMember] | [member: GuildMember | PartialGuildMember] | [members: Collection<string, GuildMember>, guild: Guild, data: { count: number; index: number; nonce: undefined | string }] | [oldMember: GuildMember | PartialGuildMember, newMember: GuildMember] | [oldGuild: Guild, newGuild: Guild] | [invite: Invite] | [invite: Invite] | [message: Message] | [message: Message] | [message: Message | PartialMessage] | [message: Message | PartialMessage] | [reaction: MessageReaction | PartialMessageReaction] | [messages: Collection<string, Message | PartialMessage>] | [reaction: MessageReaction | PartialMessageReaction, user: User | PartialUser] | [reaction: MessageReaction | PartialMessageReaction, user: User | PartialUser] | [oldMessage: Message | PartialMessage, newMessage: Message | PartialMessage] | [oldPresence: null | Presence, newPresence: Presence] | [rateLimitData: RateLimitData] | [invalidRequestWarningData: InvalidRequestWarningData] | [client: Client<true>] | [role: Role] | [role: Role] | [oldRole: Role, newRole: Role] | [thread: ThreadChannel] | [thread: ThreadChannel] | [threads: Collection<string, ThreadChannel>] | [oldMember: ThreadMember, newMember: ThreadMember] | [oldMembers: Collection<string, ThreadMember>, mewMembers: Collection<string, ThreadMember>] | [oldThread: ThreadChannel, newThread: ThreadChannel] | [typing: Typing] | [oldUser: User | PartialUser, newUser: User] | [oldState: VoiceState, newState: VoiceState] | [channel: TextChannel] | [interaction: Interaction] | [interaction: Interaction] | [closeEvent: CloseEvent, shardId: number] | [error: Error, shardId: number] | [shardId: number, unavailableGuilds: Set<string>] | [shardId: number] | [shardId: number, replayedEvents: number] | [stageInstance: StageInstance] | [oldStageInstance: null | StageInstance, newStageInstance: StageInstance] | [stageInstance: StageInstance] | [sticker: Sticker] | [sticker: Sticker] | [oldSticker: Sticker, newSticker: Sticker]
      +
    • +
    +

    Returns any

    +
  • +
+
+
+ +

unbind

+ + +
+
+
+

Constructors

+
+ +

constructor

+ +
    +
  • + +

    Returns Event

    +
  • +
+
+
+
+

Properties

+
+ +

Readonly Abstract name

+
name: "error" | "applicationCommandCreate" | "applicationCommandDelete" | "applicationCommandUpdate" | "channelCreate" | "channelDelete" | "channelPinsUpdate" | "channelUpdate" | "debug" | "warn" | "emojiCreate" | "emojiDelete" | "emojiUpdate" | "guildBanAdd" | "guildBanRemove" | "guildCreate" | "guildDelete" | "guildUnavailable" | "guildIntegrationsUpdate" | "guildMemberAdd" | "guildMemberAvailable" | "guildMemberRemove" | "guildMembersChunk" | "guildMemberUpdate" | "guildUpdate" | "inviteCreate" | "inviteDelete" | "message" | "messageCreate" | "messageDelete" | "messageReactionRemoveAll" | "messageReactionRemoveEmoji" | "messageDeleteBulk" | "messageReactionAdd" | "messageReactionRemove" | "messageUpdate" | "presenceUpdate" | "rateLimit" | "invalidRequestWarning" | "ready" | "invalidated" | "roleCreate" | "roleDelete" | "roleUpdate" | "threadCreate" | "threadDelete" | "threadListSync" | "threadMemberUpdate" | "threadMembersUpdate" | "threadUpdate" | "typingStart" | "userUpdate" | "voiceStateUpdate" | "webhookUpdate" | "interaction" | "interactionCreate" | "shardDisconnect" | "shardError" | "shardReady" | "shardReconnecting" | "shardResume" | "stageInstanceCreate" | "stageInstanceUpdate" | "stageInstanceDelete" | "stickerCreate" | "stickerDelete" | "stickerUpdate"
+ +
+
+

The name of the event.

+
+
+
+
+ +

once

+
once: boolean = false
+ +
+
+

If the event should be fired only once.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/EventContext.html b/docs-release/classes/EventContext.html new file mode 100644 index 0000000..df710e7 --- /dev/null +++ b/docs-release/classes/EventContext.html @@ -0,0 +1,331 @@ + + + + + + EventContext + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class EventContext<E>

+
+
+
+
+
+
+
+

Type parameters

+ +
+
+

Hierarchy

+
    +
  • + EventContext +
  • +
+
+
+

Implements

+
    +
  • EventContextBuilder<E>
  • +
+
+
+

Index

+
+
+
+

Accessors

+ +
+
+

Constructors

+ +
+
+

Properties

+ +
+
+
+
+
+

Accessors

+
+ +

client

+ + +
+
+ +

eventName

+
    +
  • get eventName(): "error" | "applicationCommandCreate" | "applicationCommandDelete" | "applicationCommandUpdate" | "channelCreate" | "channelDelete" | "channelPinsUpdate" | "channelUpdate" | "debug" | "warn" | "emojiCreate" | "emojiDelete" | "emojiUpdate" | "guildBanAdd" | "guildBanRemove" | "guildCreate" | "guildDelete" | "guildUnavailable" | "guildIntegrationsUpdate" | "guildMemberAdd" | "guildMemberAvailable" | "guildMemberRemove" | "guildMembersChunk" | "guildMemberUpdate" | "guildUpdate" | "inviteCreate" | "inviteDelete" | "message" | "messageCreate" | "messageDelete" | "messageReactionRemoveAll" | "messageReactionRemoveEmoji" | "messageDeleteBulk" | "messageReactionAdd" | "messageReactionRemove" | "messageUpdate" | "presenceUpdate" | "rateLimit" | "invalidRequestWarning" | "ready" | "invalidated" | "roleCreate" | "roleDelete" | "roleUpdate" | "threadCreate" | "threadDelete" | "threadListSync" | "threadMemberUpdate" | "threadMembersUpdate" | "threadUpdate" | "typingStart" | "userUpdate" | "voiceStateUpdate" | "webhookUpdate" | "interaction" | "interactionCreate" | "shardDisconnect" | "shardError" | "shardReady" | "shardReconnecting" | "shardResume" | "stageInstanceCreate" | "stageInstanceUpdate" | "stageInstanceDelete" | "stickerCreate" | "stickerDelete" | "stickerUpdate"
  • +
+
    +
  • + +
    +
    +

    Returns the name of the event associated to this EventContext.

    +
    +
    +

    Returns "error" | "applicationCommandCreate" | "applicationCommandDelete" | "applicationCommandUpdate" | "channelCreate" | "channelDelete" | "channelPinsUpdate" | "channelUpdate" | "debug" | "warn" | "emojiCreate" | "emojiDelete" | "emojiUpdate" | "guildBanAdd" | "guildBanRemove" | "guildCreate" | "guildDelete" | "guildUnavailable" | "guildIntegrationsUpdate" | "guildMemberAdd" | "guildMemberAvailable" | "guildMemberRemove" | "guildMembersChunk" | "guildMemberUpdate" | "guildUpdate" | "inviteCreate" | "inviteDelete" | "message" | "messageCreate" | "messageDelete" | "messageReactionRemoveAll" | "messageReactionRemoveEmoji" | "messageDeleteBulk" | "messageReactionAdd" | "messageReactionRemove" | "messageUpdate" | "presenceUpdate" | "rateLimit" | "invalidRequestWarning" | "ready" | "invalidated" | "roleCreate" | "roleDelete" | "roleUpdate" | "threadCreate" | "threadDelete" | "threadListSync" | "threadMemberUpdate" | "threadMembersUpdate" | "threadUpdate" | "typingStart" | "userUpdate" | "voiceStateUpdate" | "webhookUpdate" | "interaction" | "interactionCreate" | "shardDisconnect" | "shardError" | "shardReady" | "shardReconnecting" | "shardResume" | "stageInstanceCreate" | "stageInstanceUpdate" | "stageInstanceDelete" | "stickerCreate" | "stickerDelete" | "stickerUpdate"

    +
  • +
+
+
+
+

Constructors

+
+ +

constructor

+
    +
  • new EventContext<E>(options: EventContextBuilder<E>): EventContext<E>
  • +
+ +
+
+
+

Properties

+
+ +

event

+
event: E
+ +
+
+

The event related to this EventContext.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The CommandHandler.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/ImageCommand.html b/docs-release/classes/ImageCommand.html new file mode 100644 index 0000000..2ce9133 --- /dev/null +++ b/docs-release/classes/ImageCommand.html @@ -0,0 +1,1276 @@ + + + + + + ImageCommand + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class ImageCommand

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+
    +
  • + Command +
      +
    • + ImageCommand +
    • +
    +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional aliases

+
aliases: string[]
+ +
+
+

The aliases of the command.

+
+
+
+
+ +

arguments

+
arguments: Record<string, Argument<any>> = {}
+ +
+
+

The arguments of the command. + You can put your own custom arguments but you must add the type to the argument types.

+
+
+
+
+ +

Optional category

+
category: string
+ +
+
+

The category of the command.

+
+
+
defaultvalue
+

The command parent directory.

+
+
+
+
+
+ +

Optional channels

+
channels: (string | TextChannel)[]
+ +
+
+

The channels where the command should only be executed if used (if using the default message event).

+
+
+
+
+ +

Optional clientPermissions

+
clientPermissions: string[]
+ +
+
+

The client permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+ +

Optional cooldown

+
cooldown: number
+ +
+
+

The cooldown of the command in seconds.

+
+
+
defaultvalue
+

0

+
+
remarks
+

Every cooldown should be saved in CommandHandler.cooldowns.

+
+
+
+
+
+ +

Optional description

+
description: string
+ +
+
+

The description of the command.

+
+
+
+
+ +

Readonly Abstract name

+
name: string
+ +
+
+

The name of the command.

+
+
+
+
+ +

subCommands

+
subCommands: SubCommand[] = []
+ +
+
+

The SubCommands of this command.

+
+
+
remarks
+

Register SubCommands using the {@link Command#registerSubCommands} method.

+
+
+
+
+
+ +

Optional tags

+
tags: string[]
+ +
+
+

The tags of the command.

+
+
+
remarks
+

How tags works ?

+
+
see
+

Tag

+
+
+
+
+
+ +

Optional usage

+
usage: string
+ +
+
+

The usage of the command.

+
+
+
example
+
userinfo
+userinfo me
+userinfo <ID/Username/Mention of User>
+
+
+
remarks
+

If no value is set, in most places it will use the result of the {@link Command#signatures} method.

+
+
+
+
+
+ +

Optional userPermissions

+
userPermissions: string[]
+ +
+
+

The user permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Methods

+
+ +

deleteMessage

+ + +
+
+ +

execute

+ +
    +
  • + +
    +
    +

    Execute the run method, but perform validations before, prefer using this method in your custom Message Event.

    +
    +
    +

    Parameters

    + +

    Returns Promise<undefined | CommandError>

    +
      +
    • An error related to the command if any, for example : a tag not satisfied.
    • +
    +
  • +
+
+
+ +

getCooldown

+
    +
  • getCooldown(from: string | Message | User | GuildMember): Cooldown
  • +
+
    +
  • + +
    +
    +

    Get the actual cooldown of the user for this command plus when command has been executed and how many seconds to wait.

    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      Where to get the cooldown from, can be a user/guild/message, see types.

      +
      +
    • +
    +

    Returns Cooldown

    +
      +
    • The user's cooldown.
    • +
    +
  • +
+
+
+ +

getInvalidPermissions

+
    +
  • getInvalidPermissions(): { client: string[]; user: string[] }
  • +
+ +
+
+ +

getMissingPermissions

+ + +
+
+ +

getMissingTags

+ +
    +
  • + +
    +
    +

    Gives the tags of this command which are not validated by the context.
    + i.e. If a command is executed on a guild and the command has the dmOnly Tag, it will be returned.

    +
    +
    +

    Parameters

    + +

    Returns Tag[]

    +
      +
    • Tags that are not validated by the message.
    • +
    +
  • +
+
+
+ +

isInCooldown

+
    +
  • isInCooldown(from: string | Message | User | GuildMember): boolean
  • +
+
    +
  • + +
    +
    +

    Returns true if the user is in a cooldown for this command.

    +
    +
    +
    remarks
    +

    If cooldown not set, this will always return false.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      From where to test if user/guild/message is in a cooldown, see types.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • Is user in a cooldown.
    • +
    +
  • +
+
+
+ +

isInRightChannel

+ + +
+
+ +

Optional registerSubCommands

+
    +
  • registerSubCommands(): any
  • +
+ +
+
+ +

Abstract run

+ +
    +
  • + +
    +
    +

    The function to run when executing the command.

    +
    +
    +
    remarks
    +

    Use the {@link Command#execute} method if you want to have a validation before executing the run method.

    +
    +
    +
    +

    Parameters

    + +

    Returns any

    +
  • +
+
+
+ +

sendImageEmbed

+ + +
+
+ +

sendLocalImage

+ + +
+
+ +

setCooldown

+
    +
  • setCooldown(from: string | Message | User | GuildMember): void
  • +
+ +
+
+ +

signature

+ +
    +
  • + +
    +
    +

    Get the signature of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument.

    +
    help [command]
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signature of this command or subCommand.
    • +
    +
  • +
+
+
+ +

signatures

+ +
    +
  • + +
    +
    +

    Returns the signature of the command plus the signature of the subCommands of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument and a all subCommand with no arguments.

    +
    help [command]
    +help all
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signatures of the command.
    • +
    +
  • +
+
+
+ +

validate

+ + +
+
+ +

Protected subCommand

+ + +
+
+
+

Accessors

+
+ +

nameAndAliases

+
    +
  • get nameAndAliases(): string[]
  • +
+ +
+
+ +

subCommandsNamesAndAliases

+
    +
  • get subCommandsNamesAndAliases(): string[]
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/Logger.html b/docs-release/classes/Logger.html new file mode 100644 index 0000000..3fff8f0 --- /dev/null +++ b/docs-release/classes/Logger.html @@ -0,0 +1,849 @@ + + + + + + Logger + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class Logger

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+
    +
  • + Logger +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+

Methods

+ +
+
+

Constructors

+ +
+
+
+
+
+

Properties

+
+ +

Static LEVEL

+
LEVEL: LogLevel = ...
+ +
+
+

Let you set the minimum level required for a log to be sent to console.

+ For example if you set the level to LogLevel.LOG, the Logger.debug() and Logger.comments() methods won't log anything.

+
+
+
+
+ +

Static ignores

+
ignores: (string | LoggerIgnore)[] = []
+ +
+
+

Let you ignore Logs by title or by titles and levels.

+
+
+
example
+

// This will ignore any logs with the title 'mylogs'. + Logger.ignores.push('mylogs');

+

// This will ignore any logs with the title 'mylogs', and the level 'LOG' or less. + Logger.ignores.push(['mylogs', LogLevel.LOG]);

+

// It can also work by setting the string version of the LogLevel. + Logger.ignores.push(['mylogs', 'LOG']);

+
+
+
+
+
+ +

Static savingFiles

+
savingFiles: string[] = []
+ +
+
+

The files where the logs are saved.

+
+
+
+
+
+

Methods

+
+ +

Static comment

+
    +
  • comment(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as a comment.

    +
    +
    +
    remarks
    +

    Using the grey color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'comment'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static debug

+
    +
  • debug(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as a debug.

    +
    +
    +
    remarks
    +

    Using the default color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'debug'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static error

+
    +
  • error(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as an error.

    +
    +
    +
    remarks
    +

    Using the red color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'error'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static event

+
    +
  • event(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as an event.

    +
    +
    +
    remarks
    +

    Using the green color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'event'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static info

+
    +
  • info(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as an info.

    +
    +
    +
    remarks
    +

    Using the blue color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'info'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static isIgnored

+
    +
  • isIgnored(title: string, level: LogLevel): boolean
  • +
+
    +
  • + +
    +
    +

    Test if a title and level is ignored.

    +
    +
    +
    internal
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      title: string
      +
      +

      The title of the log.

      +
      +
    • +
    • +
      level: LogLevel
      +
      +

      The level of the log.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • Is it ignored or not.
    • +
    +
  • +
+
+
+ +

Static log

+
    +
  • log(message: any, title?: string, color?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console.

    +
    +
    +
    remarks
    +

    Using the # color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'log'
      +
      +

      The title of the log.

      +
      +
    • +
    • +
      color: string = ...
      +
      +

      The color of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static saveInFile

+
    +
  • saveInFile(path: string): void
  • +
+
    +
  • + +
    +
    +

    Save from now the logs in the file.

    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the file.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static setColor

+
    +
  • setColor(color?: string, text?: string): string
  • +
+
    +
  • + +
    +
    +

    Set the color for the following text.

    +
    +
    +

    Parameters

    +
      +
    • +
      color: string = ...
      +
      +

      The color of the text.

      +
      +
    • +
    • +
      text: string = ''
      +
      +

      The text to colorize.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The text colored, adapted for consoles using escape sequences.
    • +
    +
  • +
+
+
+ +

Static warn

+
    +
  • warn(message: any, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log a message in the console as a warning.

    +
    +
    +
    remarks
    +

    Using the yellow color.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      message: any
      +
      +

      The message to log, can be anything.

      +
      +
    • +
    • +
      title: string = 'warn'
      +
      +

      The title of the log.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static Protected process

+
    +
  • process(text: any, color?: string, title?: string): void
  • +
+
    +
  • + +
    +
    +

    Log something in the console and transform the ColorResolvable into an ASCII Escape Sequence containing the color.

    +
    +
    +
    internal
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      text: any
      +
      +

      The text to log.

      +
      +
    • +
    • +
      color: string = 'debug'
      +
      +

      The color of the text.

      +
      +
    • +
    • +
      title: string = ''
      +
      +

      The title of the text.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

Static Private getColorFromColorResolvable

+
    +
  • getColorFromColorResolvable(color: string): string
  • +
+
    +
  • + +
    +
    +

    Returns a color in hexadecimal without the sharp from a ColorResolvable.

    +
    +
    +
    remarks
    +

    Returns the default color if it cannot be resolved.

    +
    +
    internal
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      color: string
      +
      +

      The ColorResolvable.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The color.
    • +
    +
  • +
+
+
+
+

Constructors

+
+ +

Private constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/SlowCommand.html b/docs-release/classes/SlowCommand.html new file mode 100644 index 0000000..24505b7 --- /dev/null +++ b/docs-release/classes/SlowCommand.html @@ -0,0 +1,1295 @@ + + + + + + SlowCommand + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class SlowCommand

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+
    +
  • + Command +
      +
    • + SlowCommand +
    • +
    +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional aliases

+
aliases: string[]
+ +
+
+

The aliases of the command.

+
+
+
+
+ +

arguments

+
arguments: Record<string, Argument<any>> = {}
+ +
+
+

The arguments of the command. + You can put your own custom arguments but you must add the type to the argument types.

+
+
+
+
+ +

Optional category

+
category: string
+ +
+
+

The category of the command.

+
+
+
defaultvalue
+

The command parent directory.

+
+
+
+
+
+ +

Optional channels

+
channels: (string | TextChannel)[]
+ +
+
+

The channels where the command should only be executed if used (if using the default message event).

+
+
+
+
+ +

Optional clientPermissions

+
clientPermissions: string[]
+ +
+
+

The client permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+ +

Optional cooldown

+
cooldown: number
+ +
+
+

The cooldown of the command in seconds.

+
+
+
defaultvalue
+

0

+
+
remarks
+

Every cooldown should be saved in CommandHandler.cooldowns.

+
+
+
+
+
+ +

Optional description

+
description: string
+ +
+
+

The description of the command.

+
+
+
+
+ +

Readonly Abstract name

+
name: string
+ +
+
+

The name of the command.

+
+
+
+
+ +

subCommands

+
subCommands: SubCommand[] = []
+ +
+
+

The SubCommands of this command.

+
+
+
remarks
+

Register SubCommands using the {@link Command#registerSubCommands} method.

+
+
+
+
+
+ +

Optional tags

+
tags: string[]
+ +
+
+

The tags of the command.

+
+
+
remarks
+

How tags works ?

+
+
see
+

Tag

+
+
+
+
+
+ +

Optional usage

+
usage: string
+ +
+
+

The usage of the command.

+
+
+
example
+
userinfo
+userinfo me
+userinfo <ID/Username/Mention of User>
+
+
+
remarks
+

If no value is set, in most places it will use the result of the {@link Command#signatures} method.

+
+
+
+
+
+ +

Optional userPermissions

+
userPermissions: string[]
+ +
+
+

The user permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+ +

waitEmoji

+
waitEmoji: string = ':hourglass_flowing_sand:'
+ +
+
+

The emoji for waiting.

+
+
+
remarks
+

Feel free to modify the emoji to use a custom one.

+
+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Methods

+
+ +

deleteMessage

+ + +
+
+ +

execute

+ +
    +
  • + +
    +
    +

    Execute the run method, but perform validations before, prefer using this method in your custom Message Event.

    +
    +
    +

    Parameters

    + +

    Returns Promise<undefined | CommandError>

    +
      +
    • An error related to the command if any, for example : a tag not satisfied.
    • +
    +
  • +
+
+
+ +

getCooldown

+
    +
  • getCooldown(from: string | Message | User | GuildMember): Cooldown
  • +
+
    +
  • + +
    +
    +

    Get the actual cooldown of the user for this command plus when command has been executed and how many seconds to wait.

    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      Where to get the cooldown from, can be a user/guild/message, see types.

      +
      +
    • +
    +

    Returns Cooldown

    +
      +
    • The user's cooldown.
    • +
    +
  • +
+
+
+ +

getInvalidPermissions

+
    +
  • getInvalidPermissions(): { client: string[]; user: string[] }
  • +
+ +
+
+ +

getMissingPermissions

+ + +
+
+ +

getMissingTags

+ +
    +
  • + +
    +
    +

    Gives the tags of this command which are not validated by the context.
    + i.e. If a command is executed on a guild and the command has the dmOnly Tag, it will be returned.

    +
    +
    +

    Parameters

    + +

    Returns Tag[]

    +
      +
    • Tags that are not validated by the message.
    • +
    +
  • +
+
+
+ +

isInCooldown

+
    +
  • isInCooldown(from: string | Message | User | GuildMember): boolean
  • +
+
    +
  • + +
    +
    +

    Returns true if the user is in a cooldown for this command.

    +
    +
    +
    remarks
    +

    If cooldown not set, this will always return false.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      From where to test if user/guild/message is in a cooldown, see types.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • Is user in a cooldown.
    • +
    +
  • +
+
+
+ +

isInRightChannel

+ + +
+
+ +

Optional registerSubCommands

+
    +
  • registerSubCommands(): any
  • +
+ +
+
+ +

Abstract run

+ +
    +
  • + +
    +
    +

    The function to run when executing the command.

    +
    +
    +
    remarks
    +

    Use the {@link Command#execute} method if you want to have a validation before executing the run method.

    +
    +
    +
    +

    Parameters

    + +

    Returns any

    +
  • +
+
+
+ +

setCooldown

+
    +
  • setCooldown(from: string | Message | User | GuildMember): void
  • +
+ +
+
+ +

signature

+ +
    +
  • + +
    +
    +

    Get the signature of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument.

    +
    help [command]
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signature of this command or subCommand.
    • +
    +
  • +
+
+
+ +

signatures

+ +
    +
  • + +
    +
    +

    Returns the signature of the command plus the signature of the subCommands of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument and a all subCommand with no arguments.

    +
    help [command]
    +help all
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signatures of the command.
    • +
    +
  • +
+
+
+ +

startWait

+ + +
+
+ +

stopWait

+ + +
+
+ +

validate

+ + +
+
+ +

Protected subCommand

+ + +
+
+
+

Accessors

+
+ +

nameAndAliases

+
    +
  • get nameAndAliases(): string[]
  • +
+ +
+
+ +

subCommandsNamesAndAliases

+
    +
  • get subCommandsNamesAndAliases(): string[]
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/SubCommand.html b/docs-release/classes/SubCommand.html new file mode 100644 index 0000000..12cc3fd --- /dev/null +++ b/docs-release/classes/SubCommand.html @@ -0,0 +1,1259 @@ + + + + + + SubCommand + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class SubCommand

+
+
+
+
+
+
+
+
+
+
see
+

https://ayfri.gitbook.io/advanced-command-handler/concepts/commands/subcommands

+
+
remarks
+

This class is not in the SubCommand file because otherwise it won't compile because of circular because of the Command.subCommands property.

+
+
+
+
+
+

Hierarchy

+
    +
  • + Command +
      +
    • + SubCommand +
    • +
    +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional aliases

+
aliases: string[]
+ +
+
+

The aliases of the command.

+
+
+
+
+ +

arguments

+
arguments: Record<string, Argument<any>> = {}
+ +
+
+

The arguments of the command. + You can put your own custom arguments but you must add the type to the argument types.

+
+
+
+
+ +

Optional category

+
category: string
+ +
+
+

The category of the command.

+
+
+
defaultvalue
+

The command parent directory.

+
+
+
+
+
+ +

Optional channels

+
channels: (string | TextChannel)[]
+ +
+
+

The channels where the command should only be executed if used (if using the default message event).

+
+
+
+
+ +

Optional clientPermissions

+
clientPermissions: string[]
+ +
+
+

The client permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+ +

Optional cooldown

+
cooldown: number
+ +
+
+

The cooldown of the command in seconds.

+
+
+
defaultvalue
+

0

+
+
remarks
+

Every cooldown should be saved in CommandHandler.cooldowns.

+
+
+
+
+
+ +

Optional description

+
description: string
+ +
+
+

The description of the command.

+
+
+
+
+ +

Readonly name

+
name: string
+ +
+
+

The name of the SubCommand.

+
+
+
+
+ +

Readonly runFunction

+ + +
+
+

The function executed when the SubCommand is executed.

+
+
+
+
+ +

subCommands

+
subCommands: SubCommand[] = []
+ +
+
+

The SubCommands of this command.

+
+
+
remarks
+

Register SubCommands using the {@link Command#registerSubCommands} method.

+
+
+
+
+
+ +

Optional tags

+
tags: string[]
+ +
+
+

The tags of the command.

+
+
+
remarks
+

How tags works ?

+
+
see
+

Tag

+
+
+
+
+
+ +

Optional usage

+
usage: string
+ +
+
+

The usage of the command.

+
+
+
example
+
userinfo
+userinfo me
+userinfo <ID/Username/Mention of User>
+
+
+
remarks
+

If no value is set, in most places it will use the result of the {@link Command#signatures} method.

+
+
+
+
+
+ +

Optional userPermissions

+
userPermissions: string[]
+ +
+
+

The user permissions needed to run the command (if using the default message event).

+
+
+
defaultvalue
+

['SEND_MESSAGES']

+
+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+

Methods

+
+ +

deleteMessage

+ + +
+
+ +

execute

+ +
    +
  • + +
    +
    +

    Execute the run method, but perform validations before, prefer using this method in your custom Message Event.

    +
    +
    +

    Parameters

    + +

    Returns Promise<undefined | CommandError>

    +
      +
    • An error related to the command if any, for example : a tag not satisfied.
    • +
    +
  • +
+
+
+ +

getCooldown

+
    +
  • getCooldown(from: string | Message | User | GuildMember): Cooldown
  • +
+
    +
  • + +
    +
    +

    Get the actual cooldown of the user for this command plus when command has been executed and how many seconds to wait.

    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      Where to get the cooldown from, can be a user/guild/message, see types.

      +
      +
    • +
    +

    Returns Cooldown

    +
      +
    • The user's cooldown.
    • +
    +
  • +
+
+
+ +

getInvalidPermissions

+
    +
  • getInvalidPermissions(): { client: string[]; user: string[] }
  • +
+ +
+
+ +

getMissingPermissions

+ + +
+
+ +

getMissingTags

+ +
    +
  • + +
    +
    +

    Gives the tags of this command which are not validated by the context.
    + i.e. If a command is executed on a guild and the command has the dmOnly Tag, it will be returned.

    +
    +
    +

    Parameters

    + +

    Returns Tag[]

    +
      +
    • Tags that are not validated by the message.
    • +
    +
  • +
+
+
+ +

isInCooldown

+
    +
  • isInCooldown(from: string | Message | User | GuildMember): boolean
  • +
+
    +
  • + +
    +
    +

    Returns true if the user is in a cooldown for this command.

    +
    +
    +
    remarks
    +

    If cooldown not set, this will always return false.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      from: string | Message | User | GuildMember
      +
      +

      From where to test if user/guild/message is in a cooldown, see types.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • Is user in a cooldown.
    • +
    +
  • +
+
+
+ +

isInRightChannel

+ + +
+
+ +

Optional registerSubCommands

+
    +
  • registerSubCommands(): any
  • +
+ +
+
+ +

run

+ + +
+
+ +

setCooldown

+
    +
  • setCooldown(from: string | Message | User | GuildMember): void
  • +
+ +
+
+ +

signature

+ +
    +
  • + +
    +
    +

    Get the signature of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument.

    +
    help [command]
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signature of this command or subCommand.
    • +
    +
  • +
+
+
+ +

signatures

+ +
    +
  • + +
    +
    +

    Returns the signature of the command plus the signature of the subCommands of this command.

    +
    +
    +
    example
    +

    // The help command with an optional command commandArgument argument and a all subCommand with no arguments.

    +
    help [command]
    +help all
    +
    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Optional options: CommandSignatureOptions
      +
      +

      The options for the signature, show the type of the arguments or the default values.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The signatures of the command.
    • +
    +
  • +
+
+
+ +

validate

+ + +
+
+ +

Protected subCommand

+ + +
+
+
+

Accessors

+
+ +

nameAndAliases

+
    +
  • get nameAndAliases(): string[]
  • +
+ +
+
+ +

subCommandsNamesAndAliases

+
    +
  • get subCommandsNamesAndAliases(): string[]
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/classes/SubCommandContext.html b/docs-release/classes/SubCommandContext.html new file mode 100644 index 0000000..36ce96d --- /dev/null +++ b/docs-release/classes/SubCommandContext.html @@ -0,0 +1,1416 @@ + + + + + + SubCommandContext + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Class SubCommandContext

+
+
+
+
+
+
+
+ +
+
+

Hierarchy

+ +
+
+

Index

+
+ +
+
+
+

Accessors

+
+ +

args

+
    +
  • get args(): string[]
  • +
+ +
+
+ +

argsString

+
    +
  • get argsString(): string
  • +
+ +
+
+ +

arguments

+ + +
+
+ +

channel

+
    +
  • get channel(): TextBasedChannels
  • +
+ +
+
+ +

client

+ + +
+
+ +

commandName

+
    +
  • get commandName(): string
  • +
+ +
+
+ +

content

+
    +
  • get content(): string
  • +
+ +
+
+ +

guild

+
    +
  • get guild(): null | Guild
  • +
+ +
+
+ +

isCallingASubCommand

+
    +
  • get isCallingASubCommand(): boolean
  • +
+ +
+
+ +

member

+
    +
  • get member(): null | GuildMember
  • +
+ +
+
+ +

prefix

+
    +
  • get prefix(): string
  • +
+ +
+
+ +

subCommandName

+
    +
  • get subCommandName(): string
  • +
+ +
+
+ +

textChannel

+
    +
  • get textChannel(): undefined | TextChannel | NewsChannel
  • +
+ +
+
+ +

thread

+
    +
  • get thread(): undefined | ThreadChannel
  • +
+ +
+
+ +

user

+
    +
  • get user(): User
  • +
+ +
+
+
+

Methods

+
+ +

argument

+
    +
  • argument<T>(name: string): Promise<null | T>
  • +
+
    +
  • + +
    +
    +

    Returns an argument. + If the argument is errored or not found it will return null.

    +
    +
    +

    Type parameters

    +
      +
    • +

      T

      +
      +

      The type of the argument.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The name of the argument.

      +
      +
    • +
    +

    Returns Promise<null | T>

    +
      +
    • The argument in a promise or null if the argument is not found or errored or the command has no arguments.
    • +
    +
  • +
+
+
+ +

bulkDeleteInChannel

+
    +
  • bulkDeleteInChannel(number: number, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: Collection<string, Message>, filterOld?: boolean): Promise<Collection<string, Message>>
  • +
  • bulkDeleteInChannel(number: readonly MessageResolvable[], filterOld?: boolean): Promise<Collection<string, Message>>
  • +
+ +
+
+ +

createThread

+
    +
  • createThread(options: StartThreadOptions): undefined | Promise<ThreadChannel>
  • +
+ +
+
+ +

deleteMessage

+
    +
  • deleteMessage(timeout?: number): Promise<Message>
  • +
+ +
+
+ +

react

+
    +
  • react(...emoji: EmojiIdentifierResolvable[]): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Add one or multiple reactions to a message.

    +
    +
    +
    remarks
    +

    React in the order of emoji used.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      Rest ...emoji: EmojiIdentifierResolvable[]
      +
      +

      The emoji to react with, can be custom or native.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

removeAllReactions

+
    +
  • removeAllReactions(): Promise<void>
  • +
+ +
+
+ +

removeReaction

+
    +
  • removeReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+ +
+
+ +

removeSelfReaction

+
    +
  • removeSelfReaction(...emojis: EmojiIdentifierResolvable[]): Promise<void>
  • +
+ +
+
+ +

reply

+
    +
  • reply(options: ReplyOptions): Promise<Message>
  • +
  • reply(content: string): Promise<Message>
  • +
  • reply(content: string, options: ReplyOptions): Promise<Message>
  • +
+ +
+
+ +

resolveArgument

+ + +
+
+ +

resolveArguments

+
    +
  • resolveArguments<A>(): Promise<undefined | Map<string, ArgumentResolved<A[number]>>>
  • +
+ +
+
+ +

send

+
    +
  • send(options: SendOptions): Promise<Message>
  • +
  • send(content: string): Promise<Message>
  • +
  • send(content: string, options: SendOptions): Promise<Message>
  • +
+ +
+
+ +

sendGlobalHelpMessage

+
    +
  • sendGlobalHelpMessage(): Promise<Message>
  • +
+ +
+
+ +

sendHelpMessage

+
    +
  • sendHelpMessage(commandName?: string): Promise<undefined | Message>
  • +
+
    +
  • + +
    +
    +

    Sends the help menu of the command from the default HelpCommand command (even if you are not using it).

    +
    +
    +

    Parameters

    +
      +
    • +
      commandName: string = ...
      +
      +

      The name of the command to send the help menu.

      +
      +
    • +
    +

    Returns Promise<undefined | Message>

    +
      +
    • The message of the help menu of the command.
    • +
    +
  • +
+
+
+
+

Properties

+
+ +

Optional argumentParser

+
argumentParser: ArgumentParser
+ +
+
+

The argument parser of this context, if the command has no arguments it will be undefined.

+
+
+
+
+ +

command

+
command: Command
+ +
+
+

The command itself.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The handler.

+
+
+
+
+ +

message

+
message: Message
+ +
+
+

The message that executed the command.

+
+
+
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+

The arguments in the message.

+
+
+
+
+ +

subCommand

+
subCommand: SubCommand
+ +
+
+

The SubCommand related to this SubcommandContext.

+
+
+
+
+
+

Constructors

+
+ +

constructor

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/enums/ArgumentType.html b/docs-release/enums/ArgumentType.html new file mode 100644 index 0000000..0dda1a5 --- /dev/null +++ b/docs-release/enums/ArgumentType.html @@ -0,0 +1,431 @@ + + + + + + ArgumentType + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Enumeration ArgumentType

+
+
+
+
+
+
+
+
+
+

The arguments types. + You can add your own if you want to add arguments types.

+
+
+
+
+

Index

+
+
+
+

Enumeration members

+ +
+
+
+
+
+

Enumeration members

+
+ +

BOOLEAN

+
BOOLEAN: = "boolean"
+ +
+
+ +

CHANNEL

+
CHANNEL: = "channel"
+ +
+
+ +

CHOICE

+
CHOICE: = "choice"
+ +
+
+ +

COMMAND

+
COMMAND: = "command"
+ +
+
+ +

EMOJI

+
EMOJI: = "emoji"
+ +
+
+ +

ENUM

+
ENUM: = "enum"
+ +
+
+ +

EVENT

+
EVENT: = "event"
+ +
+
+ +

FLOAT

+
FLOAT: = "float"
+ +
+
+ +

GUILD

+
GUILD: = "guild"
+ +
+
+ +

GUILD_MEMBER

+
GUILD_MEMBER: = "guild_member"
+ +
+
+ +

INTEGER

+
INTEGER: = "integer"
+ +
+
+ +

MESSAGE

+
MESSAGE: = "message"
+ +
+
+ +

REGEX

+
REGEX: = "regex"
+ +
+
+ +

ROLE

+
ROLE: = "role"
+ +
+
+ +

SNOWFLAKE

+
SNOWFLAKE: = "snowflake"
+ +
+
+ +

STRING

+
STRING: = "string"
+ +
+
+ +

TEXT_CHANNEL

+
TEXT_CHANNEL: = "text_channel"
+ +
+
+ +

USER

+
USER: = "user"
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/enums/CommandErrorType.html b/docs-release/enums/CommandErrorType.html new file mode 100644 index 0000000..5259505 --- /dev/null +++ b/docs-release/enums/CommandErrorType.html @@ -0,0 +1,273 @@ + + + + + + CommandErrorType + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Enumeration CommandErrorType

+
+
+
+
+
+
+
+

Index

+
+ +
+
+
+

Enumeration members

+
+ +

ARGUMENT_NOT_FOUND

+
ARGUMENT_NOT_FOUND: = 0
+ +
+
+ +

CLIENT_MISSING_PERMISSIONS

+
CLIENT_MISSING_PERMISSIONS: = 1
+ +
+
+ +

COOLDOWN

+
COOLDOWN: = 2
+ +
+
+ +

ERROR

+
ERROR: = 3
+ +
+
+ +

INVALID_ARGUMENT

+
INVALID_ARGUMENT: = 4
+ +
+
+ +

MISSING_TAGS

+
MISSING_TAGS: = 5
+ +
+
+ +

USER_MISSING_PERMISSIONS

+
USER_MISSING_PERMISSIONS: = 6
+ +
+
+ +

WRONG_CHANNEL

+
WRONG_CHANNEL: = 7
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/enums/DataType.html b/docs-release/enums/DataType.html new file mode 100644 index 0000000..fee66e2 --- /dev/null +++ b/docs-release/enums/DataType.html @@ -0,0 +1,288 @@ + + + + + + DataType + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Enumeration DataType

+
+
+
+
+
+
+
+

Index

+
+
+
+

Enumeration members

+ +
+
+
+
+
+

Enumeration members

+
+ +

CHANNEL

+
CHANNEL: = "channel"
+ +
+
+ +

COMMAND

+
COMMAND: = "command"
+ +
+
+ +

EMOTE

+
EMOTE: = "emote"
+ +
+
+ +

GUILD

+
GUILD: = "guild"
+ +
+
+ +

MEMBER

+
MEMBER: = "member"
+ +
+
+ +

MESSAGE

+
MESSAGE: = "message"
+ +
+
+ +

ROLE

+
ROLE: = "role"
+ +
+
+ +

TEXT_CHANNEL

+
TEXT_CHANNEL: = "text_channel"
+ +
+
+ +

USER

+
USER: = "user"
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/enums/LogLevel.html b/docs-release/enums/LogLevel.html new file mode 100644 index 0000000..f15095f --- /dev/null +++ b/docs-release/enums/LogLevel.html @@ -0,0 +1,288 @@ + + + + + + LogLevel + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Enumeration LogLevel

+
+
+
+
+
+
+
+

Index

+
+
+
+

Enumeration members

+ +
+
+
+
+
+

Enumeration members

+
+ +

ALL

+
ALL: = 7
+ +
+
+ +

COMMENT

+
COMMENT: = 7
+ +
+
+ +

DEBUG

+
DEBUG: = 6
+ +
+
+ +

ERROR

+
ERROR: = 1
+ +
+
+ +

EVENT

+
EVENT: = 4
+ +
+
+ +

INFO

+
INFO: = 3
+ +
+
+ +

LOG

+
LOG: = 5
+ +
+
+ +

OFF

+
OFF: = 0
+ +
+
+ +

WARNING

+
WARNING: = 2
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/enums/Tag.html b/docs-release/enums/Tag.html new file mode 100644 index 0000000..2475912 --- /dev/null +++ b/docs-release/enums/Tag.html @@ -0,0 +1,316 @@ + + + + + + Tag + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Enumeration Tag

+
+
+
+
+
+
+
+
+ +

When using commands, you want certain commands to only run on a server or in private messages etc.
+ Most other CommandHandlers uses boolean properties like guildOnly.
+ To avoid having a ton of these, I imagined a system where you have command tags and for every call, tags of the command are verified one by one.
+ And this system works very smoothly !
+ So if you're using the default message event + (see how to use defaults events), tags will be checked.

+
+
example
+
if (command.tags.includes(Tag.guildOnly) && !message.guild) {
+    message.channel.send(`You must be on a guild to execute the ${command.name} command !`);
+}
+
+
+
+
+
+
+

Index

+
+
+
+

Enumeration members

+ +
+
+
+
+
+

Enumeration members

+
+ +

channelOnly

+
channelOnly: = "channelOnly"
+ +
+
+

Tag for commands to not run in a thread.

+
+
+
+
+ +

dmOnly

+
dmOnly: = "dmOnly"
+ +
+
+

Tag for commands to only run in private messages.

+
+
+
+
+ +

guildOnly

+
guildOnly: = "guildOnly"
+ +
+
+

Tag for commands to only run on a guild.

+
+
+
+
+ +

guildOwnerOnly

+
guildOwnerOnly: = "guildOwnerOnly"
+ +
+
+

Tag for commands to only run on a guild and if the author is the owner of the guild.

+
+
+
+
+ +

nsfw

+
nsfw: = "nsfw"
+ +
+
+

Tag for commands to only run on a guild and in an NSFW channel.

+
+
+
+
+ +

ownerOnly

+
ownerOnly: = "ownerOnly"
+ +
+
+

Tag for commands to only run if author is an owner defined in CommandHandler.owners.

+
+
+
+
+ +

threadOnly

+
threadOnly: = "threadOnly"
+ +
+
+

Tag for commands to only run in a thread.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/index.html b/docs-release/index.html new file mode 100644 index 0000000..c253b04 --- /dev/null +++ b/docs-release/index.html @@ -0,0 +1,415 @@ + + + + + + Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+

Advanced Command-Handler - v3.0.0

+
+
+
+
+
+
+
+ +

Advanced Command Handler

+
+

npm + npm + GitHub issues + GitHub last commit (branch)

+

npm install

+

This is an Advanced Command Handler for Discord Bots, which uses classes for commands & events. You have a plethora of utils like functions that everyone uses, functions for errors, functions for + tedious things that everyone needs for a Discord Bot, and some classes to simplify Logging things and manipulating embeds.

+

Version 3.0 uses Discord.js v12, wait for 3.1 to use Discord.js v13.

+

This library is here to simplify a lot developing Discord Bots and is far from being finished with every feature I want to add.
+ So feel free to watch this repo for futures releases! + For now, it offers :

+
    +
  • Command Handling
  • +
  • SubCommand Handling
  • +
  • Event Handling
  • +
  • Default message event & help command
  • +
  • A complete Logger
  • +
  • Some utilities function for errors, jsons and other
  • +
+

For more information on how to use it, see the Guide and the Documentation :

+ +

You can also see some examples that I've made here.
+ Feel free to PR to these to update these and add features that this handler can offer!

+ +

That's all for now :)

+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/ArgumentOptions.html b/docs-release/interfaces/ArgumentOptions.html new file mode 100644 index 0000000..2dcb769 --- /dev/null +++ b/docs-release/interfaces/ArgumentOptions.html @@ -0,0 +1,229 @@ + + + + + + ArgumentOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface ArgumentOptions<T>

+
+
+
+
+
+
+
+

Type parameters

+
    +
  • +

    T

    +
  • +
+
+
+

Hierarchy

+
    +
  • + ArgumentOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

Optional coalescing

+
coalescing: boolean
+ +
+
+ +

Optional defaultValue

+
defaultValue: T
+ +
+
+ +

Optional description

+
description: string
+ +
+
+ +

Optional optional

+
optional: boolean
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandContextBuilder.html b/docs-release/interfaces/CommandContextBuilder.html new file mode 100644 index 0000000..48c9ae3 --- /dev/null +++ b/docs-release/interfaces/CommandContextBuilder.html @@ -0,0 +1,259 @@ + + + + + + CommandContextBuilder + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface CommandContextBuilder

+
+
+
+
+
+
+
+
+
+

The interface to create a new CommandContext.

+
+
+
+
+

Hierarchy

+ +
+
+

Implemented by

+ +
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

command

+
command: Command
+ +
+
+

The command.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The handler.

+
+
+
+
+ +

message

+
message: Message
+ +
+
+

The message that executed the command.

+
+
+
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+

The arguments in the message.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandErrorBuilder.html b/docs-release/interfaces/CommandErrorBuilder.html new file mode 100644 index 0000000..048165e --- /dev/null +++ b/docs-release/interfaces/CommandErrorBuilder.html @@ -0,0 +1,233 @@ + + + + + + CommandErrorBuilder + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface CommandErrorBuilder

+
+
+
+
+
+
+
+
+
+

The object to create a new CommandError.

+
+
+
+
+

Hierarchy

+
    +
  • + CommandErrorBuilder +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

Optional data

+
data: any
+ +
+
+

The data of the error, can be anything but should be related to the error type.

+
+
+
see
+

CommandErrorBuilder#type.

+
+
+
+
+
+ +

message

+
message: string
+ +
+
+

The message of the error, to inform what is the problem.

+
+
+
+
+ +

type

+ + +
+
+

The type of error.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandHandler.CommandCooldown.html b/docs-release/interfaces/CommandHandler.CommandCooldown.html new file mode 100644 index 0000000..a0de059 --- /dev/null +++ b/docs-release/interfaces/CommandHandler.CommandCooldown.html @@ -0,0 +1,322 @@ + + + + + + CommandCooldown + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface CommandCooldown

+
+
+
+
+
+
+
+
+
+
internal
+
+
+
+
+
+

Hierarchy

+
    +
  • + CommandCooldown + +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

cooldown

+
cooldown: number
+ +
+
+

The actual cooldown of the Command.

+
+
+
+
+ +

executedAt

+
executedAt: Date
+ +
+
+

The date the cooldown has started.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandHandler.CreateCommandHandlerOptions.html b/docs-release/interfaces/CommandHandler.CreateCommandHandlerOptions.html new file mode 100644 index 0000000..47b5844 --- /dev/null +++ b/docs-release/interfaces/CommandHandler.CreateCommandHandlerOptions.html @@ -0,0 +1,406 @@ + + + + + + CreateCommandHandlerOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface CreateCommandHandlerOptions

+
+
+
+
+
+
+
+
+
+

The options for creating a new CommandHandler instance.

+
+
+
+
+

Hierarchy

+
    +
  • + CreateCommandHandlerOptions +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

commandsDir

+
commandsDir: string
+ +
+
+

The directory of your commands.

+
+
+
+
+ +

eventsDir

+
eventsDir: string
+ +
+
+

The directory of your events.

+
+
+
+
+ +

Optional owners

+
owners: string[]
+ +
+
+

The owners IDs from discord of the bot.

+
+
+
+
+ +

Optional prefixes

+
prefixes: string[]
+ +
+
+

The prefixes for the CommandHandler.

+
+
+
+
+ +

Optional saveLogsInFile

+
saveLogsInFile: string[]
+ +
+
+

Save all the logs in these files.

+
+
+
remarks
+

If one of the files is not found, it will create it.

+
+
+
+
+
+ +

Optional useMentionAsPrefix

+
useMentionAsPrefix: boolean
+ +
+
+

Add mention of the bot as prefixes.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandHandler.HelpOptions.html b/docs-release/interfaces/CommandHandler.HelpOptions.html new file mode 100644 index 0000000..bb01412 --- /dev/null +++ b/docs-release/interfaces/CommandHandler.HelpOptions.html @@ -0,0 +1,337 @@ + + + + + + HelpOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface HelpOptions

+
+
+
+
+
+
+
+
+
+

The options for the default {@link HelpCommand | help} command.

+
+
+
+
+

Hierarchy

+
    +
  • + HelpOptions +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional deleteMessageAfterDelay

+
deleteMessageAfterDelay: number
+ +
+
+

Delete the help message after the delay, in seconds.

+
+
+
+
+ +

Optional globalMenuExcludeCommands

+
globalMenuExcludeCommands: string[]
+ +
+
+

Exclude commands to the global help menu, exclude by name or alias.

+
+
+
+
+ +

Optional globalMenuUseList

+
globalMenuUseList: boolean
+ +
+
+

Use a list of commands instead of a list categories. + Will only work for 25 commands max and throw an error if you use it with more commands.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandHandler.LaunchCommandHandlerOptions.html b/docs-release/interfaces/CommandHandler.LaunchCommandHandlerOptions.html new file mode 100644 index 0000000..d1fd3f7 --- /dev/null +++ b/docs-release/interfaces/CommandHandler.LaunchCommandHandlerOptions.html @@ -0,0 +1,441 @@ + + + + + + LaunchCommandHandlerOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface LaunchCommandHandlerOptions

+
+
+
+
+
+
+
+
+
+

Options for launching the CommandHandler.

+
+
+
+
+

Hierarchy

+
    +
  • + LaunchCommandHandlerOptions +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional addBotAndTeamOwnersToOwners

+
addBotAndTeamOwnersToOwners: boolean
+ +
+
+

Whether to add the bot owner or the team members (if bot is from a team) to the owners.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+ +

clientOptions

+
clientOptions: ClientOptions
+ +
+
+

The client options, see ClientOptions.

+
+
+
+
+ +

Optional cycleBetweenPresences

+
cycleBetweenPresences: boolean
+ +
+
+

If set to true, it will cycle between the presences.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+ +

Optional cycleDuration

+
cycleDuration: number
+ +
+
+

The duration in seconds between the cycle of two presences of presences.

+
+
+
defaultvalue
+

60

+
+
+
+
+
+ +

Optional presence

+
presence: PresenceData
+ +
+
+

The presence of your bot when launched.

+
+
+
remarks
+

If presences is also set, it will overcome this property.

+
+
+
+
+
+ +

Optional presences

+
presences: PresenceData[]
+ +
+
+

The presences of your bot, if this field is used it will cycle between all if cycleBetweenPresences options is set to true.

+
+
+
remarks
+

If presence is also set, it will still cycle between presences.

+
+
+
+
+
+ +

token

+
token: string
+ +
+
+

The token of your bot.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandHandler.MessageCreateOptions.html b/docs-release/interfaces/CommandHandler.MessageCreateOptions.html new file mode 100644 index 0000000..eaab820 --- /dev/null +++ b/docs-release/interfaces/CommandHandler.MessageCreateOptions.html @@ -0,0 +1,391 @@ + + + + + + MessageCreateOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface MessageCreateOptions

+
+
+
+
+
+
+
+
+
+

The options for the default {@link MessageCreateEvent | messageCreate} event.

+
+
+
+
+

Hierarchy

+
    +
  • + MessageCreateOptions +
  • +
+
+
+

Index

+
+ +
+
+
+

Properties

+
+ +

Optional excludeBots

+
excludeBots: boolean
+ +
+
+

Exclude bot or not.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+ +

Optional globalTags

+
globalTags: string[]
+ +
+
+

A list of global tags to apply before the commands is executed.

+
+
+
+
+ +

Optional sendCodeError

+
sendCodeError: boolean
+ +
+
+

Send the code error when a command execution is failed and an error is thrown.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+ +

Optional sendCodeErrorOnlyToOwners

+
sendCodeErrorOnlyToOwners: boolean
+ +
+
+

Send the code error only to owners when a command execution is failed and an error is thrown.

+
+
+
defaultvalue
+

true

+
+
+
+
+
+ +

Optional sendWhenError

+
sendWhenError: string | MessageEmbed
+ +
+
+

A message to send to anyone (or not-owners if sendCodeErrorOnlyToOwners is set) when a command execution is failed and an error is thrown.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/CommandSignatureOptions.html b/docs-release/interfaces/CommandSignatureOptions.html new file mode 100644 index 0000000..9b38940 --- /dev/null +++ b/docs-release/interfaces/CommandSignatureOptions.html @@ -0,0 +1,191 @@ + + + + + + CommandSignatureOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface CommandSignatureOptions

+
+
+
+
+
+
+
+

Hierarchy

+
    +
  • + CommandSignatureOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

Optional showDefaultValues

+
showDefaultValues: boolean
+ +
+
+ +

Optional showTypes

+
showTypes: boolean
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/Cooldown.html b/docs-release/interfaces/Cooldown.html new file mode 100644 index 0000000..4c22aad --- /dev/null +++ b/docs-release/interfaces/Cooldown.html @@ -0,0 +1,235 @@ + + + + + + Cooldown + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface Cooldown

+
+
+
+
+
+
+
+
+
+

The cooldown object.

+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

cooldown

+
cooldown: number
+ +
+
+

The actual cooldown of the Command.

+
+
+
+
+ +

executedAt

+
executedAt: Date
+ +
+
+

The date the cooldown has started.

+
+
+
+
+ +

waitMore

+
waitMore: number
+ +
+
+

The time to wait, in seconds & milliseconds.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/DeleteMessageOptions.html b/docs-release/interfaces/DeleteMessageOptions.html new file mode 100644 index 0000000..33556b1 --- /dev/null +++ b/docs-release/interfaces/DeleteMessageOptions.html @@ -0,0 +1,208 @@ + + + + + + DeleteMessageOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface DeleteMessageOptions

+
+
+
+
+
+
+
+
+
+

Options for the Command#deleteMessage method.

+
+
+
+
+

Hierarchy

+
    +
  • + DeleteMessageOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

message

+
message: Message
+ +
+
+

The message to delete.

+
+
+
+
+ +

Optional timeout

+
timeout: number
+ +
+
+

How long to wait to delete the message in milliseconds.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/ImageEmbedContextOptions.html b/docs-release/interfaces/ImageEmbedContextOptions.html new file mode 100644 index 0000000..2fc6bd6 --- /dev/null +++ b/docs-release/interfaces/ImageEmbedContextOptions.html @@ -0,0 +1,277 @@ + + + + + + ImageEmbedContextOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface ImageEmbedContextOptions

+
+
+
+
+
+
+
+
+
+

The options for setting an image in an embed to send in a context.

+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

ctx

+ + +
+
+

The context where to send the image.

+
+
+
+
+ +

description

+
description: string
+ +
+
+

Description of the embed.

+
+
+
+
+ +

Optional link

+
link: string
+ +
+
+

Link of the image.

+
+
+
+
+ +

Optional path

+
path: string
+ +
+
+

Local path of the image.

+
+
+
+
+ +

title

+
title: string
+ +
+
+

Title of the embed.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/ImageEmbedOptions.html b/docs-release/interfaces/ImageEmbedOptions.html new file mode 100644 index 0000000..0b8a2ed --- /dev/null +++ b/docs-release/interfaces/ImageEmbedOptions.html @@ -0,0 +1,268 @@ + + + + + + ImageEmbedOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface ImageEmbedOptions

+
+
+
+
+
+
+
+
+
+

The options for setting an image in an embed.

+
+
+
+
+

Hierarchy

+
    +
  • + ImageEmbedOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

channel

+
channel: TextBasedChannels
+ +
+
+

Channel where to send the image.

+
+
+
+
+ +

description

+
description: string
+ +
+
+

Description of the embed.

+
+
+
+
+ +

Optional link

+
link: string
+ +
+
+

Link of the image.

+
+
+
+
+ +

Optional path

+
path: string
+ +
+
+

Local path of the image.

+
+
+
+
+ +

title

+
title: string
+ +
+
+

Title of the embed.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/ImageLocalContextOptions.html b/docs-release/interfaces/ImageLocalContextOptions.html new file mode 100644 index 0000000..762207d --- /dev/null +++ b/docs-release/interfaces/ImageLocalContextOptions.html @@ -0,0 +1,235 @@ + + + + + + ImageLocalContextOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface ImageLocalContextOptions

+
+
+
+
+
+
+
+
+
+

The options for setting a local image in a message from a context.

+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

content

+
content: string
+ +
+
+

Content of the message.

+
+
+
+
+ +

ctx

+ + +
+
+

The context where to send the image.

+
+
+
+
+ +

path

+
path: string
+ +
+
+

Local path of the image.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/ImageLocalOptions.html b/docs-release/interfaces/ImageLocalOptions.html new file mode 100644 index 0000000..cb729dd --- /dev/null +++ b/docs-release/interfaces/ImageLocalOptions.html @@ -0,0 +1,228 @@ + + + + + + ImageLocalOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface ImageLocalOptions

+
+
+
+
+
+
+
+
+
+

The options for setting a local image in a message.

+
+
+
+
+

Hierarchy

+
    +
  • + ImageLocalOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

channel

+
channel: TextBasedChannels
+ +
+
+

Channel where to send the image.

+
+
+
+
+ +

content

+
content: string
+ +
+
+

Content of the message.

+
+
+
+
+ +

path

+
path: string
+ +
+
+

Local path of the image.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/MissingPermissions.html b/docs-release/interfaces/MissingPermissions.html new file mode 100644 index 0000000..ad8bcfa --- /dev/null +++ b/docs-release/interfaces/MissingPermissions.html @@ -0,0 +1,208 @@ + + + + + + MissingPermissions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface MissingPermissions

+
+
+
+
+
+
+
+
+
+

The object for missing permissions.

+
+
+
+
+

Hierarchy

+
    +
  • + MissingPermissions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

client

+
client: PermissionString[]
+ +
+
+

Missing permissions of the client.

+
+
+
+
+ +

user

+
user: PermissionString[]
+ +
+
+

Missing permissions of the user.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/SubCommandContextBuilder.html b/docs-release/interfaces/SubCommandContextBuilder.html new file mode 100644 index 0000000..e25f24e --- /dev/null +++ b/docs-release/interfaces/SubCommandContextBuilder.html @@ -0,0 +1,277 @@ + + + + + + SubCommandContextBuilder + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface SubCommandContextBuilder

+
+
+
+
+
+
+
+
+
+

The object to create a new SubCommandContext.

+
+
+
+
+

Hierarchy

+ +
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

command

+
command: Command
+ +
+
+

The command.

+
+
+
+
+ +

handler

+
handler: typeof CommandHandler
+ +
+
+

The handler.

+
+
+
+
+ +

message

+
message: Message
+ +
+
+

The message that executed the command.

+
+
+
+
+ +

rawArgs

+
rawArgs: string[]
+ +
+
+

The arguments in the message.

+
+
+
+
+ +

subCommand

+
subCommand: SubCommand
+ +
+
+

The SubCommand related to this SubcommandContext.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/interfaces/SubCommandOptions.html b/docs-release/interfaces/SubCommandOptions.html new file mode 100644 index 0000000..9de6209 --- /dev/null +++ b/docs-release/interfaces/SubCommandOptions.html @@ -0,0 +1,288 @@ + + + + + + SubCommandOptions + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Interface SubCommandOptions

+
+
+
+
+
+
+
+
+
+

The options for a SubCommand.

+
+
+
+
+

Hierarchy

+
    +
  • + SubCommandOptions +
  • +
+
+
+

Index

+
+
+
+

Properties

+ +
+
+
+
+
+

Properties

+
+ +

Optional aliases

+
aliases: string[]
+ +
+
+

The aliases of the SubCommand.

+
+
+
+
+ +

Optional arguments

+
arguments: Record<string, Argument<any>>
+ +
+
+ +

Optional channels

+
channels: string[]
+ +
+
+

The channels where the SubCommand can be executed.

+
+
+
+
+ +

Optional description

+
description: string
+ +
+
+

The description of the SubCommand.

+
+
+
remarks
+

If a SubCommand has no description, it will not be shown in the default Help Command.

+
+
+
+
+
+ +

Optional tags

+
tags: (Tag | "channelOnly" | "dmOnly" | "guildOnly" | "guildOwnerOnly" | "ownerOnly" | "nsfw" | "threadOnly" | "check")[]
+ +
+
+

The tags of the SubCommand.

+
+
+
+
+ +

Optional usage

+
usage: string
+ +
+
+

Examples of usages for the SubCommand.

+
+
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/modules.html b/docs-release/modules.html new file mode 100644 index 0000000..82077cd --- /dev/null +++ b/docs-release/modules.html @@ -0,0 +1,2436 @@ + + + + + + Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+

Advanced Command-Handler - v3.0.0

+
+
+
+
+
+
+
+

Index

+
+
+
+

Classes

+ +
+
+

Type aliases

+ +
+
+

Interfaces

+ +
+
+

Enumerations

+ +
+
+

Namespaces

+ +
+
+

Variables

+ +
+
+

Functions

+ +
+
+
+
+
+

Type aliases

+
+ +

AnyObject

+
AnyObject: Record<string, any>
+ +
+
+ +

ArgumentBuilder

+
ArgumentBuilder<T>: Partial<(DefaultValueArgument<T> | CoalescingArgument | OptionalArgument) & { description: string }>
+ +

Type parameters

+
    +
  • +

    T

    +
  • +
+
+
+ +

ArgumentFunction

+
ArgumentFunction<T>: (options: ArgumentBuilder<T>) => Argument<T>
+ +

Type parameters

+
    +
  • +

    T

    +
  • +
+
+

Type declaration

+ +
+
+
+ +

ArgumentResolved

+
ArgumentResolved<A>: null | CommandError | A
+ +

Type parameters

+
    +
  • +

    A

    +
  • +
+
+
+ +

ColorResolvable

+
ColorResolvable: NonNullable<keyof typeof colors | keyof typeof LogType | string>
+ +
+
+ +

Constructor

+
Constructor<T>: new (...args: any[]) => T
+ +

Type parameters

+
    +
  • +

    T: {} = {}

    +
  • +
+
+

Type declaration

+
    +
  • +
      +
    • new (...args: any[]): T
    • +
    +
      +
    • +

      Parameters

      +
        +
      • +
        Rest ...args: any[]
        +
      • +
      +

      Returns T

      +
    • +
    +
  • +
+
+
+
+ +

JSONLike

+
JSONLike: {} | JSONLike[]
+ +
+
+ +

LoggerIgnore

+
LoggerIgnore: [title: string, level: LogLevel | keyof typeof LogLevel]
+ +
+
+ +

MapArguments

+
MapArguments<A>: Map<string, null | CommandError | A[number]>
+ +

Type parameters

+
    +
  • +

    A: any[]

    +
  • +
+
+
+ +

MaybeCommand

+
MaybeCommand: Constructor<Command> | { default: Constructor<Command> } | {}
+ +
+
+ +

MaybeEvent

+
MaybeEvent: Constructor<Event> | { default: Constructor<Event> } | {}
+ +
+
+ +

MaybePromise

+
MaybePromise<T>: Promise<T> | T
+ +

Type parameters

+
    +
  • +

    T

    +
  • +
+
+
+ +

RunSubCommandFunction

+
RunSubCommandFunction: (ctx: SubCommandContext) => any | Promise<any>
+ +
+

Type declaration

+ +
+
+
+ +

Template

+
Template<V>: Partial<MessageEmbedOptions> & (V extends undefined ? {} : { values?: V })
+ +

Type parameters

+ +
+
+ +

Templates

+
Templates: typeof templates
+ +
+
+ +

TextChannelLike

+
TextChannelLike: TextChannel | NewsChannel
+ +
+
+
+

Variables

+
+ +

Const LogType

+
LogType: { comment: string; debug: string; error: string; event: string; info: string; log: string; warn: string } = ...
+ +
+

Type declaration

+
    +
  • +
    comment: string
    +
  • +
  • +
    debug: string
    +
  • +
  • +
    error: string
    +
  • +
  • +
    event: string
    +
  • +
  • +
    info: string
    +
  • +
  • +
    log: string
    +
  • +
  • +
    warn: string
    +
  • +
+
+
+
+ +

Const colors

+
colors: { black: string; blue: string; brown: string; default: string; gold: string; green: string; grey: string; indigo: string; magenta: string; orange: string; pink: string; red: string; teal: string; violet: string; white: string; yellow: string } = ...
+ +
+

Type declaration

+
    +
  • +
    black: string
    +
  • +
  • +
    blue: string
    +
  • +
  • +
    brown: string
    +
  • +
  • +
    default: string
    +
  • +
  • +
    gold: string
    +
  • +
  • +
    green: string
    +
  • +
  • +
    grey: string
    +
  • +
  • +
    indigo: string
    +
  • +
  • +
    magenta: string
    +
  • +
  • +
    orange: string
    +
  • +
  • +
    pink: string
    +
  • +
  • +
    red: string
    +
  • +
  • +
    teal: string
    +
  • +
  • +
    violet: string
    +
  • +
  • +
    white: string
    +
  • +
  • +
    yellow: string
    +
  • +
+
+
+
+ +

Const limits

+
limits: { author: { name: number }; description: number; fields: { name: number; size: number; value: number }; footer: { text: number }; title: number }
+ +
+

Type declaration

+
    +
  • +
    author: { name: number }
    +
      +
    • +
      name: number
      +
    • +
    +
  • +
  • +
    description: number
    +
  • +
  • +
    fields: { name: number; size: number; value: number }
    +
      +
    • +
      name: number
      +
    • +
    • +
      size: number
      +
    • +
    • +
      value: number
      +
    • +
    +
  • +
  • +
    footer: { text: number }
    +
      +
    • +
      text: number
      +
    • +
    +
  • +
  • +
    title: number
    +
  • +
+
+
+
+ +

Const templates

+
templates: TemplatesValues
+ +
+
+
+

Functions

+
+ +

argError

+ +
    +
  • + +
    +
    +

    A function to use when a user fail on an argument of a command.

    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: CommandContext
      +
      +

      The message context where the error come from.

      +
      +
    • +
    • +
      error: string
      +
      +

      The error.

      +
      +
    • +
    +

    Returns Promise<Message>

    +
      +
    • The error message sent.
    • +
    +
  • +
+
+
+ +

booleanArgument

+ + +
+
+ +

channelArgument

+ +
    +
  • + +
    +
    +

    Creates a channel argument. + The value can be a mention, an ID, or a part of a channel from the entire client.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<Channel> = {}
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<Channel>

    +
      +
    • A channel Argument.
    • +
    +
  • +
+
+
+ +

choiceArgument

+ +
    +
  • + +
    +
    +

    Creates a choice argument. + You must put the values possible as a string array. + The value can be anything contained in the array.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<string> & { values: string[] }
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<string>

    +
      +
    • A choice argument.
    • +
    +
  • +
+
+
+ +

codeError

+ +
    +
  • + +
    +
    +

    A function to use when a code error occurs in a command for example.

    +
    +
    +
    remarks
    +

    If the message author is an owner, it sends the error stack.
    Do not use for sending string as errors.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: CommandContext
      +
      +

      The command context where the error come from.

      +
      +
    • +
    • +
      error: Error
      +
      +

      The native error.

      +
      +
    • +
    +

    Returns Promise<Message>

    +
      +
    • The error message sent.
    • +
    +
  • +
+
+
+ +

commandArgument

+ + +
+
+ +

cutIfTooLong

+
    +
  • cutIfTooLong(text: string, maxLength: number, endTextIfTooLong?: string): string
  • +
+
    +
  • + +
    +
    +

    Return the text cut if length is above maxLength arg and add endTextIfTooLong at the end.

    +
    +
    +

    Parameters

    +
      +
    • +
      text: string
      +
      +

      The text to cut if it is too long.

      +
      +
    • +
    • +
      maxLength: number
      +
      +

      The maximum length required.

      +
      +
    • +
    • +
      endTextIfTooLong: string = '...'
      +
      +

      The end text to add if it is too long.

      +
      +
    • +
    +

    Returns string

    +
      +
    • The text, cut if it was too long.
    • +
    +
  • +
+
+
+ +

emojiArgument

+ + +
+
+ +

enumArgument

+ +
    +
  • + +
    +
    +

    Creates a enum argument. + You must put an enum (or a record) of the possible values. + The value can be any key of the possible values and it will return the value of the entry.

    +
    +
    +

    Type parameters

    +
      +
    • +

      E: Record<string, V>

      +
    • +
    • +

      V

      +
    • +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<V> & { values: E }
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<V>

    +
      +
    • A enum argument.
    • +
    +
  • +
+
+
+ +

eventArgument

+ + +
+
+ +

floatArgument

+ + +
+
+ +

getKeyByValue

+
    +
  • getKeyByValue<O>(object: O, value: O[keyof O]): keyof O | undefined
  • +
+
    +
  • + +
    +
    +

    Get a key from a value from an Object.

    +
    +
    +

    Type parameters

    +
      +
    • +

      O: {}

      +
      +

      The object type.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      object: O
      +
      +

      The object to get key from.

      +
      +
    • +
    • +
      value: O[keyof O]
      +
      +

      The value.

      +
      +
    • +
    +

    Returns keyof O | undefined

    +
      +
    • The key of the object if found, else undefined.
    • +
    +
  • +
+
+
+ +

getThing

+
    +
  • getThing(dataType: DataTypeResolver<CHANNEL>, text: string | Message): Promise<Channel | null>
  • +
  • getThing(dataType: DataTypeResolver<COMMAND>, text: string | Message): Promise<Command | null>
  • +
  • getThing(dataType: DataTypeResolver<EMOTE>, text: string | Message): Promise<Emoji | null>
  • +
  • getThing(dataType: DataTypeResolver<GUILD>, text: string | Message): Promise<Guild | null>
  • +
  • getThing(dataType: DataTypeResolver<MEMBER>, text: string | Message): Promise<GuildMember | null>
  • +
  • getThing(dataType: DataTypeResolver<MESSAGE>, text: string | Message): Promise<Message | null>
  • +
  • getThing(dataType: DataTypeResolver<ROLE>, text: string | Message): Promise<Role | null>
  • +
  • getThing(dataType: DataTypeResolver<TEXT_CHANNEL>, text: string | Message): Promise<TextChannelLike | null>
  • +
  • getThing(dataType: DataTypeResolver<USER>, text: string | Message): Promise<User | null>
  • +
+
    +
  • + +
    +
    +

    Finds a Channel from the text, or the message content and returns null if nothing found. + It can find it from ID/name/mention.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<CHANNEL>
      +
      +

      Channel DataType.CHANNEL.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Channel | null>

    +
      +
    • The Channel or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a Command from the text, or the message content and returns null if nothing found. + It can find it from the name/alias.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<COMMAND>
      +
      +

      Command DataType.COMMAND.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Command | null>

    +
      +
    • The Command or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds an Emoji from the text, or the message content and returns null if nothing found. + It can find it from the name/emoji itself/ID.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<EMOTE>
      +
      +

      Emote DataType.EMOTE.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Emoji | null>

    +
      +
    • The Emoji or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a Guild from the text, or the message content and returns null if nothing found. + It can find it from the name/ID.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<GUILD>
      +
      +

      Guild DataType.GUILD.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Guild | null>

    +
      +
    • The Guild or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a GuildMember from the text, or the message content and returns null if nothing found. + It can find it from the username/ID/mention/nickname.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<MEMBER>
      +
      +

      Member DataType.MEMBER.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<GuildMember | null>

    +
      +
    • The Guild or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a Message from the text, or the message content and returns null if nothing found. + It can find it from the name/ID/link.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<MESSAGE>
      +
      +

      Message DataType.MESSAGE.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Message | null>

    +
      +
    • The Message or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a Role from the text, or the message content and returns null if nothing found. + It can find it from the name/ID/mention, if a message is provided, it will fetch the last 100 messages and search in it.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<ROLE>
      +
      +

      Role DataType.ROLE.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<Role | null>

    +
      +
    • The Role or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a TextChannel or a NewsChannel from the text, or the message content and returns null if nothing found. + It can find it from ID/name/mention.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<TEXT_CHANNEL>
      +
      +

      TextChannel | NewsChannel DataType.TEXT_CHANNEL.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<TextChannelLike | null>

    +
      +
    • The Channel or null if not found.
    • +
    +
  • +
  • + +
    +
    +

    Finds a User from the text, or the message content and returns null if nothing found.
    + It can find it from the username/ID.

    +
    +
    +

    Parameters

    +
      +
    • +
      dataType: DataTypeResolver<USER>
      +
      +

      User DataType.USER.

      +
      +
    • +
    • +
      text: string | Message
      +
      +

      A string or a Message to find dataType from.

      +
      +
    • +
    +

    Returns Promise<User | null>

    +
      +
    • The User or null if not found.
    • +
    +
  • +
+
+
+ +

guildArgument

+ + +
+
+ +

guildMemberArgument

+ +
    +
  • + +
    +
    +

    Creates a guildMember argument. + The value can be an ID, mention, nickname or username of any member from the actual guild where the command was executed. + If executed in DM it will always return null.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<GuildMember> = {}
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<GuildMember>

    +
      +
    • A guildMember argument.
    • +
    +
  • +
+
+
+ +

intArgument

+ + +
+
+ +

isOwner

+
    +
  • isOwner(id: Snowflake): boolean
  • +
+ +
+
+ +

isPermission

+
    +
  • isPermission(permission: string): permission is PermissionString
  • +
+
    +
  • + +
    +
    +

    Check if some permission is a valid permission that exists.

    +
    +
    +

    Parameters

    +
      +
    • +
      permission: string
      +
      +

      The permission to test.

      +
      +
    • +
    +

    Returns permission is PermissionString

    +
      +
    • Is the permission is a valid permission.
    • +
    +
  • +
+
+
+ +

isSnowflake

+
    +
  • isSnowflake(value: string): value is string
  • +
+
    +
  • + +
    +
    +

    Returns true if the value looks like a Snowflake.

    +
    +
    +
    remarks
    +

    There is no way to identify at 100% if the value is veritable snowflake of something.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      value: string
      +
    • +
    +

    Returns value is string

    +
      +
    • Is the value a Snowflake.
    • +
    +
  • +
+
+
+ +

isTextChannelLike

+ +
    +
  • + +
    +
    +

    Returns true if the value is a TextChannel or a NewsChannel.

    +
    +
    +

    Parameters

    +
      +
    • +
      value: any
      +
      +

      The value you want to test.

      +
      +
    • +
    +

    Returns value is TextChannelLike

    +
      +
    • Is the value a TextChannelLike.
    • +
    +
  • +
+
+
+ +

messageArgument

+ +
    +
  • + +
    +
    +

    Creates a message argument. + The value can be any ID or URL of a message, if the value is an ID it will search in the last 100 messages of all the channels of the current guild.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<Message> = {}
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<Message>

    +
      +
    • A message argument.
    • +
    +
  • +
+
+
+ +

permissionsError

+
    +
  • permissionsError(ctx: CommandContext, missingPermissions: PermissionString[], fromClient?: boolean): Promise<Message>
  • +
+
    +
  • + +
    +
    +

    A function to use when a user, or the client hasn't all the permissions needed.

    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: CommandContext
      +
      +

      The command context where the permission where missing.

      +
      +
    • +
    • +
      missingPermissions: PermissionString[]
      +
      +

      The error.

      +
      +
    • +
    • +
      fromClient: boolean = false
      +
      +

      If the error is from the client.

      +
      +
    • +
    +

    Returns Promise<Message>

    +
      +
    • The error message sent.
    • +
    +
  • +
+
+
+ +

random

+
    +
  • random<T>(array: T[]): T
  • +
+
    +
  • + +
    +
    +

    Returns a random value from an array.

    +
    +
    +

    Type parameters

    +
      +
    • +

      T: unknown

      +
      +

      The array type.

      +
      +
    • +
    +

    Parameters

    +
      +
    • +
      array: T[]
      +
      +

      The array to get a random value from.

      +
      +
    • +
    +

    Returns T

    +
      +
    • A random value from the array.
    • +
    +
  • +
+
+
+ +

readJSON

+ +
    +
  • + +
    +
    +

    Reads a JSON through its path.

    +
    +
    +
    remarks
    +

    Prefer using import or require.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path to the JSON file.

      +
      +
    • +
    +

    Returns JSONLike

    +
      +
    • The JSON.
    • +
    +
  • +
+
+
+ +

regexArgument

+ + +
+
+ +

saveJSON

+
    +
  • saveJSON(path: string, content: JSONLike): boolean
  • +
+
    +
  • + +
    +
    +

    Saves a JSON-Like object into a JSON file.

    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the JSON file.

      +
      +
    • +
    • +
      content: JSONLike
      +
      +

      The content to save.

      +
      +
    • +
    +

    Returns boolean

    +
      +
    • True if operation has successfully worked.
    • +
    +
  • +
+
+
+ +

snowflakeArgument

+ + +
+
+ +

stringArgument

+ +
    +
  • + +
    +
    +

    Creates a string argument. + The value can be anything. + It can also be filtered using the optional regex option.

    +
    +
    +

    Parameters

    +
      +
    • +
      options: ArgumentBuilder<string> & { regex?: RegExp } = {}
      +
      +

      The options of the argument.

      +
      +
    • +
    +

    Returns Argument<string>

    +
      +
    • A string argument.
    • +
    +
  • +
+
+
+ +

textChannelArgument

+ +
    +
  • + +
    +
    +

    Creates a textChannel argument. + The value can be an ID, mention or name of a TextChannel or a NewsChannel. + If a channel is found but is not a TextChannel or a NewsChannel, it will returns null.

    +
    +
    +

    Parameters

    + +

    Returns Argument<TextChannel | NewsChannel>

    +
      +
    • A textChannel argument.
    • +
    +
  • +
+
+
+ +

userArgument

+ + +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/modules/CommandHandler.html b/docs-release/modules/CommandHandler.html new file mode 100644 index 0000000..8e65332 --- /dev/null +++ b/docs-release/modules/CommandHandler.html @@ -0,0 +1,1248 @@ + + + + + + CommandHandler + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Namespace CommandHandler

+
+
+
+
+
+
+
+

Index

+
+ +
+
+
+

Type aliases

+
+ +

CommandHandlerEvents

+
CommandHandlerEvents: { create: [CreateCommandHandlerOptions]; error: [CommandHandlerError]; launch: [LaunchCommandHandlerOptions]; launched: []; loadCommand: [Command]; loadEvent: [Event] }
+ +
+
+

The CommandHandler events.

+
+
+
see
+

EventEmitter.

+
+
+
+
+

Type declaration

+
    +
  • +
    create: [CreateCommandHandlerOptions]
    +
    +
    +

    The event executed when creating the CommandHandler.

    +
    +
    +
  • +
  • +
    error: [CommandHandlerError]
    +
    +
    +

    The event executed when a CommandHandlerError is created.

    +
    +
    +
    remarks
    +

    You need to add a listener to this event for every bots otherwise it will crash in some places with a weird error.

    +
    +
    see
    +

    https://nodejs.org/api/errors.html#errors_err_unhandled_error

    +
    +
    +
    +
  • +
  • +
    launch: [LaunchCommandHandlerOptions]
    +
    +
    +

    The event executed when the CommandHandler starts its launch.

    +
    +
    +
  • +
  • +
    launched: []
    +
    +
    +

    The event executed when the CommandHandler has finished launching..

    +
    +
    +
  • +
  • +
    loadCommand: [Command]
    +
    +
    +

    The event executed when loading a Command.

    +
    +
    +
  • +
  • +
    loadEvent: [Event]
    +
    +
    +

    The event executed when loading an Event.

    +
    +
    +
  • +
+
+
+
+ +

CooldownUser

+
CooldownUser: {}
+ +
+
+
internal
+
+
+
+
+

Type declaration

+ +
+
+
+
+

Variables

+
+ +

Let client

+
client: AdvancedClient | null = null
+ +
+
+

The client of the handler, null before launch function executed.

+
+
+
+
+ +

Const commands

+
commands: Collection<string, Command> = ...
+ +
+
+

The commands registered by the CommandHandler.

+
+
+
+
+ +

Let commandsDir

+
commandsDir: string = ''
+ +
+
+ +

Const cooldowns

+
cooldowns: Collection<string, CooldownUser> = ...
+ +
+
+

The cooldowns mapped by ID and cooldown user.

+
+

A simple explication :
+ When a user executes a command with a cooldown, a new value is added.

+
[anyID]: {
+   [commandName]: {
+       executedAt: Date,
+       cooldown: [command cooldown]
+   }
+}
+
+

So cooldowns are mapped by IDs (can be anything, user IDs recommended) then mapped by commands.

+
+
+
+ +

Const emitter

+
emitter: EventEmitter = ...
+ +
+
+

The event emitter for the CommandHandler.

+
+
+
eventproperty
+
+
+
+
+
+ +

Const events

+
events: Collection<string, Event> = ...
+ +
+
+

The events registered by the EventHandler.

+
+
+
remarks
+

These events may not be bound to the client.

+
+
+
+
+
+ +

Let eventsDir

+
eventsDir: string = ''
+ +
+
+ +

Let owners

+
owners: string[] = []
+ +
+
+ +

Let prefixes

+
prefixes: string[] = []
+ +
+
+ +

Let presencesInterval

+
presencesInterval: NodeJS.Timer
+ +
+
+

The interval of the cycling presences, undefined if you don't use it.

+
+
+
+
+ +

Const version

+
version: any = ...
+ +
+
+

The version of the handler.

+
+
+
+
+
+

Functions

+
+ +

create

+ + +
+
+ +

emit

+ +
    +
  • + +
    +
    +

    Execute the event you want from the listener throughout the CommandHandler.

    +
    +
    +

    Type parameters

    + +

    Parameters

    +
      +
    • +
      eventName: K
      +
      +

      The event name.

      +
      +
    • +
    • +
      Rest ...args: CommandHandlerEvents[K]
      +
      +

      The arguments to pass.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

findCommand

+
    +
  • findCommand(name: string): undefined | Command
  • +
+
    +
  • + +
    +
    +

    Find a command by name or alias.

    +
    +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The name or alias of the command.

      +
      +
    • +
    +

    Returns undefined | Command

    +
      +
    • The command found or undefined.
    • +
    +
  • +
+
+
+ +

getCommandAliasesAndNames

+
    +
  • getCommandAliasesAndNames(): string[]
  • +
+
    +
  • + +
    +
    +

    Returns the list of names and aliases of all commands, useful to find a command by name.

    +
    +
    +

    Returns string[]

    +
      +
    • All the names and aliases in a flat array.
    • +
    +
  • +
+
+
+ +

getPrefixFromMessage

+
    +
  • getPrefixFromMessage(message: Message): undefined | string
  • +
+
    +
  • + +
    +
    +

    Get the prefix from the prefixes defined in CommandHandler.launch or null.

    +
    +
    +

    Parameters

    +
      +
    • +
      message: Message
      +
      +

      The message to get the prefix for.

      +
      +
    • +
    +

    Returns undefined | string

    +
      +
    • The prefix found or null if not.
    • +
    +
  • +
+
+
+ +

launch

+ + +
+
+ +

loadCommand

+
    +
  • loadCommand(path: string, name: string): Promise<Command>
  • +
+
    +
  • + +
    +
    +

    Load a command from the directory & filename.

    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the command folder.

      +
      +
    • +
    • +
      name: string
      +
      +

      The name of the command including the extension.

      +
      +
    • +
    +

    Returns Promise<Command>

    +
      +
    • The command itself.
    • +
    +
  • +
+
+
+ +

loadCommands

+
    +
  • loadCommands(path: string): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Load all the commands from a directory.

    +
    +
    +
    remarks
    +

    The path must be a directory containing sub-directories.

    +
    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the directory to load the commands from.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

loadEvent

+
    +
  • loadEvent(path: string, name: string): Promise<Event>
  • +
+
    +
  • + +
    +
    +

    Load an event from the directory and filename.

    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the event folder.

      +
      +
    • +
    • +
      name: string
      +
      +

      The name of the event including the extension.

      +
      +
    • +
    +

    Returns Promise<Event>

    +
      +
    • The event itself.
    • +
    +
  • +
+
+
+ +

loadEvents

+
    +
  • loadEvents(path: string): Promise<void>
  • +
+
    +
  • + +
    +
    +

    Load all the events from a directory.

    +
    +
    +

    Parameters

    +
      +
    • +
      path: string
      +
      +

      The path of the directory to load the events from.

      +
      +
    • +
    +

    Returns Promise<void>

    +
  • +
+
+
+ +

on

+ + +
+
+ +

once

+ + +
+
+ +

unloadCommand

+
    +
  • unloadCommand(name: string): void
  • +
+
    +
  • + +
    +
    +

    Unloads a command.

    +
    +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The command to unload.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

unloadEvent

+
    +
  • unloadEvent(name: string): void
  • +
+
    +
  • + +
    +
    +

    Unloads an event.

    +
    +
    +

    Parameters

    +
      +
    • +
      name: string
      +
      +

      The event to unload.

      +
      +
    • +
    +

    Returns void

    +
  • +
+
+
+ +

useDefaultCommands

+
    +
  • useDefaultCommands(options?: DefaultCommandsOptions): typeof CommandHandler
  • +
+ +
+
+ +

useDefaultEvents

+
    +
  • useDefaultEvents(options?: DefaultEventsOptions): typeof CommandHandler
  • +
+ +
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file diff --git a/docs-release/modules/Tag.html b/docs-release/modules/Tag.html new file mode 100644 index 0000000..0957f48 --- /dev/null +++ b/docs-release/modules/Tag.html @@ -0,0 +1,195 @@ + + + + + + Tag + | Advanced Command-Handler - v3.0.0 + + + + + + +
+
+
+
+ +
+
+ Options +
+
+ All +
    +
  • Public
  • +
  • Public/Protected
  • +
  • All
  • +
+
+ + + + +
+
+ Menu +
+
+
+
+
+
+ +

Namespace Tag

+
+
+
+
+
+
+
+

Index

+
+
+
+

Functions

+ +
+
+
+
+
+

Functions

+
+ +

check

+ +
    +
  • + +
    +
    +

    Check if some tags are validated in the command context.

    +
    +
    +

    Parameters

    +
      +
    • +
      ctx: CommandContext
      +
      +

      The command context.

      +
      +
    • +
    • +
      tags: (Tag | keyof typeof Tag | string)[]
      +
      +

      The tags to test.

      +
      +
    • +
    +

    Returns Tag[]

    +
      +
    • The tags not validated.
    • +
    +
  • +
+
+
+
+ +
+
+
+
+

Legend

+
+
    +
  • Constructor
  • +
  • Property
  • +
  • Method
  • +
+
    +
  • Inherited constructor
  • +
  • Inherited property
  • +
  • Inherited method
  • +
+
    +
  • Static property
  • +
  • Static method
  • +
+
    +
  • Property
  • +
+
    +
  • Protected method
  • +
+
+
+
+
+

Generated using TypeDoc

+
+
+ + + \ No newline at end of file