angular-toolbox 1.4.2 → 1.4.4

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.4.2%231E90FF.svg)]()
5
+ [![Angular Toolbox version](https://img.shields.io/badge/Angular%20Toolbox:1.4.4%231E90FF.svg)]()
6
6
 
7
7
  ## License
8
8
 
@@ -19,6 +19,18 @@ const API_MATCH = ':popover-open';
19
19
  * This component is part of the LAF-less API.
20
20
  */
21
21
  export class DropdownComponent extends IdentifiableComponent {
22
+ /**
23
+ * The disabled property sets or returns whether a dropdown is disabled, or not.
24
+ */
25
+ set disabled(value) {
26
+ this._disabled = this._button.nativeElement.disabled = value;
27
+ if (!value)
28
+ return;
29
+ this.hideContent();
30
+ }
31
+ get disabled() {
32
+ return this._disabled;
33
+ }
22
34
  /**
23
35
  * @private
24
36
  */
@@ -45,6 +57,10 @@ export class DropdownComponent extends IdentifiableComponent {
45
57
  * (`auto`), or not (`manual`).
46
58
  */
47
59
  this.popoverState = "auto";
60
+ /**
61
+ * @private
62
+ */
63
+ this._disabled = false;
48
64
  this.id = this.getID().toString();
49
65
  }
50
66
  /**
@@ -59,7 +75,7 @@ export class DropdownComponent extends IdentifiableComponent {
59
75
  * Displays the dropdown container.
60
76
  */
61
77
  showContent() {
62
- if (!this._popover)
78
+ if (!this._popover || this._disabled)
63
79
  return;
64
80
  this._popover.nativeElement.showPopover();
65
81
  }
@@ -92,11 +108,11 @@ export class DropdownComponent extends IdentifiableComponent {
92
108
  return new DropdownEvent(this, type, event.newState, event.oldState);
93
109
  }
94
110
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
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"] }); }
111
+ 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", disabled: "disabled" }, outputs: { toggle: "toggle", beforeToggle: "beforeToggle" }, viewQueries: [{ propertyName: "_popover", first: true, predicate: ["popover"], descendants: true }, { propertyName: "_button", first: true, predicate: ["button"], 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 #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"] }); }
96
112
  }
