angular-toolbox 1.3.2 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  A library that provides useful tools for Angular apps development.
4
4
 
5
- [![Angular Toolbox version](https://img.shields.io/badge/Angular%20Toolbox:1.3.2%231E90FF.svg)]()
5
+ [![Angular Toolbox version](https://img.shields.io/badge/Angular%20Toolbox:1.4.0%231E90FF.svg)]()
6
6
 
7
7
  ## License
8
8
 
@@ -40,6 +40,11 @@ export class DropdownComponent extends IdentifiableComponent {
40
40
  * Sets the horizontal position of the content container.
41
41
  */
42
42
  this.hPos = "left";
43
+ /**
44
+ * Indicates whether the content container can be "light dismissed" by selecting outside the popover area
45
+ * (`auto`), or not (`manual`).
46
+ */
47
+ this.popoverState = "auto";
43
48
  this.id = this.getID().toString();
44
49
  }
45
50
  /**
@@ -87,11 +92,11 @@ export class DropdownComponent extends IdentifiableComponent {
87
92
  return new DropdownEvent(this, type, event.newState, event.oldState);
88
93
  }
89
94
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: DropdownComponent, isStandalone: true, selector: "atx-dropdown", inputs: { buttonClass: "buttonClass", containerClass: "containerClass", vPos: "vPos", hPos: "hPos" }, outputs: { toggle: "toggle", beforeToggle: "beforeToggle" }, viewQueries: [{ propertyName: "_popover", first: true, predicate: ["popover"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n <ng-content></ng-content>\r\n </button>\r\n <div #popover popover [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n <div class=\"atx-dropdown-popover\"\r\n [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n <ng-content select=\"[content]\"></ng-content>\r\n </div>\r\n</div>\r\n", styles: [".atx-dropdown-container{position:relative}[popover]:popover-open{inset:unset;border:none;background:none;margin:0;padding:0}[popover]:popover-open+.atx-dropdown-popover{display:block}.atx-dropdown-popover{display:none;position:absolute;left:0;margin:0;padding:0;z-index:100;height:auto;width:max-content}.atx-dropdown-v-start{bottom:unset;top:0}.atx-dropdown-top{bottom:calc(100% + var(--atx-dropdown-gutter, 2px));top:unset}.atx-dropdown-middle{bottom:unset;top:50%;transform:translateY(-50%)}.atx-dropdown-bottom{bottom:unset;top:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-v-end{bottom:0;top:unset}.atx-dropdown-h-start{right:calc(100% + var(--atx-dropdown-gutter, 2px));left:unset}.atx-dropdown-left{left:0;right:unset}.atx-dropdown-center{left:50%;transform:translate(-50%);right:unset}.atx-dropdown-right{right:0;left:unset}.atx-dropdown-h-end{right:unset;left:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-centered{transform:translate(-50%,-50%)}\n/**\n * @license\n * Copyright Pascal ECHEMANN. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n"] }); }
95
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: DropdownComponent, isStandalone: true, selector: "atx-dropdown", inputs: { buttonClass: "buttonClass", containerClass: "containerClass", vPos: "vPos", hPos: "hPos", popoverState: "popoverState" }, outputs: { toggle: "toggle", beforeToggle: "beforeToggle" }, viewQueries: [{ propertyName: "_popover", first: true, predicate: ["popover"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n <ng-content></ng-content>\r\n </button>\r\n <div #popover [attr.popover]=\"popoverState\" [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n <div class=\"atx-dropdown-popover\"\r\n [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n <ng-content select=\"[content]\"></ng-content>\r\n </div>\r\n</div>\r\n", styles: [".atx-dropdown-container{position:relative}[popover]:popover-open{inset:unset;border:none;background:none;margin:0;padding:0}[popover]:popover-open+.atx-dropdown-popover{display:block}.atx-dropdown-popover{display:none;position:absolute;left:0;margin:0;padding:0;z-index:100;height:auto;width:max-content}.atx-dropdown-v-start{bottom:unset;top:0}.atx-dropdown-top{bottom:calc(100% + var(--atx-dropdown-gutter, 2px));top:unset}.atx-dropdown-middle{bottom:unset;top:50%;transform:translateY(-50%)}.atx-dropdown-bottom{bottom:unset;top:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-v-end{bottom:0;top:unset}.atx-dropdown-h-start{right:calc(100% + var(--atx-dropdown-gutter, 2px));left:unset}.atx-dropdown-left{left:0;right:unset}.atx-dropdown-center{left:50%;transform:translate(-50%);right:unset}.atx-dropdown-right{right:0;left:unset}.atx-dropdown-h-end{right:unset;left:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-centered{transform:translate(-50%,-50%)}\n/**\n * @license\n * Copyright Pascal ECHEMANN. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n"] }); }
91
96
  }
92
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DropdownComponent, decorators: [{
93
98
  type: Component,
94
- args: [{ selector: 'atx-dropdown', standalone: true, template: "<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n <ng-content></ng-content>\r\n </button>\r\n <div #popover popover [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n <div class=\"atx-dropdown-popover\"\r\n [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n <ng-content select=\"[content]\"></ng-content>\r\n </div>\r\n</div>\r\n", styles: [".atx-dropdown-container{position:relative}[popover]:popover-open{inset:unset;border:none;background:none;margin:0;padding:0}[popover]:popover-open+.atx-dropdown-popover{display:block}.atx-dropdown-popover{display:none;position:absolute;left:0;margin:0;padding:0;z-index:100;height:auto;width:max-content}.atx-dropdown-v-start{bottom:unset;top:0}.atx-dropdown-top{bottom:calc(100% + var(--atx-dropdown-gutter, 2px));top:unset}.atx-dropdown-middle{bottom:unset;top:50%;transform:translateY(-50%)}.atx-dropdown-bottom{bottom:unset;top:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-v-end{bottom:0;top:unset}.atx-dropdown-h-start{right:calc(100% + var(--atx-dropdown-gutter, 2px));left:unset}.atx-dropdown-left{left:0;right:unset}.atx-dropdown-center{left:50%;transform:translate(-50%);right:unset}.atx-dropdown-right{right:0;left:unset}.atx-dropdown-h-end{right:unset;left:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-centered{transform:translate(-50%,-50%)}\n/**\n * @license\n * Copyright Pascal ECHEMANN. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n"] }]
99
+ args: [{ selector: 'atx-dropdown', standalone: true, template: "<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n <ng-content></ng-content>\r\n </button>\r\n <div #popover [attr.popover]=\"popoverState\" [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n <div class=\"atx-dropdown-popover\"\r\n [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n <ng-content select=\"[content]\"></ng-content>\r\n </div>\r\n</div>\r\n", styles: [".atx-dropdown-container{position:relative}[popover]:popover-open{inset:unset;border:none;background:none;margin:0;padding:0}[popover]:popover-open+.atx-dropdown-popover{display:block}.atx-dropdown-popover{display:none;position:absolute;left:0;margin:0;padding:0;z-index:100;height:auto;width:max-content}.atx-dropdown-v-start{bottom:unset;top:0}.atx-dropdown-top{bottom:calc(100% + var(--atx-dropdown-gutter, 2px));top:unset}.atx-dropdown-middle{bottom:unset;top:50%;transform:translateY(-50%)}.atx-dropdown-bottom{bottom:unset;top:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-v-end{bottom:0;top:unset}.atx-dropdown-h-start{right:calc(100% + var(--atx-dropdown-gutter, 2px));left:unset}.atx-dropdown-left{left:0;right:unset}.atx-dropdown-center{left:50%;transform:translate(-50%);right:unset}.atx-dropdown-right{right:0;left:unset}.atx-dropdown-h-end{right:unset;left:calc(100% + var(--atx-dropdown-gutter, 2px))}.atx-dropdown-centered{transform:translate(-50%,-50%)}\n/**\n * @license\n * Copyright Pascal ECHEMANN. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n"] }]
95
100
  }], ctorParameters: () => [], propDecorators: { toggle: [{
96
101
  type: Output
97
102
  }], beforeToggle: [{
@@ -104,8 +109,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
104
109
  type: Input
105
110
  }], hPos: [{
106
111
  type: Input
112
+ }], popoverState: [{
113
+ type: Input
107
114
  }], _popover: [{
108
115
  type: ViewChild,
109
116
  args: ["popover"]
110
117
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-toolbox/src/lib/component/dropdown/dropdown.component.ts","../../../../../../projects/angular-toolbox/src/lib/component/dropdown/dropdown.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAuE,MAAM,aAAa,CAAC;;AAEpI;;GAEG;AACH,MAAM,SAAS,GAAW,eAAe,CAAC;AAE1C;;;;GAIG;AAOH,MAAM,OAAO,iBAAkB,SAAQ,qBAAqB;IAiD1D;;OAEG;IACH;QACE,KAAK,EAAE,CAAC;QAnDV;;WAEG;QAEa,WAAM,GAAgC,IAAI,YAAY,EAAE,CAAC;QAEzE;;WAEG;QAEa,iBAAY,GAAgC,IAAI,YAAY,EAAE,CAAC;QAc/E;;WAEG;QAEI,SAAI,GAA6B,QAAQ,CAAC;QAEjD;;WAEG;QAEI,SAAI,GAA+B,MAAM,CAAC;QAkB/C,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;;;OAIG;IACI,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO,KAAK,CAAC;QACjC,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACO,cAAc,CAAC,KAAY;QACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,IAAI,CAAC,UAAU,CAAC,KAAoB,EAAE,iBAAiB,CAAC,aAAa,CAAC,CACvE,CAAC;IACJ,CAAC;IAED;;OAEG;IACO,QAAQ,CAAC,KAAY;QAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,IAAI,CAAC,UAAU,CAAC,KAAoB,EAAE,iBAAiB,CAAC,MAAM,CAAC,CAChE,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,KAAkB,EAAE,IAAuB;QAC5D,OAAO,IAAI,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,QAAyB,EAAE,KAAK,CAAC,QAAyB,CAAC,CAAC;IACzG,CAAC;8GA1GU,iBAAiB;kGAAjB,iBAAiB,uWC5B9B,q3CA4BA;;2FDAa,iBAAiB;kBAN7B,SAAS;+BACE,cAAc,cACZ,IAAI;wDAUA,MAAM;sBADrB,MAAM;gBAOS,YAAY;sBAD3B,MAAM;gBAOA,WAAW;sBADjB,KAAK;gBAOC,cAAc;sBADpB,KAAK;gBAOC,IAAI;sBADV,KAAK;gBAOC,IAAI;sBADV,KAAK;gBAYE,QAAQ;sBADf,SAAS;uBAAC,SAAS","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { IdentifiableComponent } from '../../core';\r\nimport { DropdownEvent, DropdownEventType, DropdownHorizontalPosition, DropdownState, DropdownVerticalPosition } from '../../model';\r\n\r\n/**\r\n * @private\r\n */\r\nconst API_MATCH: string = ':popover-open';\r\n\r\n/**\r\n * The ATX dropdown component allows to create popup containers that are displayed by clicking on a button.\r\n * The content of the container is defined by Developer.\r\n * This component is part of the LAF-less API.\r\n */\r\n@Component({\r\n  selector: 'atx-dropdown',\r\n  standalone: true,\r\n  templateUrl: './dropdown.component.html',\r\n  styleUrl: './dropdown.component.scss'\r\n})\r\nexport class DropdownComponent extends IdentifiableComponent {\r\n\r\n  /**\r\n   * An event fired on the dropdown component just after it is shown or hidden.\r\n   */\r\n  @Output()\r\n  public readonly toggle: EventEmitter<DropdownEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * An event fired on the dropdown component just before it is shown or hidden.\r\n   */\r\n  @Output()\r\n  public readonly beforeToggle: EventEmitter<DropdownEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Sets the dropdown button CSS class.\r\n   */\r\n  @Input()\r\n  public buttonClass!: string;\r\n\r\n  /**\r\n   * Sets the dropdown conpoment CSS class.\r\n   */\r\n  @Input()\r\n  public containerClass!: string;\r\n\r\n  /**\r\n   * Sets the vertical position of the content container.\r\n   */\r\n  @Input()\r\n  public vPos: DropdownVerticalPosition = \"bottom\";\r\n\r\n  /**\r\n   * Sets the horizontal position of the content container.\r\n   */\r\n  @Input()\r\n  public hPos: DropdownHorizontalPosition = \"left\";\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected id!: string;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ViewChild(\"popover\")\r\n  private _popover!: ElementRef;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  constructor() {\r\n    super();\r\n    this.id = this.getID().toString();\r\n  }\r\n\r\n  /**\r\n   * Hides the dropdown container.\r\n   */\r\n  public hideContent(): void {\r\n    if (!this._popover) return;\r\n    this._popover.nativeElement.hidePopover();\r\n  }\r\n\r\n  /**\r\n   * Displays the dropdown container.\r\n   */\r\n  public showContent(): void {\r\n    if (!this._popover) return;\r\n    this._popover.nativeElement.showPopover();\r\n  }\r\n\r\n  /**\r\n   * Returns the display state of the dropdown.\r\n   * \r\n   * @returns Returns `true` whether the dropdown is opened; `false` otherwise.\r\n   */\r\n  public isOpened(): boolean {\r\n    if (!this._popover) return false;\r\n    return this._popover.nativeElement.matches(API_MATCH);\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected onBeforeToggle(event: Event): void {\r\n    this.beforeToggle.emit(\r\n      this.buildEvent(event as ToggleEvent, DropdownEventType.BEFORE_TOGGLE)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected onToggle(event: Event): void {\r\n    this.toggle.emit(\r\n      this.buildEvent(event as ToggleEvent, DropdownEventType.TOGGLE)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  private buildEvent(event: ToggleEvent, type: DropdownEventType): DropdownEvent {\r\n    return new DropdownEvent(this, type, event.newState as DropdownState, event.oldState as DropdownState);\r\n  }\r\n}\r\n","<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n    <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n        <ng-content></ng-content>\r\n    </button>\r\n    <div #popover popover [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n    <div class=\"atx-dropdown-popover\"\r\n         [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n         [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n         [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n         [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n         [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n         [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n         [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n         [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n         [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n         [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n         [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n        <ng-content select=\"[content]\"></ng-content>\r\n    </div>\r\n</div>\r\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-toolbox/src/lib/component/dropdown/dropdown.component.ts","../../../../../../projects/angular-toolbox/src/lib/component/dropdown/dropdown.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAqF,MAAM,aAAa,CAAC;;AAElJ;;GAEG;AACH,MAAM,SAAS,GAAW,eAAe,CAAC;AAE1C;;;;GAIG;AAOH,MAAM,OAAO,iBAAkB,SAAQ,qBAAqB;IAwD1D;;OAEG;IACH;QACE,KAAK,EAAE,CAAC;QA1DV;;WAEG;QAEa,WAAM,GAAgC,IAAI,YAAY,EAAE,CAAC;QAEzE;;WAEG;QAEa,iBAAY,GAAgC,IAAI,YAAY,EAAE,CAAC;QAc/E;;WAEG;QAEI,SAAI,GAA6B,QAAQ,CAAC;QAEjD;;WAEG;QAEI,SAAI,GAA+B,MAAM,CAAC;QAEjD;;;WAGG;QAEI,iBAAY,GAAiB,MAAM,CAAC;QAkBzC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED;;;;OAIG;IACI,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO,KAAK,CAAC;QACjC,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACO,cAAc,CAAC,KAAY;QACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,IAAI,CAAC,UAAU,CAAC,KAAoB,EAAE,iBAAiB,CAAC,aAAa,CAAC,CACvE,CAAC;IACJ,CAAC;IAED;;OAEG;IACO,QAAQ,CAAC,KAAY;QAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,IAAI,CAAC,UAAU,CAAC,KAAoB,EAAE,iBAAiB,CAAC,MAAM,CAAC,CAChE,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,KAAkB,EAAE,IAAuB;QAC5D,OAAO,IAAI,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,QAAyB,EAAE,KAAK,CAAC,QAAyB,CAAC,CAAC;IACzG,CAAC;8GAjHU,iBAAiB;kGAAjB,iBAAiB,qYC5B9B,64CA4BA;;2FDAa,iBAAiB;kBAN7B,SAAS;+BACE,cAAc,cACZ,IAAI;wDAUA,MAAM;sBADrB,MAAM;gBAOS,YAAY;sBAD3B,MAAM;gBAOA,WAAW;sBADjB,KAAK;gBAOC,cAAc;sBADpB,KAAK;gBAOC,IAAI;sBADV,KAAK;gBAOC,IAAI;sBADV,KAAK;gBAQC,YAAY;sBADlB,KAAK;gBAYE,QAAQ;sBADf,SAAS;uBAAC,SAAS","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\r\nimport { IdentifiableComponent } from '../../core';\r\nimport { DropdownEvent, DropdownEventType, DropdownHorizontalPosition, DropdownState, DropdownVerticalPosition, PopoverState } from '../../model';\r\n\r\n/**\r\n * @private\r\n */\r\nconst API_MATCH: string = ':popover-open';\r\n\r\n/**\r\n * The ATX dropdown component allows to create popup containers that are displayed by clicking on a button.\r\n * The content of the container is defined by Developer.\r\n * This component is part of the LAF-less API.\r\n */\r\n@Component({\r\n  selector: 'atx-dropdown',\r\n  standalone: true,\r\n  templateUrl: './dropdown.component.html',\r\n  styleUrl: './dropdown.component.scss'\r\n})\r\nexport class DropdownComponent extends IdentifiableComponent {\r\n\r\n  /**\r\n   * An event fired on the dropdown component just after it is shown or hidden.\r\n   */\r\n  @Output()\r\n  public readonly toggle: EventEmitter<DropdownEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * An event fired on the dropdown component just before it is shown or hidden.\r\n   */\r\n  @Output()\r\n  public readonly beforeToggle: EventEmitter<DropdownEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Sets the dropdown button CSS class.\r\n   */\r\n  @Input()\r\n  public buttonClass!: string;\r\n\r\n  /**\r\n   * Sets the dropdown conpoment CSS class.\r\n   */\r\n  @Input()\r\n  public containerClass!: string;\r\n\r\n  /**\r\n   * Sets the vertical position of the content container.\r\n   */\r\n  @Input()\r\n  public vPos: DropdownVerticalPosition = \"bottom\";\r\n\r\n  /**\r\n   * Sets the horizontal position of the content container.\r\n   */\r\n  @Input()\r\n  public hPos: DropdownHorizontalPosition = \"left\";\r\n  \r\n  /**\r\n   * Indicates whether the content container can be \"light dismissed\" by selecting outside the popover area\r\n   * (`auto`), or not (`manual`).\r\n   */\r\n  @Input()\r\n  public popoverState: PopoverState = \"auto\";\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected id!: string;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ViewChild(\"popover\")\r\n  private _popover!: ElementRef;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  constructor() {\r\n    super();\r\n    this.id = this.getID().toString();\r\n  }\r\n\r\n  /**\r\n   * Hides the dropdown container.\r\n   */\r\n  public hideContent(): void {\r\n    if (!this._popover) return;\r\n    this._popover.nativeElement.hidePopover();\r\n  }\r\n\r\n  /**\r\n   * Displays the dropdown container.\r\n   */\r\n  public showContent(): void {\r\n    if (!this._popover) return;\r\n    this._popover.nativeElement.showPopover();\r\n  }\r\n\r\n  /**\r\n   * Returns the display state of the dropdown.\r\n   * \r\n   * @returns Returns `true` whether the dropdown is opened; `false` otherwise.\r\n   */\r\n  public isOpened(): boolean {\r\n    if (!this._popover) return false;\r\n    return this._popover.nativeElement.matches(API_MATCH);\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected onBeforeToggle(event: Event): void {\r\n    this.beforeToggle.emit(\r\n      this.buildEvent(event as ToggleEvent, DropdownEventType.BEFORE_TOGGLE)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected onToggle(event: Event): void {\r\n    this.toggle.emit(\r\n      this.buildEvent(event as ToggleEvent, DropdownEventType.TOGGLE)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  private buildEvent(event: ToggleEvent, type: DropdownEventType): DropdownEvent {\r\n    return new DropdownEvent(this, type, event.newState as DropdownState, event.oldState as DropdownState);\r\n  }\r\n}\r\n","<!--\r\n * LICENSE\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n-->\r\n \r\n<div class=\"atx-dropdown-container\" [class]=\"containerClass\">\r\n    <button [class]=\"buttonClass\" [attr.popovertarget]=\"id\">\r\n        <ng-content></ng-content>\r\n    </button>\r\n    <div #popover [attr.popover]=\"popoverState\" [attr.id]=\"id\" (toggle)=\"onToggle($event)\" (beforetoggle)=\"onBeforeToggle($event)\"></div>\r\n    <div class=\"atx-dropdown-popover\"\r\n         [class.atx-dropdown-v-start]=\"vPos === 'start'\"\r\n         [class.atx-dropdown-top]=\"vPos === 'top'\"\r\n         [class.atx-dropdown-middle]=\"vPos === 'middle'\"\r\n         [class.atx-dropdown-bottom]=\"vPos === 'bottom'\"\r\n         [class.atx-dropdown-v-end]=\"vPos === 'end'\"\r\n         [class.atx-dropdown-h-start]=\"hPos === 'start'\"\r\n         [class.atx-dropdown-left]=\"hPos === 'left'\"\r\n         [class.atx-dropdown-center]=\"hPos === 'center'\"\r\n         [class.atx-dropdown-right]=\"hPos === 'right'\"\r\n         [class.atx-dropdown-h-end]=\"hPos === 'end'\"\r\n         [class.atx-dropdown-centered]=\"hPos === 'center' && vPos === 'middle'\">\r\n        <ng-content select=\"[content]\"></ng-content>\r\n    </div>\r\n</div>\r\n"]}
@@ -8,10 +8,8 @@
8
8
  import { HttpStatusCode } from "@angular/common/http";
9
9
  import { HttpHeadersUtil } from "./http-headers.util";
10
10
  import { HTTP_MOCK_MAX_DELAY } from "./http-mock-max-delay";
11
- /**
12
- * @private
13
- */
14
- const OK = "OK";
11
+ import { HttpStatusTextFinder } from "./http-status-text-finder";
12
+ import { EMPTY_STRING } from "../../../../util";
15
13
  /**
16
14
  * A statefull builder for creating new `HttpResponseMock` instances.
17
15
  */
@@ -24,7 +22,7 @@ export class HttpResponseMockBuilder {
24
22
  url: null,
25
23
  body: null,
26
24
  status: HttpStatusCode.Ok,
27
- statusText: OK,
25
+ statusText: EMPTY_STRING,
28
26
  error: null,
29
27
  delay: 0
30
28
  };
@@ -80,17 +78,6 @@ export class HttpResponseMockBuilder {
80
78
  this._response.status = status;
81
79
  return this;
82
80
  }
83
- /**
84
- * Sets the `statusText` property of the new `HttpResponseMock` instance with the specified `statusText` value.
85
- *
86
- * @param statusText The value used to set the `statusText` property of the new `HttpResponseMock` instance.
87
- *
88
- * @returns A reference to this `HttpResponseMockBuilder` instance.
89
- */
90
- statusText(statusText) {
91
- this._response.statusText = statusText;
92
- return this;
93
- }
94
81
  /**
95
82
  * Sets the `url` property of the new `HttpResponseMock` instance with the specified `url` value.
96
83
  *
@@ -141,6 +128,7 @@ export class HttpResponseMockBuilder {
141
128
  */
142
129
  response(error = null) {
143
130
  this._response.error = error;
131
+ this._response.statusText = HttpStatusTextFinder.getStatusText(this._response.status);
144
132
  return this._response;
145
133
  }
146
134
  }
@@ -150,4 +138,4 @@ export class HttpResponseMockBuilder {
150
138
  * @returns A new `HttpResponseMockBuilder` instance.
151
139
  */
152
140
  export const httpResponseMock = () => new HttpResponseMockBuilder();
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-mock-response.builder.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-toolbox/src/lib/framework/mock/http/util/http-mock-response.builder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be found in\r\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { HttpHeaders, HttpStatusCode } from \"@angular/common/http\";\r\nimport { HttpMockError, HttpResponseMock } from \"../../../../model\";\r\nimport { HttpHeadersUtil } from \"./http-headers.util\";\r\nimport { HTTP_MOCK_MAX_DELAY } from \"./http-mock-max-delay\";\r\n\r\n/**\r\n * @private\r\n */\r\nconst OK: string = \"OK\";\r\n\r\n/**\r\n * A statefull builder for creating new `HttpResponseMock` instances.\r\n */\r\nexport class HttpResponseMockBuilder {\r\n\r\n    /**\r\n     * @private\r\n     */\r\n    private _response: HttpResponseMock = {\r\n        url: null,\r\n        body: null,\r\n        status: HttpStatusCode.Ok,\r\n        statusText: OK,\r\n        error: null,\r\n        delay: 0\r\n    };\r\n\r\n    /**\r\n     * Sets the body property of the new `HttpResponseMock` instance with the specified `body` value.\r\n     * \r\n     * @param body The value used to set the body property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public body(body: any): HttpResponseMockBuilder {\r\n        this._response.body = body;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the headers property of the new `HttpResponseMock` instance with the specified `headers` value.\r\n     * \r\n     * @param headers The value used to set the `headers` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public headers(headers: HttpHeaders): HttpResponseMockBuilder {\r\n        this._response.headers = headers;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Add the list of HTTP headers generated by the `HttpHeadersUtil.createDefaultRequestHeaders()`\r\n     * to the mock response.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public defaultHeaders(): HttpResponseMockBuilder {\r\n        const defaultHeaders: HttpHeaders = HttpHeadersUtil.createDefaultRequestHeaders();\r\n        let headers: HttpHeaders | undefined = this._response.headers;\r\n        if (headers) {\r\n            const keys: string[] = defaultHeaders.keys();\r\n            keys.forEach(key=> headers?.append(key, defaultHeaders.get(key) as any))\r\n        } else headers = defaultHeaders;\r\n        this._response.headers = headers;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `status` property of the new `HttpResponseMock` instance with the specified `status` value.\r\n     * \r\n     * @param status The value used to set the `status` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public status(status: number): HttpResponseMockBuilder {\r\n        this._response.status = status;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `statusText` property of the new `HttpResponseMock` instance with the specified `statusText` value.\r\n     * \r\n     * @param statusText The value used to set the `statusText` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public statusText(statusText: string): HttpResponseMockBuilder {\r\n        this._response.statusText = statusText;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `url` property of the new `HttpResponseMock` instance with the specified `url` value.\r\n     * \r\n     * @param url The value used to set the `url` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public url(url: string | null): HttpResponseMockBuilder {\r\n        this._response.url = url;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `delay` property of the new `HttpResponseMock` instance with the specified `timer` duration.\r\n     * Maximum value is `10000` miliseconds (10 seconds).\r\n     * \r\n     * @param timer The value used to set the `delay` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public delay(timer?: number): HttpResponseMockBuilder;\r\n    \r\n    /**\r\n     * Sets the `delay` property of the new `HttpResponseMock` instance with the specified `timer` duration.\r\n     * Maximum value is `10000` miliseconds (10 seconds).\r\n     * \r\n     * @param timer The value used to set the `delay` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public delay(min?: number, max?: number): HttpResponseMockBuilder;\r\n\r\n    /**\r\n     * @private\r\n     * Overload implementation \r\n     */\r\n    public delay(...arg: any): HttpResponseMockBuilder {\r\n        if (arg.length <= 1) {\r\n            let timer: number = arg[0] || NaN;\r\n            if (isNaN(timer)) {\r\n                this._response.delay = HTTP_MOCK_MAX_DELAY - Math.random() * HTTP_MOCK_MAX_DELAY;\r\n                return this;\r\n            }\r\n            if (timer > HTTP_MOCK_MAX_DELAY) {\r\n                this._response.delay = HTTP_MOCK_MAX_DELAY;\r\n                return this;\r\n            }\r\n            if (timer < 0) timer = 0;\r\n            this._response.delay = timer;\r\n            return this;\r\n        }\r\n        let min: number = arg[0], max: number = arg[1];\r\n        if (max > HTTP_MOCK_MAX_DELAY) max = HTTP_MOCK_MAX_DELAY;\r\n        if (min < 0 || min > max) min = 0;\r\n        this._response.delay = Math.floor(Math.random() * (max - min) + min);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Returns a new `HttpResponseMock` instance, built from the properties specified with the\r\n     * `HttpResponseMockBuilder` methods.\r\n     * \r\n     * @param error An optional value used to set the `error` property of the new `HttpResponseMock` instance.\r\n     *              The `error` parameter values take precedence over all other properties of the `HttpResponseMock`\r\n     *              instance.\r\n     * @returns A new `HttpResponseMock` instance.\r\n     */\r\n    public response(error: HttpMockError | null = null): HttpResponseMock {\r\n        this._response.error = error;\r\n        return this._response;\r\n    }\r\n}\r\n\r\n/**\r\n * A utility function used to create new \"chainable\" `HttpResponseMockBuilder` instances.\r\n * \r\n * @returns A new `HttpResponseMockBuilder` instance.\r\n */\r\nexport const httpResponseMock:()=> HttpResponseMockBuilder = ()=> new HttpResponseMockBuilder();"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-mock-response.builder.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-toolbox/src/lib/framework/mock/http/util/http-mock-response.builder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be found in\r\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { HttpHeaders, HttpStatusCode } from \"@angular/common/http\";\r\nimport { HttpMockError, HttpResponseMock } from \"../../../../model\";\r\nimport { HttpHeadersUtil } from \"./http-headers.util\";\r\nimport { HTTP_MOCK_MAX_DELAY } from \"./http-mock-max-delay\";\r\nimport { HttpStatusTextFinder } from \"./http-status-text-finder\";\r\nimport { EMPTY_STRING } from \"../../../../util\";\r\n\r\n/**\r\n * A statefull builder for creating new `HttpResponseMock` instances.\r\n */\r\nexport class HttpResponseMockBuilder {\r\n\r\n    /**\r\n     * @private\r\n     */\r\n    private _response: HttpResponseMock = {\r\n        url: null,\r\n        body: null,\r\n        status: HttpStatusCode.Ok,\r\n        statusText: EMPTY_STRING,\r\n        error: null,\r\n        delay: 0\r\n    };\r\n\r\n    /**\r\n     * Sets the body property of the new `HttpResponseMock` instance with the specified `body` value.\r\n     * \r\n     * @param body The value used to set the body property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public body(body: any): HttpResponseMockBuilder {\r\n        this._response.body = body;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the headers property of the new `HttpResponseMock` instance with the specified `headers` value.\r\n     * \r\n     * @param headers The value used to set the `headers` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public headers(headers: HttpHeaders): HttpResponseMockBuilder {\r\n        this._response.headers = headers;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Add the list of HTTP headers generated by the `HttpHeadersUtil.createDefaultRequestHeaders()`\r\n     * to the mock response.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public defaultHeaders(): HttpResponseMockBuilder {\r\n        const defaultHeaders: HttpHeaders = HttpHeadersUtil.createDefaultRequestHeaders();\r\n        let headers: HttpHeaders | undefined = this._response.headers;\r\n        if (headers) {\r\n            const keys: string[] = defaultHeaders.keys();\r\n            keys.forEach(key=> headers?.append(key, defaultHeaders.get(key) as any))\r\n        } else headers = defaultHeaders;\r\n        this._response.headers = headers;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `status` property of the new `HttpResponseMock` instance with the specified `status` value.\r\n     * \r\n     * @param status The value used to set the `status` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public status(status: number): HttpResponseMockBuilder {\r\n        this._response.status = status;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `url` property of the new `HttpResponseMock` instance with the specified `url` value.\r\n     * \r\n     * @param url The value used to set the `url` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public url(url: string | null): HttpResponseMockBuilder {\r\n        this._response.url = url;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Sets the `delay` property of the new `HttpResponseMock` instance with the specified `timer` duration.\r\n     * Maximum value is `10000` miliseconds (10 seconds).\r\n     * \r\n     * @param timer The value used to set the `delay` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public delay(timer?: number): HttpResponseMockBuilder;\r\n    \r\n    /**\r\n     * Sets the `delay` property of the new `HttpResponseMock` instance with the specified `timer` duration.\r\n     * Maximum value is `10000` miliseconds (10 seconds).\r\n     * \r\n     * @param timer The value used to set the `delay` property of the new `HttpResponseMock` instance.\r\n     * \r\n     * @returns A reference to this `HttpResponseMockBuilder` instance.\r\n     */\r\n    public delay(min?: number, max?: number): HttpResponseMockBuilder;\r\n\r\n    /**\r\n     * @private\r\n     * Overload implementation \r\n     */\r\n    public delay(...arg: any): HttpResponseMockBuilder {\r\n        if (arg.length <= 1) {\r\n            let timer: number = arg[0] || NaN;\r\n            if (isNaN(timer)) {\r\n                this._response.delay = HTTP_MOCK_MAX_DELAY - Math.random() * HTTP_MOCK_MAX_DELAY;\r\n                return this;\r\n            }\r\n            if (timer > HTTP_MOCK_MAX_DELAY) {\r\n                this._response.delay = HTTP_MOCK_MAX_DELAY;\r\n                return this;\r\n            }\r\n            if (timer < 0) timer = 0;\r\n            this._response.delay = timer;\r\n            return this;\r\n        }\r\n        let min: number = arg[0], max: number = arg[1];\r\n        if (max > HTTP_MOCK_MAX_DELAY) max = HTTP_MOCK_MAX_DELAY;\r\n        if (min < 0 || min > max) min = 0;\r\n        this._response.delay = Math.floor(Math.random() * (max - min) + min);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * Returns a new `HttpResponseMock` instance, built from the properties specified with the\r\n     * `HttpResponseMockBuilder` methods.\r\n     * \r\n     * @param error An optional value used to set the `error` property of the new `HttpResponseMock` instance.\r\n     *              The `error` parameter values take precedence over all other properties of the `HttpResponseMock`\r\n     *              instance.\r\n     * @returns A new `HttpResponseMock` instance.\r\n     */\r\n    public response(error: HttpMockError | null = null): HttpResponseMock {\r\n        this._response.error = error;\r\n        this._response.statusText = HttpStatusTextFinder.getStatusText(this._response.status);\r\n        return this._response;\r\n    }\r\n}\r\n\r\n/**\r\n * A utility function used to create new \"chainable\" `HttpResponseMockBuilder` instances.\r\n * \r\n * @returns A new `HttpResponseMockBuilder` instance.\r\n */\r\nexport const httpResponseMock:()=> HttpResponseMockBuilder = ()=> new HttpResponseMockBuilder();"]}
@@ -0,0 +1,146 @@
1
+ /**
2
+ * @license
3
+ * Copyright Pascal ECHEMANN. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be found in
6
+ * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license
7
+ */
8
+ import { HttpStatusCode } from "@angular/common/http";
9
+ import { HttpStatusText } from "./http-status-text.enum";
10
+ /**
11
+ * @private
12
+ * A utility class that helps to retreive a status text depending on its status code.
13
+ */
14
+ export class HttpStatusTextFinder {
15
+ /**
16
+ * @private
17
+ * Retreives and return a status text depending on its status code.
18
+ *
19
+ * @param code The status code for which to find the status text.
20
+ * @returns A `HttpStatusText` constant.
21
+ */
22
+ static getStatusText(code) {
23
+ if (code === HttpStatusCode.Continue)
24
+ return HttpStatusText.CONTINUE;
25
+ if (code === HttpStatusCode.SwitchingProtocols)
26
+ return HttpStatusText.SWITCHING_PROTOCOLS;
27
+ if (code === HttpStatusCode.Processing)
28
+ return HttpStatusText.PROCESSING;
29
+ if (code === HttpStatusCode.EarlyHints)
30
+ return HttpStatusText.EARLY_HINTS;
31
+ if (code === HttpStatusCode.Ok)
32
+ return HttpStatusText.OK;
33
+ if (code === HttpStatusCode.Created)
34
+ return HttpStatusText.CREATED;
35
+ if (code === HttpStatusCode.Accepted)
36
+ return HttpStatusText.ACCEPTED;
37
+ if (code === HttpStatusCode.NonAuthoritativeInformation)
38
+ return HttpStatusText.NON_AUTHORITATIVE_INFORMATION;
39
+ if (code === HttpStatusCode.NoContent)
40
+ return HttpStatusText.NO_CONTENT;
41
+ if (code === HttpStatusCode.ResetContent)
42
+ return HttpStatusText.RESET_CONTENT;
43
+ if (code === HttpStatusCode.PartialContent)
44
+ return HttpStatusText.PARTIAL_CONTENT;
45
+ if (code === HttpStatusCode.MultiStatus)
46
+ return HttpStatusText.MULTI_STATUS;
47
+ if (code === HttpStatusCode.AlreadyReported)
48
+ return HttpStatusText.ALREADY_REPORTED;
49
+ if (code === HttpStatusCode.ImUsed)
50
+ return HttpStatusText.IM_USED;
51
+ if (code === HttpStatusCode.MultipleChoices)
52
+ return HttpStatusText.MULTIPLE_CHOICES;
53
+ if (code === HttpStatusCode.MovedPermanently)
54
+ return HttpStatusText.MOVED_PERMANENTLY;
55
+ if (code === HttpStatusCode.Found)
56
+ return HttpStatusText.FOUND;
57
+ if (code === HttpStatusCode.SeeOther)
58
+ return HttpStatusText.SEE_OTHER;
59
+ if (code === HttpStatusCode.NotModified)
60
+ return HttpStatusText.NOT_MODIFIED;
61
+ if (code === HttpStatusCode.TemporaryRedirect)
62
+ return HttpStatusText.TEMPORARY_REDIRECT;
63
+ if (code === HttpStatusCode.PermanentRedirect)
64
+ return HttpStatusText.PERMANENT_REDIRECT;
65
+ if (code === HttpStatusCode.BadRequest)
66
+ return HttpStatusText.BAD_REQUEST;
67
+ if (code === HttpStatusCode.Unauthorized)
68
+ return HttpStatusText.UNAUTHORIZED;
69
+ if (code === HttpStatusCode.PaymentRequired)
70
+ return HttpStatusText.PAYMENT_REQUIRED;
71
+ if (code === HttpStatusCode.Forbidden)
72
+ return HttpStatusText.FORBIDDEN;
73
+ if (code === HttpStatusCode.NotFound)
74
+ return HttpStatusText.NOT_FOUND;
75
+ if (code === HttpStatusCode.MethodNotAllowed)
76
+ return HttpStatusText.METHOD_NOT_ALLOWED;
77
+ if (code === HttpStatusCode.NotAcceptable)
78
+ return HttpStatusText.NOT_ACCEPTABLE;
79
+ if (code === HttpStatusCode.ProxyAuthenticationRequired)
80
+ return HttpStatusText.PROXY_AUTHENTICATION_REQUIRED;
81
+ if (code === HttpStatusCode.RequestTimeout)
82
+ return HttpStatusText.REQUEST_TIMEOUT;
83
+ if (code === HttpStatusCode.Conflict)
84
+ return HttpStatusText.CONFLICT;
85
+ if (code === HttpStatusCode.Gone)
86
+ return HttpStatusText.GONE;
87
+ if (code === HttpStatusCode.LengthRequired)
88
+ return HttpStatusText.LENGTH_REQUIRED;
89
+ if (code === HttpStatusCode.PreconditionFailed)
90
+ return HttpStatusText.PRECONDITION_FAILED;
91
+ if (code === HttpStatusCode.PayloadTooLarge)
92
+ return HttpStatusText.PAYLOAD_TOO_LARGE;
93
+ if (code === HttpStatusCode.UriTooLong)
94
+ return HttpStatusText.URI_TOO_LONG;
95
+ if (code === HttpStatusCode.UnsupportedMediaType)
96
+ return HttpStatusText.UNSUPPORTED_MEDIA_TYPE;
97
+ if (code === HttpStatusCode.RangeNotSatisfiable)
98
+ return HttpStatusText.RANGE_NOT_SATISFIABLE;
99
+ if (code === HttpStatusCode.ExpectationFailed)
100
+ return HttpStatusText.EXPECTATION_FAILED;
101
+ if (code === HttpStatusCode.ImATeapot)
102
+ return HttpStatusText.I_M_A_TEAPOT;
103
+ if (code === HttpStatusCode.MisdirectedRequest)
104
+ return HttpStatusText.MISDIRECTED_REQUEST;
105
+ if (code === HttpStatusCode.UnprocessableEntity)
106
+ return HttpStatusText.UNPROCESSABLE_ENTITY;
107
+ if (code === HttpStatusCode.Locked)
108
+ return HttpStatusText.LOCKED;
109
+ if (code === HttpStatusCode.FailedDependency)
110
+ return HttpStatusText.FAILED_DEPENDENCY;
111
+ if (code === HttpStatusCode.UpgradeRequired)
112
+ return HttpStatusText.UPGRADE_REQUIRED;
113
+ if (code === HttpStatusCode.PreconditionRequired)
114
+ return HttpStatusText.PRECONDITION_REQUIRED;
115
+ if (code === HttpStatusCode.TooManyRequests)
116
+ return HttpStatusText.TOO_MANY_REQUESTS;
117
+ if (code === HttpStatusCode.RequestHeaderFieldsTooLarge)
118
+ return HttpStatusText.REQUEST_HEADER_FIELDS_TOO_LARGE;
119
+ if (code === HttpStatusCode.UnavailableForLegalReasons)
120
+ return HttpStatusText.UNAVAILABLE_FOR_LEGAL_REASONS;
121
+ if (code === HttpStatusCode.InternalServerError)
122
+ return HttpStatusText.INTERNAL_SERVER_ERROR;
123
+ if (code === HttpStatusCode.NotImplemented)
124
+ return HttpStatusText.NOT_IMPLEMENTED;
125
+ if (code === HttpStatusCode.BadGateway)
126
+ return HttpStatusText.BAD_GATEWAY;
127
+ if (code === HttpStatusCode.ServiceUnavailable)
128
+ return HttpStatusText.SERVICE_UNAVAILABLE;
129
+ if (code === HttpStatusCode.GatewayTimeout)
130
+ return HttpStatusText.GATEWAY_TIMEOUT;
131
+ if (code === HttpStatusCode.HttpVersionNotSupported)
132
+ return HttpStatusText.HTTP_VERSION_NOT_SUPPORTED;
133
+ if (code === HttpStatusCode.VariantAlsoNegotiates)
134
+ return HttpStatusText.VARIANT_ALSO_NEGOTIATES;
135
+ if (code === HttpStatusCode.InsufficientStorage)
136
+ return HttpStatusText.INSUFFICIENT_STORAGE;
137
+ if (code === HttpStatusCode.LoopDetected)
138
+ return HttpStatusText.LOOP_DETECTED;
139
+ if (code === HttpStatusCode.NotExtended)
140
+ return HttpStatusText.NOT_EXTENDED;
141
+ if (code === HttpStatusCode.NetworkAuthenticationRequired)
142
+ return HttpStatusText.NETWORK_AUTHENTICATION_REQUIRED;
143
+ return HttpStatusText.INTERNAL_SERVER_ERROR;
144
+ }
145
+ }
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-status-text-finder.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-toolbox/src/lib/framework/mock/http/util/http-status-text-finder.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD;;;GAGG;AACH,MAAM,OAAO,oBAAoB;IAE7B;;;;;;OAMG;IACI,MAAM,CAAC,aAAa,CAAC,IAAoB;QAC5C,IAAG,IAAI,KAAK,cAAc,CAAC,QAAQ;YAAE,OAAO,cAAc,CAAC,QAAQ,CAAC;QACpE,IAAG,IAAI,KAAK,cAAc,CAAC,kBAAkB;YAAE,OAAO,cAAc,CAAC,mBAAmB,CAAC;QACzF,IAAG,IAAI,KAAK,cAAc,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,UAAU,CAAC;QACxE,IAAG,IAAI,KAAK,cAAc,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,WAAW,CAAC;QACzE,IAAG,IAAI,KAAK,cAAc,CAAC,EAAE;YAAE,OAAO,cAAc,CAAC,EAAE,CAAC;QACxD,IAAG,IAAI,KAAK,cAAc,CAAC,OAAO;YAAE,OAAO,cAAc,CAAC,OAAO,CAAC;QAClE,IAAG,IAAI,KAAK,cAAc,CAAC,QAAQ;YAAE,OAAO,cAAc,CAAC,QAAQ,CAAC;QACpE,IAAG,IAAI,KAAK,cAAc,CAAC,2BAA2B;YAAE,OAAO,cAAc,CAAC,6BAA6B,CAAC;QAC5G,IAAG,IAAI,KAAK,cAAc,CAAC,SAAS;YAAE,OAAO,cAAc,CAAC,UAAU,CAAC;QACvE,IAAG,IAAI,KAAK,cAAc,CAAC,YAAY;YAAE,OAAO,cAAc,CAAC,aAAa,CAAC;QAC7E,IAAG,IAAI,KAAK,cAAc,CAAC,cAAc;YAAE,OAAO,cAAc,CAAC,eAAe,CAAC;QACjF,IAAG,IAAI,KAAK,cAAc,CAAC,WAAW;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QAC3E,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,gBAAgB,CAAC;QACnF,IAAG,IAAI,KAAK,cAAc,CAAC,MAAM;YAAE,OAAO,cAAc,CAAC,OAAO,CAAC;QACjE,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,gBAAgB,CAAC;QACnF,IAAG,IAAI,KAAK,cAAc,CAAC,gBAAgB;YAAE,OAAO,cAAc,CAAC,iBAAiB,CAAC;QACrF,IAAG,IAAI,KAAK,cAAc,CAAC,KAAK;YAAE,OAAO,cAAc,CAAC,KAAK,CAAC;QAC9D,IAAG,IAAI,KAAK,cAAc,CAAC,QAAQ;YAAE,OAAO,cAAc,CAAC,SAAS,CAAC;QACrE,IAAG,IAAI,KAAK,cAAc,CAAC,WAAW;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QAC3E,IAAG,IAAI,KAAK,cAAc,CAAC,iBAAiB;YAAE,OAAO,cAAc,CAAC,kBAAkB,CAAC;QACvF,IAAG,IAAI,KAAK,cAAc,CAAC,iBAAiB;YAAE,OAAO,cAAc,CAAC,kBAAkB,CAAC;QACvF,IAAG,IAAI,KAAK,cAAc,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,WAAW,CAAC;QACzE,IAAG,IAAI,KAAK,cAAc,CAAC,YAAY;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QAC5E,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,gBAAgB,CAAC;QACnF,IAAG,IAAI,KAAK,cAAc,CAAC,SAAS;YAAE,OAAO,cAAc,CAAC,SAAS,CAAC;QACtE,IAAG,IAAI,KAAK,cAAc,CAAC,QAAQ;YAAE,OAAO,cAAc,CAAC,SAAS,CAAC;QACrE,IAAG,IAAI,KAAK,cAAc,CAAC,gBAAgB;YAAE,OAAO,cAAc,CAAC,kBAAkB,CAAC;QACtF,IAAG,IAAI,KAAK,cAAc,CAAC,aAAa;YAAE,OAAO,cAAc,CAAC,cAAc,CAAC;QAC/E,IAAG,IAAI,KAAK,cAAc,CAAC,2BAA2B;YAAE,OAAO,cAAc,CAAC,6BAA6B,CAAC;QAC5G,IAAG,IAAI,KAAK,cAAc,CAAC,cAAc;YAAE,OAAO,cAAc,CAAC,eAAe,CAAC;QACjF,IAAG,IAAI,KAAK,cAAc,CAAC,QAAQ;YAAE,OAAO,cAAc,CAAC,QAAQ,CAAC;QACpE,IAAG,IAAI,KAAK,cAAc,CAAC,IAAI;YAAE,OAAO,cAAc,CAAC,IAAI,CAAC;QAC5D,IAAG,IAAI,KAAK,cAAc,CAAC,cAAc;YAAE,OAAO,cAAc,CAAC,eAAe,CAAC;QACjF,IAAG,IAAI,KAAK,cAAc,CAAC,kBAAkB;YAAE,OAAO,cAAc,CAAC,mBAAmB,CAAC;QACzF,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,iBAAiB,CAAC;QACpF,IAAG,IAAI,KAAK,cAAc,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QAC1E,IAAG,IAAI,KAAK,cAAc,CAAC,oBAAoB;YAAE,OAAO,cAAc,CAAC,sBAAsB,CAAC;QAC9F,IAAG,IAAI,KAAK,cAAc,CAAC,mBAAmB;YAAE,OAAO,cAAc,CAAC,qBAAqB,CAAC;QAC5F,IAAG,IAAI,KAAK,cAAc,CAAC,iBAAiB;YAAE,OAAO,cAAc,CAAC,kBAAkB,CAAC;QACvF,IAAG,IAAI,KAAK,cAAc,CAAC,SAAS;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QACzE,IAAG,IAAI,KAAK,cAAc,CAAC,kBAAkB;YAAE,OAAO,cAAc,CAAC,mBAAmB,CAAC;QACzF,IAAG,IAAI,KAAK,cAAc,CAAC,mBAAmB;YAAE,OAAO,cAAc,CAAC,oBAAoB,CAAC;QAC3F,IAAG,IAAI,KAAK,cAAc,CAAC,MAAM;YAAE,OAAO,cAAc,CAAC,MAAM,CAAC;QAChE,IAAG,IAAI,KAAK,cAAc,CAAC,gBAAgB;YAAE,OAAO,cAAc,CAAC,iBAAiB,CAAC;QACrF,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,gBAAgB,CAAC;QACnF,IAAG,IAAI,KAAK,cAAc,CAAC,oBAAoB;YAAE,OAAO,cAAc,CAAC,qBAAqB,CAAC;QAC7F,IAAG,IAAI,KAAK,cAAc,CAAC,eAAe;YAAE,OAAO,cAAc,CAAC,iBAAiB,CAAC;QACpF,IAAG,IAAI,KAAK,cAAc,CAAC,2BAA2B;YAAE,OAAO,cAAc,CAAC,+BAA+B,CAAC;QAC9G,IAAG,IAAI,KAAK,cAAc,CAAC,0BAA0B;YAAE,OAAO,cAAc,CAAC,6BAA6B,CAAC;QAC3G,IAAG,IAAI,KAAK,cAAc,CAAC,mBAAmB;YAAE,OAAO,cAAc,CAAC,qBAAqB,CAAC;QAC5F,IAAG,IAAI,KAAK,cAAc,CAAC,cAAc;YAAE,OAAO,cAAc,CAAC,eAAe,CAAC;QACjF,IAAG,IAAI,KAAK,cAAc,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,WAAW,CAAC;QACzE,IAAG,IAAI,KAAK,cAAc,CAAC,kBAAkB;YAAE,OAAO,cAAc,CAAC,mBAAmB,CAAC;QACzF,IAAG,IAAI,KAAK,cAAc,CAAC,cAAc;YAAE,OAAO,cAAc,CAAC,eAAe,CAAC;QACjF,IAAG,IAAI,KAAK,cAAc,CAAC,uBAAuB;YAAE,OAAO,cAAc,CAAC,0BAA0B,CAAC;QACrG,IAAG,IAAI,KAAK,cAAc,CAAC,qBAAqB;YAAE,OAAO,cAAc,CAAC,uBAAuB,CAAC;QAChG,IAAG,IAAI,KAAK,cAAc,CAAC,mBAAmB;YAAE,OAAO,cAAc,CAAC,oBAAoB,CAAC;QAC3F,IAAG,IAAI,KAAK,cAAc,CAAC,YAAY;YAAE,OAAO,cAAc,CAAC,aAAa,CAAC;QAC7E,IAAG,IAAI,KAAK,cAAc,CAAC,WAAW;YAAE,OAAO,cAAc,CAAC,YAAY,CAAC;QAC3E,IAAG,IAAI,KAAK,cAAc,CAAC,6BAA6B;YAAE,OAAO,cAAc,CAAC,+BAA+B,CAAC;QAChH,OAAO,cAAc,CAAC,qBAAqB,CAAC;IAChD,CAAC;CACJ","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be found in\r\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { HttpStatusCode } from \"@angular/common/http\";\r\nimport { HttpStatusText } from \"./http-status-text.enum\";\r\n\r\n/**\r\n * @private\r\n * A utility class that helps to retreive a status text depending on its status code.\r\n */\r\nexport class HttpStatusTextFinder {\r\n\r\n    /**\r\n     * @private\r\n     * Retreives and return a status text depending on its status code.\r\n     * \r\n     * @param code The status code for which to find the status text.\r\n     * @returns A `HttpStatusText` constant.\r\n     */\r\n    public static getStatusText(code: HttpStatusCode): HttpStatusText {\r\n        if(code === HttpStatusCode.Continue) return HttpStatusText.CONTINUE;\r\n        if(code === HttpStatusCode.SwitchingProtocols) return HttpStatusText.SWITCHING_PROTOCOLS;\r\n        if(code === HttpStatusCode.Processing) return HttpStatusText.PROCESSING;\r\n        if(code === HttpStatusCode.EarlyHints) return HttpStatusText.EARLY_HINTS;\r\n        if(code === HttpStatusCode.Ok) return HttpStatusText.OK;\r\n        if(code === HttpStatusCode.Created) return HttpStatusText.CREATED;\r\n        if(code === HttpStatusCode.Accepted) return HttpStatusText.ACCEPTED;\r\n        if(code === HttpStatusCode.NonAuthoritativeInformation) return HttpStatusText.NON_AUTHORITATIVE_INFORMATION;\r\n        if(code === HttpStatusCode.NoContent) return HttpStatusText.NO_CONTENT;\r\n        if(code === HttpStatusCode.ResetContent) return HttpStatusText.RESET_CONTENT;\r\n        if(code === HttpStatusCode.PartialContent) return HttpStatusText.PARTIAL_CONTENT;\r\n        if(code === HttpStatusCode.MultiStatus) return HttpStatusText.MULTI_STATUS;\r\n        if(code === HttpStatusCode.AlreadyReported) return HttpStatusText.ALREADY_REPORTED;\r\n        if(code === HttpStatusCode.ImUsed) return HttpStatusText.IM_USED;\r\n        if(code === HttpStatusCode.MultipleChoices) return HttpStatusText.MULTIPLE_CHOICES;\r\n        if(code === HttpStatusCode.MovedPermanently) return HttpStatusText.MOVED_PERMANENTLY;\r\n        if(code === HttpStatusCode.Found) return HttpStatusText.FOUND;\r\n        if(code === HttpStatusCode.SeeOther) return HttpStatusText.SEE_OTHER;\r\n        if(code === HttpStatusCode.NotModified) return HttpStatusText.NOT_MODIFIED;\r\n        if(code === HttpStatusCode.TemporaryRedirect) return HttpStatusText.TEMPORARY_REDIRECT;\r\n        if(code === HttpStatusCode.PermanentRedirect) return HttpStatusText.PERMANENT_REDIRECT;\r\n        if(code === HttpStatusCode.BadRequest) return HttpStatusText.BAD_REQUEST;\r\n        if(code === HttpStatusCode.Unauthorized) return HttpStatusText.UNAUTHORIZED;\r\n        if(code === HttpStatusCode.PaymentRequired) return HttpStatusText.PAYMENT_REQUIRED;\r\n        if(code === HttpStatusCode.Forbidden) return HttpStatusText.FORBIDDEN;\r\n        if(code === HttpStatusCode.NotFound) return HttpStatusText.NOT_FOUND;\r\n        if(code === HttpStatusCode.MethodNotAllowed) return HttpStatusText.METHOD_NOT_ALLOWED;\r\n        if(code === HttpStatusCode.NotAcceptable) return HttpStatusText.NOT_ACCEPTABLE;\r\n        if(code === HttpStatusCode.ProxyAuthenticationRequired) return HttpStatusText.PROXY_AUTHENTICATION_REQUIRED;\r\n        if(code === HttpStatusCode.RequestTimeout) return HttpStatusText.REQUEST_TIMEOUT;\r\n        if(code === HttpStatusCode.Conflict) return HttpStatusText.CONFLICT;\r\n        if(code === HttpStatusCode.Gone) return HttpStatusText.GONE;\r\n        if(code === HttpStatusCode.LengthRequired) return HttpStatusText.LENGTH_REQUIRED;\r\n        if(code === HttpStatusCode.PreconditionFailed) return HttpStatusText.PRECONDITION_FAILED;\r\n        if(code === HttpStatusCode.PayloadTooLarge) return HttpStatusText.PAYLOAD_TOO_LARGE;\r\n        if(code === HttpStatusCode.UriTooLong) return HttpStatusText.URI_TOO_LONG;\r\n        if(code === HttpStatusCode.UnsupportedMediaType) return HttpStatusText.UNSUPPORTED_MEDIA_TYPE;\r\n        if(code === HttpStatusCode.RangeNotSatisfiable) return HttpStatusText.RANGE_NOT_SATISFIABLE;\r\n        if(code === HttpStatusCode.ExpectationFailed) return HttpStatusText.EXPECTATION_FAILED;\r\n        if(code === HttpStatusCode.ImATeapot) return HttpStatusText.I_M_A_TEAPOT;\r\n        if(code === HttpStatusCode.MisdirectedRequest) return HttpStatusText.MISDIRECTED_REQUEST;\r\n        if(code === HttpStatusCode.UnprocessableEntity) return HttpStatusText.UNPROCESSABLE_ENTITY;\r\n        if(code === HttpStatusCode.Locked) return HttpStatusText.LOCKED;\r\n        if(code === HttpStatusCode.FailedDependency) return HttpStatusText.FAILED_DEPENDENCY;\r\n        if(code === HttpStatusCode.UpgradeRequired) return HttpStatusText.UPGRADE_REQUIRED;\r\n        if(code === HttpStatusCode.PreconditionRequired) return HttpStatusText.PRECONDITION_REQUIRED;\r\n        if(code === HttpStatusCode.TooManyRequests) return HttpStatusText.TOO_MANY_REQUESTS;\r\n        if(code === HttpStatusCode.RequestHeaderFieldsTooLarge) return HttpStatusText.REQUEST_HEADER_FIELDS_TOO_LARGE;\r\n        if(code === HttpStatusCode.UnavailableForLegalReasons) return HttpStatusText.UNAVAILABLE_FOR_LEGAL_REASONS;\r\n        if(code === HttpStatusCode.InternalServerError) return HttpStatusText.INTERNAL_SERVER_ERROR;\r\n        if(code === HttpStatusCode.NotImplemented) return HttpStatusText.NOT_IMPLEMENTED;\r\n        if(code === HttpStatusCode.BadGateway) return HttpStatusText.BAD_GATEWAY;\r\n        if(code === HttpStatusCode.ServiceUnavailable) return HttpStatusText.SERVICE_UNAVAILABLE;\r\n        if(code === HttpStatusCode.GatewayTimeout) return HttpStatusText.GATEWAY_TIMEOUT;\r\n        if(code === HttpStatusCode.HttpVersionNotSupported) return HttpStatusText.HTTP_VERSION_NOT_SUPPORTED;\r\n        if(code === HttpStatusCode.VariantAlsoNegotiates) return HttpStatusText.VARIANT_ALSO_NEGOTIATES;\r\n        if(code === HttpStatusCode.InsufficientStorage) return HttpStatusText.INSUFFICIENT_STORAGE;\r\n        if(code === HttpStatusCode.LoopDetected) return HttpStatusText.LOOP_DETECTED;\r\n        if(code === HttpStatusCode.NotExtended) return HttpStatusText.NOT_EXTENDED;\r\n        if(code === HttpStatusCode.NetworkAuthenticationRequired) return HttpStatusText.NETWORK_AUTHENTICATION_REQUIRED;\r\n        return HttpStatusText.INTERNAL_SERVER_ERROR;\r\n    }\r\n}"]}