97
113
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DropdownComponent, decorators: [{
98
114
  type: Component,
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"] }]
115
+ 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 #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"] }]
100
116
  }], ctorParameters: () => [], propDecorators: { toggle: [{
101
117
  type: Output
102
118
  }], beforeToggle: [{
@@ -111,8 +127,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
111
127
  type: Input
112
128
  }], popoverState: [{
113
129
  type: Input
130
+ }], disabled: [{
131
+ type: Input
114
132
  }], _popover: [{
115
133
  type: ViewChild,
116
134
  args: ["popover"]
135
+ }], _button: [{
136
+ type: ViewChild,
137
+ args: ["button"]
117
138
  }] } });
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"]}
139
+ //# 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":"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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\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   * The disabled property sets or returns whether a dropdown is disabled, or not.\r\n   */\r\n  @Input()\r\n  public set disabled(value: boolean) {\r\n    this._disabled = this._button.nativeElement.disabled = value;\r\n    if (!value) return;\r\n    this.hideContent();\r\n  }\r\n  public get disabled(): boolean {\r\n    return this._disabled;\r\n  }\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  @ViewChild(\"button\")\r\n  private _button!: ElementRef;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  private _disabled: boolean = false;\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 || this._disabled) 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 #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"]}
@@ -102,6 +102,14 @@ export class BorderLayout extends IdentifiableComponent {
102
102
  resizeRegion(region, size) {
103
103
  this.renderer.resizeRegion(region, size);
104
104
  }
105
+ /**
106
+ * Changes the constraints of the region specified by the `LayoutConstraints.region` property.
107
+ *
108
+ * @param constraints The new constraints of the associated region.
109
+ */
110
+ setConstraints(constraints) {
111
+ this.renderer.setConstraints(constraints);
112
+ }
105
113
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BorderLayout, deps: [{ token: i1.SubscriptionService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
106
114
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: BorderLayout, isStandalone: true, selector: "atx-border-layout", outputs: { dragStart: "dragStart", dragStop: "dragStop", dragging: "dragging" }, host: { listeners: { "window:resize": "onResize()" } }, queries: [{ propertyName: "__containers__", predicate: BorderLayoutContainer }], viewQueries: [{ propertyName: "layoutContainer", first: true, predicate: ["atxLayoutContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\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\n<div #atxLayoutContainer class=\"atx-border-layout\">\n <ng-content></ng-content>\n</div>", styles: [".atx-border-layout{position:relative;height:100%;width:100%;-webkit-user-select:none;user-select:none;overflow:hidden}.atx-border-layout{box-sizing:border-box}\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 found in\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n"] }); }
107
115
  }
@@ -127,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
127
135
  type: ContentChildren,
128
136
  args: [BorderLayoutContainer]
129
137
  }] } });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/border-layout.component.ts","../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/border-layout.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAiB,SAAS,EAAE,eAAe,EAAyB,SAAS,EAAE,YAAY,EAAa,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnK,OAAO,EAAE,qBAAqB,EAAE,MAAM,8DAA8D,CAAC;AACrG,OAAO,EAAmB,mBAAmB,EAAuD,MAAM,gBAAgB,CAAC;AAC3H,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;AAE3C;;;;GAIG;AAOH,MAAM,OAAO,YAAa,SAAQ,qBAAqB;IAoBrD;;OAEG;IAEK,QAAQ;QACd,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAaD;;OAEG;IACH,IACY,cAAc,CAAC,UAA4C;QACrE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAAA,CAAC;IAEF;;OAEG;IACH,YAAoB,YAAiC,EACvB,QAAkB;QAC9C,KAAK,EAAE,CAAC;QAFU,iBAAY,GAAZ,YAAY,CAAqB;QAhDrD;;WAEG;QAEa,cAAS,GAAkC,IAAI,YAAY,EAAE,CAAC;QAE9E;;WAEG;QAEa,aAAQ,GAAkC,IAAI,YAAY,EAAE,CAAC;QAE7E;;WAEG;QAEa,aAAQ,GAAkC,IAAI,YAAY,EAAE,CAAC;QAmC3E,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACjE,YAAY,CAAC,QAAQ,CAAC,IAAI,EACxB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,KAAsB,EAAC,EAAE;YAC3D,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,IAAI,KAAK,CAAC,IAAI,KAAK,mBAAmB,CAAC,QAAQ,EAAE,CAAC;gBAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC1B,OAAO;YACT,CAAC;YACD,IAAI,KAAK,CAAC,IAAI,KAAK,mBAAmB,CAAC,UAAU,EAAE,CAAC;gBAClD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC3B,OAAO;YACT,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED;;OAEG;IACI,KAAK;QACV,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAED;;;;;;;OAOG;IACI,YAAY,CAAC,MAAuC,EAAE,IAAY;QACvE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAsB,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;8GA/GU,YAAY,qDAmDH,QAAQ;kGAnDjB,YAAY,qPA0CN,qBAAqB,2KCpExC,yVAUM;;2FDgBO,YAAY;kBANxB,SAAS;+BACE,mBAAmB,cAGjB,IAAI;;0BAqDH,MAAM;2BAAC,QAAQ;yCA7CZ,SAAS;sBADxB,MAAM;gBAOS,QAAQ;sBADvB,MAAM;gBAOS,QAAQ;sBADvB,MAAM;gBAOC,QAAQ;sBADf,YAAY;uBAAC,eAAe;gBASrB,eAAe;sBADtB,SAAS;uBAAC,oBAAoB;gBAYnB,cAAc;sBADzB,eAAe;uBAAC,qBAAqB","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 { AfterViewInit, Component, ContentChildren, OnDestroy, ElementRef, ViewChild, HostListener, QueryList, EventEmitter, Output, Inject } from '@angular/core';\r\nimport { BorderLayoutContainer } from '../border-layout-container/border-layout-container.component';\r\nimport { LayoutDragEvent, LayoutDragEventType, LayoutRegion, LayoutRegionType, SubscriptionService } from '../../../model';\r\nimport { BorderLayoutRenderer } from './util/border-layout-renderer';\r\nimport { IdentifiableComponent } from '../../../core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\n/**\r\n * A border layout lays out a container, arranging and resizing its components to fit in five regions: north, south, east, west, and center.\r\n * Each region is defined by a `BorderLayoutContainer` instance, and is identified by a corresponding constant: `NORTH`, `SOUTH`, `EAST`, `WEST`, and `CENTER`.\r\n * This component is part of the LAF-less API.\r\n */\r\n@Component({\r\n  selector: 'atx-border-layout',\r\n  templateUrl: './border-layout.component.html',\r\n  styleUrls: ['./border-layout.component.scss'],\r\n  standalone: true\r\n})\r\nexport class BorderLayout extends IdentifiableComponent implements AfterViewInit, OnDestroy {\r\n\r\n  /**\r\n   * Emits events each time the user starts dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragStart: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Emits events each time the user stops dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragStop: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Emits events each time the user is dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragging: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n  \r\n  /**\r\n   * @private\r\n   */\r\n  @HostListener(\"window:resize\")\r\n  private onResize(): void {\r\n    this.paint();\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ViewChild(\"atxLayoutContainer\")\r\n  private layoutContainer!: ElementRef<HTMLDivElement>;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  private renderer: BorderLayoutRenderer;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ContentChildren(BorderLayoutContainer)\r\n  private set __containers__(containers: QueryList<BorderLayoutContainer>) {\r\n    this.renderer.addContainers(containers);\r\n  };\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  constructor(private subscribeSvc: SubscriptionService,\r\n              @Inject(DOCUMENT) document: Document) {\r\n    super();\r\n    this.renderer = new BorderLayoutRenderer(subscribeSvc, document);\r\n    subscribeSvc.register(this,\r\n      this.renderer.userAction.subscribe((event: LayoutDragEvent)=> {\r\n        event.layout = this;\r\n        if (event.type === LayoutDragEventType.DRAGGING) {\r\n          this.dragging.emit(event);\r\n          return;\r\n        }\r\n        if (event.type === LayoutDragEventType.DRAG_START) {\r\n          this.dragStart.emit(event);\r\n          return;\r\n        }\r\n        this.dragStop.emit(event);\r\n      })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   * For test purpose only.\r\n   */\r\n  public getRenderer(): BorderLayoutRenderer {\r\n    return this.renderer;\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  public ngOnDestroy(): void {\r\n    this.subscribeSvc.clearAll(this);\r\n    this.renderer.destroy();\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  public ngAfterViewInit(): void {\r\n    this.renderer.setLayoutContainer(this.layoutContainer.nativeElement);\r\n    this.paint();\r\n  }\r\n\r\n  /**\r\n   * Forces the container to be redrawn.\r\n   */\r\n  public paint(): void {\r\n    this.renderer.paint();\r\n  }\r\n\r\n  /**\r\n   * Resizes the specified region.\r\n   * \r\n   * @param region The region to resize.\r\n   * @param size The new size of the region to resize.\r\n   * \r\n   * @returns `true` whether the specified region has been resized; `false` otherwise.\r\n   */\r\n  public resizeRegion(region: LayoutRegion | LayoutRegionType, size: number): void {\r\n    this.renderer.resizeRegion(region as LayoutRegion, size);\r\n  }\r\n}\r\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\n<div #atxLayoutContainer class=\"atx-border-layout\">\n    <ng-content></ng-content>\n</div>"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/border-layout.component.ts","../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/border-layout.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAiB,SAAS,EAAE,eAAe,EAAyB,SAAS,EAAE,YAAY,EAAa,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnK,OAAO,EAAE,qBAAqB,EAAE,MAAM,8DAA8D,CAAC;AACrG,OAAO,EAAsC,mBAAmB,EAAuD,MAAM,gBAAgB,CAAC;AAC9I,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;AAE3C;;;;GAIG;AAOH,MAAM,OAAO,YAAa,SAAQ,qBAAqB;IAoBrD;;OAEG;IAEK,QAAQ;QACd,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAaD;;OAEG;IACH,IACY,cAAc,CAAC,UAA4C;QACrE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAAA,CAAC;IAEF;;OAEG;IACH,YAAoB,YAAiC,EACvB,QAAkB;QAC9C,KAAK,EAAE,CAAC;QAFU,iBAAY,GAAZ,YAAY,CAAqB;QAhDrD;;WAEG;QAEa,cAAS,GAAkC,IAAI,YAAY,EAAE,CAAC;QAE9E;;WAEG;QAEa,aAAQ,GAAkC,IAAI,YAAY,EAAE,CAAC;QAE7E;;WAEG;QAEa,aAAQ,GAAkC,IAAI,YAAY,EAAE,CAAC;QAmC3E,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACjE,YAAY,CAAC,QAAQ,CAAC,IAAI,EACxB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,KAAsB,EAAC,EAAE;YAC3D,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,IAAI,KAAK,CAAC,IAAI,KAAK,mBAAmB,CAAC,QAAQ,EAAE,CAAC;gBAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC1B,OAAO;YACT,CAAC;YACD,IAAI,KAAK,CAAC,IAAI,KAAK,mBAAmB,CAAC,UAAU,EAAE,CAAC;gBAClD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC3B,OAAO;YACT,CAAC;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED;;OAEG;IACI,KAAK;QACV,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAED;;;;;;;OAOG;IACI,YAAY,CAAC,MAAuC,EAAE,IAAY;QACvE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAsB,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;IAED;;;;OAIG;IACI,cAAc,CAAC,WAA8B;QAClD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC5C,CAAC;8GAxHU,YAAY,qDAmDH,QAAQ;kGAnDjB,YAAY,qPA0CN,qBAAqB,2KCpExC,yVAUM;;2FDgBO,YAAY;kBANxB,SAAS;+BACE,mBAAmB,cAGjB,IAAI;;0BAqDH,MAAM;2BAAC,QAAQ;yCA7CZ,SAAS;sBADxB,MAAM;gBAOS,QAAQ;sBADvB,MAAM;gBAOS,QAAQ;sBADvB,MAAM;gBAOC,QAAQ;sBADf,YAAY;uBAAC,eAAe;gBASrB,eAAe;sBADtB,SAAS;uBAAC,oBAAoB;gBAYnB,cAAc;sBADzB,eAAe;uBAAC,qBAAqB","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 { AfterViewInit, Component, ContentChildren, OnDestroy, ElementRef, ViewChild, HostListener, QueryList, EventEmitter, Output, Inject } from '@angular/core';\r\nimport { BorderLayoutContainer } from '../border-layout-container/border-layout-container.component';\r\nimport { LayoutConstraints, LayoutDragEvent, LayoutDragEventType, LayoutRegion, LayoutRegionType, SubscriptionService } from '../../../model';\r\nimport { BorderLayoutRenderer } from './util/border-layout-renderer';\r\nimport { IdentifiableComponent } from '../../../core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\n/**\r\n * A border layout lays out a container, arranging and resizing its components to fit in five regions: north, south, east, west, and center.\r\n * Each region is defined by a `BorderLayoutContainer` instance, and is identified by a corresponding constant: `NORTH`, `SOUTH`, `EAST`, `WEST`, and `CENTER`.\r\n * This component is part of the LAF-less API.\r\n */\r\n@Component({\r\n  selector: 'atx-border-layout',\r\n  templateUrl: './border-layout.component.html',\r\n  styleUrls: ['./border-layout.component.scss'],\r\n  standalone: true\r\n})\r\nexport class BorderLayout extends IdentifiableComponent implements AfterViewInit, OnDestroy {\r\n\r\n  /**\r\n   * Emits events each time the user starts dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragStart: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Emits events each time the user stops dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragStop: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n\r\n  /**\r\n   * Emits events each time the user is dragging a region handle.\r\n   */\r\n  @Output()\r\n  public readonly dragging: EventEmitter<LayoutDragEvent> = new EventEmitter();\r\n  \r\n  /**\r\n   * @private\r\n   */\r\n  @HostListener(\"window:resize\")\r\n  private onResize(): void {\r\n    this.paint();\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ViewChild(\"atxLayoutContainer\")\r\n  private layoutContainer!: ElementRef<HTMLDivElement>;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  private renderer: BorderLayoutRenderer;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  @ContentChildren(BorderLayoutContainer)\r\n  private set __containers__(containers: QueryList<BorderLayoutContainer>) {\r\n    this.renderer.addContainers(containers);\r\n  };\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  constructor(private subscribeSvc: SubscriptionService,\r\n              @Inject(DOCUMENT) document: Document) {\r\n    super();\r\n    this.renderer = new BorderLayoutRenderer(subscribeSvc, document);\r\n    subscribeSvc.register(this,\r\n      this.renderer.userAction.subscribe((event: LayoutDragEvent)=> {\r\n        event.layout = this;\r\n        if (event.type === LayoutDragEventType.DRAGGING) {\r\n          this.dragging.emit(event);\r\n          return;\r\n        }\r\n        if (event.type === LayoutDragEventType.DRAG_START) {\r\n          this.dragStart.emit(event);\r\n          return;\r\n        }\r\n        this.dragStop.emit(event);\r\n      })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   * For test purpose only.\r\n   */\r\n  public getRenderer(): BorderLayoutRenderer {\r\n    return this.renderer;\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  public ngOnDestroy(): void {\r\n    this.subscribeSvc.clearAll(this);\r\n    this.renderer.destroy();\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  public ngAfterViewInit(): void {\r\n    this.renderer.setLayoutContainer(this.layoutContainer.nativeElement);\r\n    this.paint();\r\n  }\r\n\r\n  /**\r\n   * Forces the container to be redrawn.\r\n   */\r\n  public paint(): void {\r\n    this.renderer.paint();\r\n  }\r\n\r\n  /**\r\n   * Resizes the specified region.\r\n   * \r\n   * @param region The region to resize.\r\n   * @param size The new size of the region to resize.\r\n   * \r\n   * @returns `true` whether the specified region has been resized; `false` otherwise.\r\n   */\r\n  public resizeRegion(region: LayoutRegion | LayoutRegionType, size: number): void {\r\n    this.renderer.resizeRegion(region as LayoutRegion, size);\r\n  }\r\n  \r\n  /**\r\n   * Changes the constraints of the region specified by the `LayoutConstraints.region` property.\r\n   * \r\n   * @param constraints The new constraints of the associated region.\r\n   */\r\n  public setConstraints(constraints: LayoutConstraints): void {\r\n    this.renderer.setConstraints(constraints);\r\n  }\r\n}\r\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\n<div #atxLayoutContainer class=\"atx-border-layout\">\n    <ng-content></ng-content>\n</div>"]}
@@ -7,7 +7,7 @@
7
7
  */
8
8
  import { EventEmitter } from '@angular/core';
9
9
  import { EMPTY_STRING } from '../../../../util';
10
- import { LayoutDragEvent, LayoutDragEventType, LayoutRegion } from '../../../../model';
10
+ import { LayoutDragEvent, LayoutDragEventType, LayoutRegion, LayoutRegionError } from '../../../../model';
11
11
  import { IdentifiableComponent } from '../../../../core';
12
12
  import { BorderLayoutBoundsManager } from './border-layout-bounds-manager';
13
13
  /**
@@ -67,11 +67,9 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
67
67
  const constraints = container.constraints;
68
68
  const r = constraints.region;
69
69
  if (regionValidator.indexOf(r) !== -1)
70
- throw new SyntaxError(REGION_ERR_MSG + r);
70
+ throw new LayoutRegionError(REGION_ERR_MSG + r);
71
71
  regionValidator += r;
72
- if (constraints.resizable) {
73
- this.subscribeSvc.register(this, container.resizeStart.subscribe(container => this.resizeEnter(container)));
74
- }
72
+ this.subscribeSvc.register(this, container.resizeStart.subscribe(container => this.resizeEnter(container)));
75
73
  this.boundsManager.initBounds(container);
76
74
  if (r === LayoutRegion.NORTH || r === LayoutRegion.SOUTH)
77
75
  return;
@@ -96,6 +94,21 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
96
94
  getBoundsManager() {
97
95
  return this.boundsManager;
98
96
  }
97
+ /**
98
+ * Changes the constraints of the region specified by the `LayoutConstraints.region` property.
99
+ *
100
+ * @param constraints The new constraints of the associated region.
101
+ */
102
+ setConstraints(constraints) {
103
+ const region = constraints.region;
104
+ const container = this.containerList.find((container) => container.constraints.region === region);
105
+ if (!container)
106
+ throw new LayoutRegionError(`Invalid region: no container with the region '${region}' has been found.`);
107
+ if (constraints.size === undefined)
108
+ constraints.size = container.getSize();
109
+ container.constraints = constraints;
110
+ this.paint();
111
+ }
99
112
  /**
100
113
  * Makes this object elligible for garbage collection.
101
114
  */
@@ -242,4 +255,4 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
242
255
  this.storedMoveHandler = this.storedStopHandler = null;
243
256
  }
244
257
  }
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout-renderer.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/util/border-layout-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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 found in\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n\nimport { EventEmitter, QueryList } from '@angular/core';\nimport { BorderLayoutContainer } from '../../border-layout-container/border-layout-container.component';\nimport { EMPTY_STRING } from '../../../../util';\nimport { Destroyable, LayoutConstraints, LayoutDragEvent, LayoutDragEventType, LayoutRegion, SubscriptionService } from '../../../../model';\nimport { IdentifiableComponent } from '../../../../core';\nimport { BorderLayoutBoundsManager } from './border-layout-bounds-manager';\nimport { ResizeMethod } from './resize-method';\n\n/**\n * @private\n */\nconst MOUSEMOVE: any = \"mousemove\";\n\n/**\n * @private\n */\nconst MOUSEUP: any = \"mouseup\";\n\n/**\n * @private\n */\nconst REGION_ERR_MSG: string = \"A container with the same identifier has already been registered: \";\n\n/**\n * @private\n */\nconst LAYOUT_ERR_MSG: string = \"No layout container has been registered.\";\n\n/**\n * @private\n * A controller object responsible for handling user actions on a `BorderLayout` container.\n */\nexport class BorderLayoutRenderer extends IdentifiableComponent implements Destroyable {\n\n  /**\n   * Emits events each time the user starts, or stops dragging handle.\n   */\n  public readonly userAction: EventEmitter<LayoutDragEvent> = new EventEmitter();\n\n  /**\n   * @private\n   */\n  private lytContainerElm!: HTMLDivElement;\n  \n  /**\n   * @private\n   */\n  private containerList: BorderLayoutContainer[] = [];\n  \n  /**\n   * @private\n   */\n  private boundsManager: BorderLayoutBoundsManager; \n\n  /**\n   * @private\n   */\n  private storedStopHandler: any = null;\n\n  /**\n   * @private\n   */\n  private storedMoveHandler: any = null;\n\n  /**\n   * @private\n   */\n  constructor(private subscribeSvc: SubscriptionService,\n              private document: Document) {\n    super();\n    this.boundsManager = new BorderLayoutBoundsManager();\n  }\n\n  /**\n   * Add the list `BorderLayoutContainer` objects associated with the main container to this controller.\n   * \n   * @param containers the list `BorderLayoutContainer` objects associated with the main container.\n   */\n  public addContainers(containers: QueryList<BorderLayoutContainer>): void {\n    let regionValidator: string = EMPTY_STRING;\n    containers.forEach(container => {\n      const constraints: LayoutConstraints = container.constraints;\n      const r: string = constraints.region as string;\n      if (regionValidator.indexOf(r) !== -1) throw new SyntaxError(REGION_ERR_MSG + r);\n      regionValidator += r;\n      if (constraints.resizable) {\n        this.subscribeSvc.register(this,\n          container.resizeStart.subscribe(container=> this.resizeEnter(container))\n        );\n      }\n      this.boundsManager.initBounds(container);\n      if (r === LayoutRegion.NORTH || r === LayoutRegion.SOUTH) return;\n      this.containerList.push(container);\n    });\n  };\n\n  /**\n   * Sets the reference to the HTML container associated with the main container.\n   * \n   * @param lytContainer The reference to the HTML container associated with the main container.\n   */\n  public setLayoutContainer(lytContainer: HTMLDivElement): void {\n    this.lytContainerElm = lytContainer;\n  };\n\n  /**\n   * @private\n   * For test purpose only.\n   * Returns the reference to the internal `BorderLayoutBoundsManager` instance.\n   */\n  public getBoundsManager(): BorderLayoutBoundsManager {\n    return this.boundsManager; \n  }\n\n  /**\n   * Makes this object elligible for garbage collection.\n   */\n  public destroy(): void {\n    if (this.storedStopHandler) {\n      this.document.removeEventListener(MOUSEMOVE, this.storedMoveHandler);\n      this.document.removeEventListener(MOUSEUP, this.storedStopHandler);\n      this.deleteStoredHandlers();\n    }\n    this.subscribeSvc.clearAll(this);\n    this.lytContainerElm = null as any;\n    this.boundsManager.destroy();\n    this.boundsManager = null as any;\n    this.containerList.length = 0;\n    this.containerList = null as any;\n  }\n\n  /**\n   * Forces the layout of all `BorderLayoutContainer` objects associated with the main container.\n   */\n  public paint(): void {\n    this.checkLytContainer();\n    this.render(this.lytContainerElm.offsetWidth);\n  }\n\n  /**\n   * Resizes the specified region of the associated container.\n   * \n   * @param region The region to resize.\n   * @param size The new size of the region to resize.\n   * \n   * @returns `true` whether the specified region has been resized; `false` otherwise.\n   */\n  public resizeRegion(region: LayoutRegion, size: number): boolean {\n    if (region === LayoutRegion.CENTER) return false;\n    const container: BorderLayoutContainer | undefined = this.containerList.find((c: BorderLayoutContainer)=> {\n      return c.constraints.region === region;\n    });\n    if (!container) return false;\n    container.setSize(size);\n    this.boundsManager.initBounds(container);\n    this.paint();\n    return true;\n  }\n\n  /**\n   * @private\n   */\n  private resizeEnter(container: BorderLayoutContainer): void {\n    this.checkLytContainer();\n    const lytNativeElm: HTMLDivElement = this.lytContainerElm;\n    const width: number = lytNativeElm.offsetWidth;\n    const height: number = lytNativeElm.offsetHeight;\n    const bounds: DOMRect = lytNativeElm.getBoundingClientRect();\n    const constraints: LayoutConstraints = container.constraints;\n    const region: LayoutRegion = constraints.region as LayoutRegion;\n    const minSize: number | undefined = constraints.minSize;\n    const maxSize: number | undefined = constraints.maxSize;\n    const doc: Document = this.document;\n    let size: number = 0;\n    this.boundsManager.setOrigin(bounds.x, bounds.y);\n    let resizeMethod: ResizeMethod = this.boundsManager.getResizeMethod(region);\n    container.selected = true;\n    const onMoveHandler = (event: MouseEvent)=> {\n      event.stopPropagation();\n      event.preventDefault();\n      size = resizeMethod(event, width, height, minSize, maxSize);\n      container.setSize(size);\n      this.render(width);\n      this.fireEvent(container, LayoutDragEventType.DRAGGING);\n    };\n    const onStopHandler = (event: MouseEvent)=> {\n      event.stopPropagation();\n      event.preventDefault();\n      doc.removeEventListener(MOUSEMOVE, onMoveHandler);\n      doc.removeEventListener(MOUSEUP, onStopHandler);\n      this.deleteStoredHandlers();\n      container.selected = false;\n      size = resizeMethod(event, width, height, minSize, maxSize);\n      container.setSize(size);\n      this.render(width);\n      this.fireEvent(container, LayoutDragEventType.DRAG_STOP);\n    };\n    this.storedMoveHandler = onMoveHandler;\n    this.storedStopHandler = onStopHandler;\n    this.fireEvent(container, LayoutDragEventType.DRAG_START);\n    doc.addEventListener(MOUSEMOVE, onMoveHandler);\n    doc.addEventListener(MOUSEUP, onStopHandler);\n  }\n\n  /**\n   * @private\n   */\n  private fireEvent(target: BorderLayoutContainer, type: LayoutDragEventType): void {\n    const evt: LayoutDragEvent = new LayoutDragEvent(target, type);\n    this.userAction.emit(evt);\n  }\n\n  /**\n   * @private\n   */\n  private render(width: number): void {\n    const bounds: DOMRect = this.boundsManager.getBounds();\n    const top: number = bounds.top;\n    const bottom: number = bounds.bottom;\n    const left: number = bounds.left;\n    const right: number = bounds.right;\n    const cList: BorderLayoutContainer[] = this.containerList;\n    let cursor: number = cList.length - 1;\n    while(cursor >= 0) {\n      const cont: BorderLayoutContainer = cList[cursor];\n      const r: LayoutRegion = cont.constraints.region as LayoutRegion;\n      cursor--;\n      if (r === LayoutRegion.WEST) {\n        cont.setTopPos(top);\n        cont.setRightPos(width - left);\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n      if (r === LayoutRegion.CENTER) {\n        cont.setTopPos(top);\n        cont.setLeftPos(left);\n        cont.setRightPos(right - left);\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n      if (r === LayoutRegion.EAST) {\n        cont.setTopPos(top);\n        cont.setLeftPos(width - (right - left));\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n    };\n  }\n\n  /**\n   * @private\n   */\n  private checkLytContainer(): void {\n    if (!this.lytContainerElm) throw new ReferenceError(LAYOUT_ERR_MSG);\n  }\n  \n  /**\n   * @private\n   */\n  private deleteStoredHandlers(): void {\n    this.storedMoveHandler = this.storedStopHandler = null;\n  }\n}\n"]}
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout-renderer.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout/util/border-layout-renderer.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,YAAY,EAAa,MAAM,eAAe,CAAC;AAExD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAkC,eAAe,EAAE,mBAAmB,EAAE,YAAY,EAAyC,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACjL,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAG3E;;GAEG;AACH,MAAM,SAAS,GAAQ,WAAW,CAAC;AAEnC;;GAEG;AACH,MAAM,OAAO,GAAQ,SAAS,CAAC;AAE/B;;GAEG;AACH,MAAM,cAAc,GAAW,oEAAoE,CAAC;AAEpG;;GAEG;AACH,MAAM,cAAc,GAAW,0CAA0C,CAAC;AAE1E;;;GAGG;AACH,MAAM,OAAO,oBAAqB,SAAQ,qBAAqB;IAgC7D;;OAEG;IACH,YAAoB,YAAiC,EACjC,QAAkB;QACpC,KAAK,EAAE,CAAC;QAFU,iBAAY,GAAZ,YAAY,CAAqB;QACjC,aAAQ,GAAR,QAAQ,CAAU;QAlCtC;;WAEG;QACa,eAAU,GAAkC,IAAI,YAAY,EAAE,CAAC;QAO/E;;WAEG;QACK,kBAAa,GAA4B,EAAE,CAAC;QAOpD;;WAEG;QACK,sBAAiB,GAAQ,IAAI,CAAC;QAEtC;;WAEG;QACK,sBAAiB,GAAQ,IAAI,CAAC;QAQpC,IAAI,CAAC,aAAa,GAAG,IAAI,yBAAyB,EAAE,CAAC;IACvD,CAAC;IAED;;;;OAIG;IACI,aAAa,CAAC,UAA4C;QAC/D,IAAI,eAAe,GAAW,YAAY,CAAC;QAC3C,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,MAAM,WAAW,GAAsB,SAAS,CAAC,WAAW,CAAC;YAC7D,MAAM,CAAC,GAAW,WAAW,CAAC,MAAgB,CAAC;YAC/C,IAAI,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAAE,MAAM,IAAI,iBAAiB,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC;YACvF,eAAe,IAAI,CAAC,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,EAC7B,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,SAAS,CAAA,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CACzE,CAAC;YACF,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YACzC,IAAI,CAAC,KAAK,YAAY,CAAC,KAAK,IAAI,CAAC,KAAK,YAAY,CAAC,KAAK;gBAAE,OAAO;YACjE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IAAA,CAAC;IAEF;;;;OAIG;IACI,kBAAkB,CAAC,YAA4B;QACpD,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC;IACtC,CAAC;IAAA,CAAC;IAEF;;;;OAIG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACI,cAAc,CAAC,WAA8B;QAClD,MAAM,MAAM,GAAqB,WAAW,CAAC,MAA0B,CAAC;QACxE,MAAM,SAAS,GAAsC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,SAAgC,EAAE,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;QAC5J,IAAI,CAAC,SAAS;YAAE,MAAM,IAAI,iBAAiB,CAAC,iDAAiD,MAAM,mBAAmB,CAAC,CAAC;QACxH,IAAI,WAAW,CAAC,IAAI,KAAK,SAAS;YAAE,WAAW,CAAC,IAAI,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC;QAC3E,SAAS,CAAC,WAAW,GAAG,WAAW,CAAC;QACpC,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;YACrE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;YACnE,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC;QACD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,eAAe,GAAG,IAAW,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;QAC7B,IAAI,CAAC,aAAa,GAAG,IAAW,CAAC;QACjC,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,IAAW,CAAC;IACnC,CAAC;IAED;;OAEG;IACI,KAAK;QACV,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;IAChD,CAAC;IAED;;;;;;;OAOG;IACI,YAAY,CAAC,MAAoB,EAAE,IAAY;QACpD,IAAI,MAAM,KAAK,YAAY,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QACjD,MAAM,SAAS,GAAsC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAwB,EAAC,EAAE;YACvG,OAAO,CAAC,CAAC,WAAW,CAAC,MAAM,KAAK,MAAM,CAAC;QACzC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS;YAAE,OAAO,KAAK,CAAC;QAC7B,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,SAAgC;QAClD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,MAAM,YAAY,GAAmB,IAAI,CAAC,eAAe,CAAC;QAC1D,MAAM,KAAK,GAAW,YAAY,CAAC,WAAW,CAAC;QAC/C,MAAM,MAAM,GAAW,YAAY,CAAC,YAAY,CAAC;QACjD,MAAM,MAAM,GAAY,YAAY,CAAC,qBAAqB,EAAE,CAAC;QAC7D,MAAM,WAAW,GAAsB,SAAS,CAAC,WAAW,CAAC;QAC7D,MAAM,MAAM,GAAiB,WAAW,CAAC,MAAsB,CAAC;QAChE,MAAM,OAAO,GAAuB,WAAW,CAAC,OAAO,CAAC;QACxD,MAAM,OAAO,GAAuB,WAAW,CAAC,OAAO,CAAC;QACxD,MAAM,GAAG,GAAa,IAAI,CAAC,QAAQ,CAAC;QACpC,IAAI,IAAI,GAAW,CAAC,CAAC;QACrB,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QACjD,IAAI,YAAY,GAAiB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAC5E,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC1B,MAAM,aAAa,GAAG,CAAC,KAAiB,EAAC,EAAE;YACzC,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YAC5D,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QAC1D,CAAC,CAAC;QACF,MAAM,aAAa,GAAG,CAAC,KAAiB,EAAC,EAAE;YACzC,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,GAAG,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;YAClD,GAAG,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;YAChD,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,SAAS,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC3B,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YAC5D,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,mBAAmB,CAAC,SAAS,CAAC,CAAC;QAC3D,CAAC,CAAC;QACF,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;QACvC,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAC1D,GAAG,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QAC/C,GAAG,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAC/C,CAAC;IAED;;OAEG;IACK,SAAS,CAAC,MAA6B,EAAE,IAAyB;QACxE,MAAM,GAAG,GAAoB,IAAI,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,MAAM,CAAC,KAAa;QAC1B,MAAM,MAAM,GAAY,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;QACvD,MAAM,GAAG,GAAW,MAAM,CAAC,GAAG,CAAC;QAC/B,MAAM,MAAM,GAAW,MAAM,CAAC,MAAM,CAAC;QACrC,MAAM,IAAI,GAAW,MAAM,CAAC,IAAI,CAAC;QACjC,MAAM,KAAK,GAAW,MAAM,CAAC,KAAK,CAAC;QACnC,MAAM,KAAK,GAA4B,IAAI,CAAC,aAAa,CAAC;QAC1D,IAAI,MAAM,GAAW,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACtC,OAAM,MAAM,IAAI,CAAC,EAAE,CAAC;YAClB,MAAM,IAAI,GAA0B,KAAK,CAAC,MAAM,CAAC,CAAC;YAClD,MAAM,CAAC,GAAiB,IAAI,CAAC,WAAW,CAAC,MAAsB,CAAC;YAChE,MAAM,EAAE,CAAC;YACT,IAAI,CAAC,KAAK,YAAY,CAAC,IAAI,EAAE,CAAC;gBAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACpB,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;gBAChC,SAAS;YACX,CAAC;YACD,IAAI,CAAC,KAAK,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC9B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACpB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACtB,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;gBAChC,SAAS;YACX,CAAC;YACD,IAAI,CAAC,KAAK,YAAY,CAAC,IAAI,EAAE,CAAC;gBAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACpB,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC;gBAChC,SAAS;YACX,CAAC;QACH,CAAC;QAAA,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,MAAM,IAAI,cAAc,CAAC,cAAc,CAAC,CAAC;IACtE,CAAC;IAED;;OAEG;IACK,oBAAoB;QAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IACzD,CAAC;CACF","sourcesContent":["/**\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 found in\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n\nimport { EventEmitter, QueryList } from '@angular/core';\nimport { BorderLayoutContainer } from '../../border-layout-container/border-layout-container.component';\nimport { EMPTY_STRING } from '../../../../util';\nimport { Destroyable, LayoutConstraints, LayoutDragEvent, LayoutDragEventType, LayoutRegion, LayoutRegionType, SubscriptionService, LayoutRegionError } from '../../../../model';\nimport { IdentifiableComponent } from '../../../../core';\nimport { BorderLayoutBoundsManager } from './border-layout-bounds-manager';\nimport { ResizeMethod } from './resize-method';\n\n/**\n * @private\n */\nconst MOUSEMOVE: any = \"mousemove\";\n\n/**\n * @private\n */\nconst MOUSEUP: any = \"mouseup\";\n\n/**\n * @private\n */\nconst REGION_ERR_MSG: string = \"A container with the same identifier has already been registered: \";\n\n/**\n * @private\n */\nconst LAYOUT_ERR_MSG: string = \"No layout container has been registered.\";\n\n/**\n * @private\n * A controller object responsible for handling user actions on a `BorderLayout` container.\n */\nexport class BorderLayoutRenderer extends IdentifiableComponent implements Destroyable {\n\n  /**\n   * Emits events each time the user starts, or stops dragging handle.\n   */\n  public readonly userAction: EventEmitter<LayoutDragEvent> = new EventEmitter();\n\n  /**\n   * @private\n   */\n  private lytContainerElm!: HTMLDivElement;\n  \n  /**\n   * @private\n   */\n  private containerList: BorderLayoutContainer[] = [];\n  \n  /**\n   * @private\n   */\n  private boundsManager: BorderLayoutBoundsManager; \n\n  /**\n   * @private\n   */\n  private storedStopHandler: any = null;\n\n  /**\n   * @private\n   */\n  private storedMoveHandler: any = null;\n\n  /**\n   * @private\n   */\n  constructor(private subscribeSvc: SubscriptionService,\n              private document: Document) {\n    super();\n    this.boundsManager = new BorderLayoutBoundsManager();\n  }\n\n  /**\n   * Add the list `BorderLayoutContainer` objects associated with the main container to this controller.\n   * \n   * @param containers the list `BorderLayoutContainer` objects associated with the main container.\n   */\n  public addContainers(containers: QueryList<BorderLayoutContainer>): void {\n    let regionValidator: string = EMPTY_STRING;\n    containers.forEach(container => {\n      const constraints: LayoutConstraints = container.constraints;\n      const r: string = constraints.region as string;\n      if (regionValidator.indexOf(r) !== -1) throw new LayoutRegionError(REGION_ERR_MSG + r);\n      regionValidator += r;\n      this.subscribeSvc.register(this,\n        container.resizeStart.subscribe(container=> this.resizeEnter(container))\n      );\n      this.boundsManager.initBounds(container);\n      if (r === LayoutRegion.NORTH || r === LayoutRegion.SOUTH) return;\n      this.containerList.push(container);\n    });\n  };\n\n  /**\n   * Sets the reference to the HTML container associated with the main container.\n   * \n   * @param lytContainer The reference to the HTML container associated with the main container.\n   */\n  public setLayoutContainer(lytContainer: HTMLDivElement): void {\n    this.lytContainerElm = lytContainer;\n  };\n\n  /**\n   * @private\n   * For test purpose only.\n   * Returns the reference to the internal `BorderLayoutBoundsManager` instance.\n   */\n  public getBoundsManager(): BorderLayoutBoundsManager {\n    return this.boundsManager; \n  }\n  \n  /**\n   * Changes the constraints of the region specified by the `LayoutConstraints.region` property.\n   * \n   * @param constraints The new constraints of the associated region.\n   */\n  public setConstraints(constraints: LayoutConstraints): void {\n    const region: LayoutRegionType = constraints.region as LayoutRegionType;\n    const container: BorderLayoutContainer | undefined = this.containerList.find((container: BorderLayoutContainer) => container.constraints.region === region);\n    if (!container) throw new LayoutRegionError(`Invalid region: no container with the region '${region}' has been found.`);\n    if (constraints.size === undefined) constraints.size = container.getSize();\n    container.constraints = constraints;\n    this.paint();\n  }\n\n  /**\n   * Makes this object elligible for garbage collection.\n   */\n  public destroy(): void {\n    if (this.storedStopHandler) {\n      this.document.removeEventListener(MOUSEMOVE, this.storedMoveHandler);\n      this.document.removeEventListener(MOUSEUP, this.storedStopHandler);\n      this.deleteStoredHandlers();\n    }\n    this.subscribeSvc.clearAll(this);\n    this.lytContainerElm = null as any;\n    this.boundsManager.destroy();\n    this.boundsManager = null as any;\n    this.containerList.length = 0;\n    this.containerList = null as any;\n  }\n\n  /**\n   * Forces the layout of all `BorderLayoutContainer` objects associated with the main container.\n   */\n  public paint(): void {\n    this.checkLytContainer();\n    this.render(this.lytContainerElm.offsetWidth);\n  }\n\n  /**\n   * Resizes the specified region of the associated container.\n   * \n   * @param region The region to resize.\n   * @param size The new size of the region to resize.\n   * \n   * @returns `true` whether the specified region has been resized; `false` otherwise.\n   */\n  public resizeRegion(region: LayoutRegion, size: number): boolean {\n    if (region === LayoutRegion.CENTER) return false;\n    const container: BorderLayoutContainer | undefined = this.containerList.find((c: BorderLayoutContainer)=> {\n      return c.constraints.region === region;\n    });\n    if (!container) return false;\n    container.setSize(size);\n    this.boundsManager.initBounds(container);\n    this.paint();\n    return true;\n  }\n\n  /**\n   * @private\n   */\n  private resizeEnter(container: BorderLayoutContainer): void {\n    this.checkLytContainer();\n    const lytNativeElm: HTMLDivElement = this.lytContainerElm;\n    const width: number = lytNativeElm.offsetWidth;\n    const height: number = lytNativeElm.offsetHeight;\n    const bounds: DOMRect = lytNativeElm.getBoundingClientRect();\n    const constraints: LayoutConstraints = container.constraints;\n    const region: LayoutRegion = constraints.region as LayoutRegion;\n    const minSize: number | undefined = constraints.minSize;\n    const maxSize: number | undefined = constraints.maxSize;\n    const doc: Document = this.document;\n    let size: number = 0;\n    this.boundsManager.setOrigin(bounds.x, bounds.y);\n    let resizeMethod: ResizeMethod = this.boundsManager.getResizeMethod(region);\n    container.selected = true;\n    const onMoveHandler = (event: MouseEvent)=> {\n      event.stopPropagation();\n      event.preventDefault();\n      size = resizeMethod(event, width, height, minSize, maxSize);\n      container.setSize(size);\n      this.render(width);\n      this.fireEvent(container, LayoutDragEventType.DRAGGING);\n    };\n    const onStopHandler = (event: MouseEvent)=> {\n      event.stopPropagation();\n      event.preventDefault();\n      doc.removeEventListener(MOUSEMOVE, onMoveHandler);\n      doc.removeEventListener(MOUSEUP, onStopHandler);\n      this.deleteStoredHandlers();\n      container.selected = false;\n      size = resizeMethod(event, width, height, minSize, maxSize);\n      container.setSize(size);\n      this.render(width);\n      this.fireEvent(container, LayoutDragEventType.DRAG_STOP);\n    };\n    this.storedMoveHandler = onMoveHandler;\n    this.storedStopHandler = onStopHandler;\n    this.fireEvent(container, LayoutDragEventType.DRAG_START);\n    doc.addEventListener(MOUSEMOVE, onMoveHandler);\n    doc.addEventListener(MOUSEUP, onStopHandler);\n  }\n\n  /**\n   * @private\n   */\n  private fireEvent(target: BorderLayoutContainer, type: LayoutDragEventType): void {\n    const evt: LayoutDragEvent = new LayoutDragEvent(target, type);\n    this.userAction.emit(evt);\n  }\n\n  /**\n   * @private\n   */\n  private render(width: number): void {\n    const bounds: DOMRect = this.boundsManager.getBounds();\n    const top: number = bounds.top;\n    const bottom: number = bounds.bottom;\n    const left: number = bounds.left;\n    const right: number = bounds.right;\n    const cList: BorderLayoutContainer[] = this.containerList;\n    let cursor: number = cList.length - 1;\n    while(cursor >= 0) {\n      const cont: BorderLayoutContainer = cList[cursor];\n      const r: LayoutRegion = cont.constraints.region as LayoutRegion;\n      cursor--;\n      if (r === LayoutRegion.WEST) {\n        cont.setTopPos(top);\n        cont.setRightPos(width - left);\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n      if (r === LayoutRegion.CENTER) {\n        cont.setTopPos(top);\n        cont.setLeftPos(left);\n        cont.setRightPos(right - left);\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n      if (r === LayoutRegion.EAST) {\n        cont.setTopPos(top);\n        cont.setLeftPos(width - (right - left));\n        cont.setBottomPos(bottom - top);\n        continue;\n      }\n    };\n  }\n\n  /**\n   * @private\n   */\n  private checkLytContainer(): void {\n    if (!this.lytContainerElm) throw new ReferenceError(LAYOUT_ERR_MSG);\n  }\n  \n  /**\n   * @private\n   */\n  private deleteStoredHandlers(): void {\n    this.storedMoveHandler = this.storedStopHandler = null;\n  }\n}\n"]}
@@ -33,6 +33,8 @@ export class BorderLayoutContainer {
33
33
  this.region = constraints.region;
34
34
  if (constraints.resizable)
35
35
  this.initHandle();
36
+ else
37
+ this.resizable = false;
36
38
  this.setSize(constraints.size);
37
39
  }
38
40
  /**
@@ -140,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
140
142
  }], constraints: [{
141
143
  type: Input
142
144
  }] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout-container/border-layout-container.component.ts","../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout-container/border-layout-container.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\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 found in\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n\nimport { Component, Input, HostBinding, ElementRef, EventEmitter } from '@angular/core';\nimport { LayoutConstraints, LayoutRegion } from '../../../model';\n\n/**\n * @private\n */\nconst PX: string = \"px\";\n\n/**\n * A container that defines the region of a `BorderLayout` component instance.\n */\n@Component({\n  selector: 'atx-border-layout-container',\n  templateUrl: './border-layout-container.component.html',\n  styleUrls: ['./border-layout-container.component.scss'],\n  standalone: true\n})\nexport class BorderLayoutContainer {\n\n  /**\n   * @private\n   * Indicates to the parent `BorderLayout` instance that the user starts to resize this container.\n   */\n  public readonly resizeStart: EventEmitter<BorderLayoutContainer> = new EventEmitter(false);\n  \n  /**\n   * @private\n   */\n  public selected: Boolean = false;\n\n  /**\n   * Gets the CSS class associated with the region constraint of the `BorderLayoutContainer` object.\n   */\n  @HostBinding('class')\n  get class(): string {\n    return this.region;\n  }\n\n  /**\n   * @private\n   */\n  protected region!: LayoutRegion;\n  \n  /**\n   * @private\n   */\n  protected resizable: boolean = false;\n\n  /**\n   * @private\n   */\n  private atxConstraints!: LayoutConstraints;\n\n  /**\n   * @private\n   */\n  private size!: number;\n\n  /**\n   * @private\n   */\n  private readonly style: CSSStyleDeclaration;\n\n  /**\n   * Gets or sets the constraints for this `BorderLayoutContainer` object.\n   */\n  public get constraints(): LayoutConstraints  {\n    return this.atxConstraints;\n  }\n  @Input()\n  public set constraints(constraints: LayoutConstraints) {\n    this.atxConstraints = constraints;\n    this.region = constraints.region as LayoutRegion;\n    if(constraints.resizable) this.initHandle();\n    this.setSize(constraints.size);\n  }\n\n  /**\n   * @private\n   */\n  constructor(private elRef: ElementRef) {\n    this.style = this.elRef.nativeElement.style;\n  }\n\n  /**\n   * Sets the size of this container depending on the specified region.\n   * \n   * @param size The new size for this container, in pixels.\n   */\n  public setSize(size: number | undefined): void {\n    const r: LayoutRegion = this.region;\n    if (r === LayoutRegion.CENTER) return;\n    if (r === LayoutRegion.NORTH || r === LayoutRegion.SOUTH) {\n      this.size = size ? size : 50;\n      this.style.height = this.size + PX;\n      return;\n    }\n    if (r === LayoutRegion.EAST || r === LayoutRegion.WEST) {\n      this.size = size ? size : 100;\n      this.style.width = this.size + PX;\n    }\n  }\n\n  /**\n   * Returns the size of the container, in pixels.\n   * \n   * @returns The size of the container.\n   */\n  public getSize(): number {\n    return this.size;\n  }\n\n  /**\n   * Sets the left-hand side position of this container.\n   * \n   * @param position The left-hand side position of this container, in pixels.\n   */\n  public setLeftPos(position: number): void {\n    this.style.left = position + PX;\n  }\n\n  /**\n   * Sets the right-hand side position of this container.\n   * \n   * @param position The right-hand side position of this container, in pixels.\n   */\n  public setRightPos(position: number): void {\n    this.style.right = position + PX;\n  }\n  \n  /**\n   * Sets the top position of this container.\n   * \n   * @param position The top position of this container, in pixels.\n   */\n  public setTopPos(position: number): void {\n    this.style.top = position + PX;\n  }\n  \n  /**\n   * Sets the bottom position of this container.\n   * \n   * @param position The bottom position of this container, in pixels.\n   */\n  public setBottomPos(position: number): void {\n    this.style.bottom = position + PX;\n  }\n\n  /**\n   * @private\n   */\n  protected resizetart(): void {\n    this.resizeStart.emit(this);\n  }\n\n  /**\n   * @private\n   */\n  private initHandle(): void {\n    if (this.region === LayoutRegion.CENTER) return;\n    this.resizable = true;\n  }\n}\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\n<ng-content></ng-content>\n@if (resizable) {\n    <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"border-layout-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout-container/border-layout-container.component.ts","../../../../../../../projects/angular-toolbox/src/lib/component/layout/border-layout-container/border-layout-container.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAc,YAAY,EAAE,MAAM,eAAe,CAAC;AACxF,OAAO,EAAqB,YAAY,EAAE,MAAM,gBAAgB,CAAC;;AAEjE;;GAEG;AACH,MAAM,EAAE,GAAW,IAAI,CAAC;AAExB;;GAEG;AAOH,MAAM,OAAO,qBAAqB;IAahC;;OAEG;IACH,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IA2BD;;OAEG;IACH,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACD,IACW,WAAW,CAAC,WAA8B;QACnD,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC;QAClC,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,MAAsB,CAAC;QACjD,IAAG,WAAW,CAAC,SAAS;YAAE,IAAI,CAAC,UAAU,EAAE,CAAC;;YACvC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,YAAoB,KAAiB;QAAjB,UAAK,GAAL,KAAK,CAAY;QA9DrC;;;WAGG;QACa,gBAAW,GAAwC,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC;QAE3F;;WAEG;QACI,aAAQ,GAAY,KAAK,CAAC;QAejC;;WAEG;QACO,cAAS,GAAY,KAAK,CAAC;QAoCnC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;IAC9C,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAwB;QACrC,MAAM,CAAC,GAAiB,IAAI,CAAC,MAAM,CAAC;QACpC,IAAI,CAAC,KAAK,YAAY,CAAC,MAAM;YAAE,OAAO;QACtC,IAAI,CAAC,KAAK,YAAY,CAAC,KAAK,IAAI,CAAC,KAAK,YAAY,CAAC,KAAK,EAAE,CAAC;YACzD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,KAAK,YAAY,CAAC,IAAI,IAAI,CAAC,KAAK,YAAY,CAAC,IAAI,EAAE,CAAC;YACvD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACpC,CAAC;IACH,CAAC;IAED;;;;OAIG;IACI,OAAO;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACI,UAAU,CAAC,QAAgB;QAChC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,GAAG,EAAE,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,QAAgB;QACjC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,QAAQ,GAAG,EAAE,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,QAAgB;QAC/B,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,QAAQ,GAAG,EAAE,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,QAAgB;QAClC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,QAAQ,GAAG,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACO,UAAU;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED;;OAEG;IACK,UAAU;QAChB,IAAI,IAAI,CAAC,MAAM,KAAK,YAAY,CAAC,MAAM;YAAE,OAAO;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;8GAjJU,qBAAqB;kGAArB,qBAAqB,gLCzBlC,0ZAYA;;2FDaa,qBAAqB;kBANjC,SAAS;+BACE,6BAA6B,cAG3B,IAAI;+EAmBZ,KAAK;sBADR,WAAW;uBAAC,OAAO;gBAqCT,WAAW;sBADrB,KAAK","sourcesContent":["/**\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 found in\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\n */\n\nimport { Component, Input, HostBinding, ElementRef, EventEmitter } from '@angular/core';\nimport { LayoutConstraints, LayoutRegion } from '../../../model';\n\n/**\n * @private\n */\nconst PX: string = \"px\";\n\n/**\n * A container that defines the region of a `BorderLayout` component instance.\n */\n@Component({\n  selector: 'atx-border-layout-container',\n  templateUrl: './border-layout-container.component.html',\n  styleUrls: ['./border-layout-container.component.scss'],\n  standalone: true\n})\nexport class BorderLayoutContainer {\n\n  /**\n   * @private\n   * Indicates to the parent `BorderLayout` instance that the user starts to resize this container.\n   */\n  public readonly resizeStart: EventEmitter<BorderLayoutContainer> = new EventEmitter(false);\n  \n  /**\n   * @private\n   */\n  public selected: Boolean = false;\n\n  /**\n   * Gets the CSS class associated with the region constraint of the `BorderLayoutContainer` object.\n   */\n  @HostBinding('class')\n  get class(): string {\n    return this.region;\n  }\n\n  /**\n   * @private\n   */\n  protected region!: LayoutRegion;\n  \n  /**\n   * @private\n   */\n  protected resizable: boolean = false;\n\n  /**\n   * @private\n   */\n  private atxConstraints!: LayoutConstraints;\n\n  /**\n   * @private\n   */\n  private size!: number;\n\n  /**\n   * @private\n   */\n  private readonly style: CSSStyleDeclaration;\n\n  /**\n   * Gets or sets the constraints for this `BorderLayoutContainer` object.\n   */\n  public get constraints(): LayoutConstraints  {\n    return this.atxConstraints;\n  }\n  @Input()\n  public set constraints(constraints: LayoutConstraints) {\n    this.atxConstraints = constraints;\n    this.region = constraints.region as LayoutRegion;\n    if(constraints.resizable) this.initHandle();\n    else this.resizable = false;\n    this.setSize(constraints.size);\n  }\n\n  /**\n   * @private\n   */\n  constructor(private elRef: ElementRef) {\n    this.style = this.elRef.nativeElement.style;\n  }\n\n  /**\n   * Sets the size of this container depending on the specified region.\n   * \n   * @param size The new size for this container, in pixels.\n   */\n  public setSize(size: number | undefined): void {\n    const r: LayoutRegion = this.region;\n    if (r === LayoutRegion.CENTER) return;\n    if (r === LayoutRegion.NORTH || r === LayoutRegion.SOUTH) {\n      this.size = size ? size : 50;\n      this.style.height = this.size + PX;\n      return;\n    }\n    if (r === LayoutRegion.EAST || r === LayoutRegion.WEST) {\n      this.size = size ? size : 100;\n      this.style.width = this.size + PX;\n    }\n  }\n\n  /**\n   * Returns the size of the container, in pixels.\n   * \n   * @returns The size of the container.\n   */\n  public getSize(): number {\n    return this.size;\n  }\n\n  /**\n   * Sets the left-hand side position of this container.\n   * \n   * @param position The left-hand side position of this container, in pixels.\n   */\n  public setLeftPos(position: number): void {\n    this.style.left = position + PX;\n  }\n\n  /**\n   * Sets the right-hand side position of this container.\n   * \n   * @param position The right-hand side position of this container, in pixels.\n   */\n  public setRightPos(position: number): void {\n    this.style.right = position + PX;\n  }\n  \n  /**\n   * Sets the top position of this container.\n   * \n   * @param position The top position of this container, in pixels.\n   */\n  public setTopPos(position: number): void {\n    this.style.top = position + PX;\n  }\n  \n  /**\n   * Sets the bottom position of this container.\n   * \n   * @param position The bottom position of this container, in pixels.\n   */\n  public setBottomPos(position: number): void {\n    this.style.bottom = position + PX;\n  }\n\n  /**\n   * @private\n   */\n  protected resizetart(): void {\n    this.resizeStart.emit(this);\n  }\n\n  /**\n   * @private\n   */\n  private initHandle(): void {\n    if (this.region === LayoutRegion.CENTER) return;\n    this.resizable = true;\n  }\n}\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\n<ng-content></ng-content>\n@if (resizable) {\n    <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  export * from './layout-constraints';
2
2
  export * from './layout-region';
3
+ export * from './layout-region.error';
3
4
  export * from './layout-drag.event';
4
5
  export * from './layout-drag-event-type.enum';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9tb2RlbC9idXNpbmVzcy91aS9sYXlvdXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGF5b3V0LWNvbnN0cmFpbnRzJztcclxuZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQtcmVnaW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQtZHJhZy5ldmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGF5b3V0LWRyYWctZXZlbnQtdHlwZS5lbnVtJzsiXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9tb2RlbC9idXNpbmVzcy91aS9sYXlvdXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQtY29uc3RyYWludHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xheW91dC1yZWdpb24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2xheW91dC1yZWdpb24uZXJyb3InO1xyXG5leHBvcnQgKiBmcm9tICcuL2xheW91dC1kcmFnLmV2ZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQtZHJhZy1ldmVudC10eXBlLmVudW0nOyJdfQ==
@@ -0,0 +1,22 @@
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
+ /**
9
+ * The `LayoutRegionError` class represents an error thrown by layout components when manipulating
10
+ * invalid regions of the container.
11
+ */
12
+ export class LayoutRegionError extends Error {
13
+ /**
14
+ * Creates a new `LayoutRegionError` instance.
15
+ *
16
+ * @param message A human-readable description of the error.
17
+ */
18
+ constructor(message) {
19
+ super(message);
20
+ }
21
+ }
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LXJlZ2lvbi5lcnJvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdG9vbGJveC9zcmMvbGliL21vZGVsL2J1c2luZXNzL3VpL2xheW91dC9sYXlvdXQtcmVnaW9uLmVycm9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVIOzs7R0FHRztBQUNILE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxLQUFLO0lBRXhDOzs7O09BSUc7SUFDSCxZQUFZLE9BQWU7UUFDeEIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAbGljZW5zZVxyXG4gKiBDb3B5cmlnaHQgUGFzY2FsIEVDSEVNQU5OLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxyXG4gKlxyXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZSBmb3VuZCBpblxyXG4gKiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vcGFzY2FsZWNoZW1hbm4uY29tL2FuZ3VsYXItdG9vbGJveC9yZXNvdXJjZXMvbGljZW5zZVxyXG4gKi9cclxuXHJcbi8qKlxyXG4gKiBUaGUgYExheW91dFJlZ2lvbkVycm9yYCBjbGFzcyByZXByZXNlbnRzIGFuIGVycm9yIHRocm93biBieSBsYXlvdXQgY29tcG9uZW50cyB3aGVuIG1hbmlwdWxhdGluZ1xyXG4gKiBpbnZhbGlkIHJlZ2lvbnMgb2YgdGhlIGNvbnRhaW5lci5cclxuICovXHJcbmV4cG9ydCBjbGFzcyBMYXlvdXRSZWdpb25FcnJvciBleHRlbmRzIEVycm9yIHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIENyZWF0ZXMgYSBuZXcgYExheW91dFJlZ2lvbkVycm9yYCBpbnN0YW5jZS5cclxuICAgICAqIFxyXG4gICAgICogQHBhcmFtIG1lc3NhZ2UgQSBodW1hbi1yZWFkYWJsZSBkZXNjcmlwdGlvbiBvZiB0aGUgZXJyb3IuXHJcbiAgICAgKi9cclxuICAgIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xyXG4gICAgICAgc3VwZXIobWVzc2FnZSk7XHJcbiAgICB9XHJcbn0iXX0=
@@ -15,8 +15,8 @@ import * as i0 from "@angular/core";
15
15
  const ATX_VERSION_CONFIG = {
16
16
  major: 1,
17
17
  minor: 4,
18
- patch: 2,
19
- buildTimestamp: 1728546812271
18
+ patch: 4,
19
+ buildTimestamp: 1728971479807
20
20
  };
21
21
  /**
22
22
  * The public service that exposes the current version of the Angular Toolbox library.
@@ -34,4 +34,4 @@ export class AngularToolboxVersionService extends AbstractVersionManager {
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AngularToolboxVersionService, decorators: [{
35
35
  type: Injectable
36
36
  }], ctorParameters: () => [] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10b29sYm94LXZlcnNpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdG9vbGJveC9zcmMvbGliL21vZGVsL3NlcnZpY2UvdmVyc2lvbi9hbmd1bGFyLXRvb2xib3gtdmVyc2lvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUd2RDs7O0dBR0c7QUFDSCxNQUFNLGtCQUFrQixHQUFrQjtJQUN4QyxLQUFLLEVBQUUsQ0FBQztJQUNSLEtBQUssRUFBRSxDQUFDO0lBQ1IsS0FBSyxFQUFFLENBQUM7SUFDUixjQUFjLEVBQUUsYUFBYTtDQUM5QixDQUFDO0FBRUY7O0dBRUc7QUFFSCxNQUFNLE9BQU8sNEJBQTZCLFNBQVEsc0JBQXNCO0lBRXRFOztPQUVHO0lBQ0g7UUFDRSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUM1QixDQUFDOzhHQVBVLDRCQUE0QjtrSEFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEBsaWNlbnNlXHJcbiAqIENvcHlyaWdodCBQYXNjYWwgRUNIRU1BTk4uIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXHJcbiAqXHJcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlIGZvdW5kIGluXHJcbiAqIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9wYXNjYWxlY2hlbWFubi5jb20vYW5ndWxhci10b29sYm94L3Jlc291cmNlcy9saWNlbnNlXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdFZlcnNpb25NYW5hZ2VyIH0gZnJvbSAnLi4vLi4vLi4vY29yZSc7XHJcbmltcG9ydCB7IFZlcnNpb25Db25maWcgfSBmcm9tICcuLi8uLi9idXNpbmVzcyc7XHJcblxyXG4vKipcclxuICogQHByaXZhdGVcclxuICogVGhlIGN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgQW5ndWxhciBUb29sYm94IGxpYnJhcnkuXHJcbiAqL1xyXG5jb25zdCBBVFhfVkVSU0lPTl9DT05GSUc6IFZlcnNpb25Db25maWcgPSB7XHJcbiAgbWFqb3I6IDEsXHJcbiAgbWlub3I6IDQsXHJcbiAgcGF0Y2g6IDIsXHJcbiAgYnVpbGRUaW1lc3RhbXA6IDE3Mjg1NDY4MTIyNzFcclxufTtcclxuXHJcbi8qKlxyXG4gKiBUaGUgcHVibGljIHNlcnZpY2UgdGhhdCBleHBvc2VzIHRoZSBjdXJyZW50IHZlcnNpb24gb2YgdGhlIEFuZ3VsYXIgVG9vbGJveCBsaWJyYXJ5LlxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclRvb2xib3hWZXJzaW9uU2VydmljZSBleHRlbmRzIEFic3RyYWN0VmVyc2lvbk1hbmFnZXIge1xyXG5cclxuICAvKipcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgc3VwZXIoQVRYX1ZFUlNJT05fQ09ORklHKTtcclxuICB9XHJcbn1cclxuIl19
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10b29sYm94LXZlcnNpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdG9vbGJveC9zcmMvbGliL21vZGVsL3NlcnZpY2UvdmVyc2lvbi9hbmd1bGFyLXRvb2xib3gtdmVyc2lvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUd2RDs7O0dBR0c7QUFDSCxNQUFNLGtCQUFrQixHQUFrQjtJQUN4QyxLQUFLLEVBQUUsQ0FBQztJQUNSLEtBQUssRUFBRSxDQUFDO0lBQ1IsS0FBSyxFQUFFLENBQUM7SUFDUixjQUFjLEVBQUUsYUFBYTtDQUM5QixDQUFDO0FBRUY7O0dBRUc7QUFFSCxNQUFNLE9BQU8sNEJBQTZCLFNBQVEsc0JBQXNCO0lBRXRFOztPQUVHO0lBQ0g7UUFDRSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUM1QixDQUFDOzhHQVBVLDRCQUE0QjtrSEFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEBsaWNlbnNlXHJcbiAqIENvcHlyaWdodCBQYXNjYWwgRUNIRU1BTk4uIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXHJcbiAqXHJcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlIGZvdW5kIGluXHJcbiAqIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9wYXNjYWxlY2hlbWFubi5jb20vYW5ndWxhci10b29sYm94L3Jlc291cmNlcy9saWNlbnNlXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdFZlcnNpb25NYW5hZ2VyIH0gZnJvbSAnLi4vLi4vLi4vY29yZSc7XHJcbmltcG9ydCB7IFZlcnNpb25Db25maWcgfSBmcm9tICcuLi8uLi9idXNpbmVzcyc7XHJcblxyXG4vKipcclxuICogQHByaXZhdGVcclxuICogVGhlIGN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgQW5ndWxhciBUb29sYm94IGxpYnJhcnkuXHJcbiAqL1xyXG5jb25zdCBBVFhfVkVSU0lPTl9DT05GSUc6IFZlcnNpb25Db25maWcgPSB7XHJcbiAgbWFqb3I6IDEsXHJcbiAgbWlub3I6IDQsXHJcbiAgcGF0Y2g6IDQsXHJcbiAgYnVpbGRUaW1lc3RhbXA6IDE3Mjg5NzE0Nzk4MDdcclxufTtcclxuXHJcbi8qKlxyXG4gKiBUaGUgcHVibGljIHNlcnZpY2UgdGhhdCBleHBvc2VzIHRoZSBjdXJyZW50IHZlcnNpb24gb2YgdGhlIEFuZ3VsYXIgVG9vbGJveCBsaWJyYXJ5LlxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclRvb2xib3hWZXJzaW9uU2VydmljZSBleHRlbmRzIEFic3RyYWN0VmVyc2lvbk1hbmFnZXIge1xyXG5cclxuICAvKipcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgc3VwZXIoQVRYX1ZFUlNJT05fQ09ORklHKTtcclxuICB9XHJcbn1cclxuIl19