angular-toolbox 1.4.0 → 1.4.2

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.
Files changed (44) hide show
  1. package/README.md +1 -1
  2. package/esm2022/lib/component/layout/border-layout/border-layout.component.mjs +15 -11
  3. package/esm2022/lib/component/layout/border-layout/util/border-layout-renderer.mjs +48 -15
  4. package/esm2022/lib/component/layout/border-layout-container/border-layout-container.component.mjs +2 -2
  5. package/esm2022/lib/framework/index.mjs +2 -1
  6. package/esm2022/lib/framework/mock/documentation/component/atx-mock-description/atx-mock-description.component.mjs +27 -0
  7. package/esm2022/lib/framework/mock/documentation/component/atx-mock-documentation/atx-mock-documentation.component.mjs +77 -0
  8. package/esm2022/lib/framework/mock/documentation/component/atx-mock-full-description/atx-mock-full-description.component.mjs +27 -0
  9. package/esm2022/lib/framework/mock/documentation/component/atx-mock-methods/atx-mock-methods.component.mjs +71 -0
  10. package/esm2022/lib/framework/mock/documentation/component/atx-mock-param/atx-mock-param.component.mjs +27 -0
  11. package/esm2022/lib/framework/mock/documentation/index.mjs +2 -0
  12. package/esm2022/lib/framework/mock/documentation/model/business/full-description.type.mjs +9 -0
  13. package/esm2022/lib/framework/mock/documentation/model/business/method-doc-descriptor.type.mjs +9 -0
  14. package/esm2022/lib/model/business/mock/http/http-method-mock.mjs +1 -1
  15. package/esm2022/lib/model/business/mock/http/http-mock-config.mjs +1 -1
  16. package/esm2022/lib/model/business/mock/http/http-mock-endpoint-descriptor.mjs +9 -0
  17. package/esm2022/lib/model/business/mock/http/http-mock-endpoint.mjs +1 -1
  18. package/esm2022/lib/model/business/mock/http/http-mock-interceptor.mjs +1 -1
  19. package/esm2022/lib/model/business/mock/http/http-mock-method-descriptor.mjs +9 -0
  20. package/esm2022/lib/model/business/mock/http/http-mock-parameter-descriptor.mjs +9 -0
  21. package/esm2022/lib/model/business/mock/http/index.mjs +4 -1
  22. package/esm2022/lib/model/service/version/angular-toolbox-version.service.mjs +3 -3
  23. package/fesm2022/angular-toolbox.mjs +297 -28
  24. package/fesm2022/angular-toolbox.mjs.map +1 -1
  25. package/lib/component/layout/border-layout/border-layout.component.d.ts +1 -1
  26. package/lib/component/layout/border-layout/util/border-layout-renderer.d.ts +17 -1
  27. package/lib/framework/index.d.ts +1 -0
  28. package/lib/framework/mock/documentation/component/atx-mock-description/atx-mock-description.component.d.ts +14 -0
  29. package/lib/framework/mock/documentation/component/atx-mock-documentation/atx-mock-documentation.component.d.ts +43 -0
  30. package/lib/framework/mock/documentation/component/atx-mock-full-description/atx-mock-full-description.component.d.ts +15 -0
  31. package/lib/framework/mock/documentation/component/atx-mock-methods/atx-mock-methods.component.d.ts +29 -0
  32. package/lib/framework/mock/documentation/component/atx-mock-param/atx-mock-param.component.d.ts +15 -0
  33. package/lib/framework/mock/documentation/index.d.ts +1 -0
  34. package/lib/framework/mock/documentation/model/business/full-description.type.d.ts +21 -0
  35. package/lib/framework/mock/documentation/model/business/method-doc-descriptor.type.d.ts +22 -0
  36. package/lib/model/business/mock/http/http-method-mock.d.ts +5 -0
  37. package/lib/model/business/mock/http/http-mock-config.d.ts +4 -0
  38. package/lib/model/business/mock/http/http-mock-endpoint-descriptor.d.ts +21 -0
  39. package/lib/model/business/mock/http/http-mock-endpoint.d.ts +5 -0
  40. package/lib/model/business/mock/http/http-mock-interceptor.d.ts +4 -0
  41. package/lib/model/business/mock/http/http-mock-method-descriptor.d.ts +29 -0
  42. package/lib/model/business/mock/http/http-mock-parameter-descriptor.d.ts +20 -0
  43. package/lib/model/business/mock/http/index.d.ts +3 -0
  44. package/package.json +1 -1
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.0%231E90FF.svg)]()
5
+ [![Angular Toolbox version](https://img.shields.io/badge/Angular%20Toolbox:1.4.2%231E90FF.svg)]()
6
6
 
7
7
  ## License
8
8
 
@@ -5,11 +5,12 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be found in
6
6
  * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license
7
7
  */
8
- import { Component, ContentChildren, ViewChild, HostListener, EventEmitter, Output } from '@angular/core';
8
+ import { Component, ContentChildren, ViewChild, HostListener, EventEmitter, Output, Inject } from '@angular/core';
9
9
  import { BorderLayoutContainer } from '../border-layout-container/border-layout-container.component';
10
10
  import { LayoutDragEventType } from '../../../model';
11
11
  import { BorderLayoutRenderer } from './util/border-layout-renderer';
12
12
  import { IdentifiableComponent } from '../../../core';
13
+ import { DOCUMENT } from '@angular/common';
13
14
  import * as i0 from "@angular/core";
14
15
  import * as i1 from "../../../model";
15
16
  /**
@@ -34,22 +35,22 @@ export class BorderLayout extends IdentifiableComponent {
34
35
  /**
35
36
  * @private
36
37
  */
37
- constructor(subscribeSvc) {
38
+ constructor(subscribeSvc, document) {
38
39
  super();
39
40
  this.subscribeSvc = subscribeSvc;
40
41
  /**
41
42
  * Emits events each time the user starts dragging a region handle.
42
43
  */
43
- this.dragStart = new EventEmitter(false);
44
+ this.dragStart = new EventEmitter();
44
45
  /**
45
46
  * Emits events each time the user stops dragging a region handle.
46
47
  */
47
- this.dragStop = new EventEmitter(false);
48
+ this.dragStop = new EventEmitter();
48
49
  /**
49
50
  * Emits events each time the user is dragging a region handle.
50
51
  */
51
- this.dragging = new EventEmitter(false);
52
- this.renderer = new BorderLayoutRenderer(subscribeSvc);
52
+ this.dragging = new EventEmitter();
53
+ this.renderer = new BorderLayoutRenderer(subscribeSvc, document);
53
54
  subscribeSvc.register(this, this.renderer.userAction.subscribe((event) => {
54
55
  event.layout = this;
55
56
  if (event.type === LayoutDragEventType.DRAGGING) {
@@ -101,13 +102,16 @@ export class BorderLayout extends IdentifiableComponent {
101
102
  resizeRegion(region, size) {
102
103
  this.renderer.resizeRegion(region, size);
103
104
  }
104
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BorderLayout, deps: [{ token: i1.SubscriptionService }], target: i0.ɵɵFactoryTarget.Component }); }
105
- 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,.atx-border-layout *{box-sizing:border-box}.atx-border-layout .content{height:100%;width:100%;overflow:auto}.atx-border-layout .drag{position:absolute;border:2px solid black}:host ::ng-deep .atx-handle{position:absolute}:host ::ng-deep .atx-handle:hover,:host ::ng-deep .atx-handle.atx-handle-selected{background-color:var(--atx-handle-color, #469afa)}:host ::ng-deep .north{position:absolute;z-index:10;top:0;left:0;right:0}:host ::ng-deep .north .atx-handle{left:0;right:0;bottom:0;height:4px;cursor:ns-resize}:host ::ng-deep .west{position:absolute;z-index:5;left:0;height:unset!important}:host ::ng-deep .west .atx-handle{right:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host ::ng-deep .east{position:absolute;z-index:5;right:0;height:unset!important}:host ::ng-deep .east .atx-handle{left:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host ::ng-deep .south{position:absolute;z-index:10;bottom:0;left:0;right:0}:host ::ng-deep .south .atx-handle{left:0;right:0;top:0;height:4px;cursor:ns-resize}:host ::ng-deep .center{position:absolute}\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"] }); }
105
+ 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
+ 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"] }); }
106
107
  }
107
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BorderLayout, decorators: [{
108
109
  type: Component,
109
- args: [{ selector: 'atx-border-layout', standalone: true, 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,.atx-border-layout *{box-sizing:border-box}.atx-border-layout .content{height:100%;width:100%;overflow:auto}.atx-border-layout .drag{position:absolute;border:2px solid black}:host ::ng-deep .atx-handle{position:absolute}:host ::ng-deep .atx-handle:hover,:host ::ng-deep .atx-handle.atx-handle-selected{background-color:var(--atx-handle-color, #469afa)}:host ::ng-deep .north{position:absolute;z-index:10;top:0;left:0;right:0}:host ::ng-deep .north .atx-handle{left:0;right:0;bottom:0;height:4px;cursor:ns-resize}:host ::ng-deep .west{position:absolute;z-index:5;left:0;height:unset!important}:host ::ng-deep .west .atx-handle{right:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host ::ng-deep .east{position:absolute;z-index:5;right:0;height:unset!important}:host ::ng-deep .east .atx-handle{left:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host ::ng-deep .south{position:absolute;z-index:10;bottom:0;left:0;right:0}:host ::ng-deep .south .atx-handle{left:0;right:0;top:0;height:4px;cursor:ns-resize}:host ::ng-deep .center{position:absolute}\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"] }]
110
- }], ctorParameters: () => [{ type: i1.SubscriptionService }], propDecorators: { dragStart: [{
110
+ args: [{ selector: 'atx-border-layout', standalone: true, 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"] }]
111
+ }], ctorParameters: () => [{ type: i1.SubscriptionService }, { type: Document, decorators: [{
112
+ type: Inject,
113
+ args: [DOCUMENT]
114
+ }] }], propDecorators: { dragStart: [{
111
115
  type: Output
112
116
  }], dragStop: [{
113
117
  type: Output
@@ -123,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
123
127
  type: ContentChildren,
124
128
  args: [BorderLayoutContainer]
125
129
  }] } });
126
- //# 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":"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","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be found in\r\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { AfterViewInit, Component, ContentChildren, OnDestroy, ElementRef, ViewChild, HostListener, QueryList, EventEmitter, Output } 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\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(false);\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(false);\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(false);\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    super();\r\n    this.renderer = new BorderLayoutRenderer(subscribeSvc);\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>"]}
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":"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","sourcesContent":["/**\r\n * @license\r\n * Copyright Pascal ECHEMANN. All Rights Reserved.\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be found in\r\n * the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license\r\n */\r\n\r\nimport { 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>"]}
@@ -34,17 +34,26 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
34
34
  /**
35
35
  * @private
36
36
  */
37
- constructor(subscribeSvc) {
37
+ constructor(subscribeSvc, document) {
38
38
  super();
39
39
  this.subscribeSvc = subscribeSvc;
40
+ this.document = document;
40
41
  /**
41
42
  * Emits events each time the user starts, or stops dragging handle.
42
43
  */
43
- this.userAction = new EventEmitter(false);
44
+ this.userAction = new EventEmitter();
44
45
  /**
45
46
  * @private
46
47
  */
47
48
  this.containerList = [];
49
+ /**
50
+ * @private
51
+ */
52
+ this.storedStopHandler = null;
53
+ /**
54
+ * @private
55
+ */
56
+ this.storedMoveHandler = null;
48
57
  this.boundsManager = new BorderLayoutBoundsManager();
49
58
  }
50
59
  /**
@@ -91,12 +100,17 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
91
100
  * Makes this object elligible for garbage collection.
92
101
  */
93
102
  destroy() {
103
+ if (this.storedStopHandler) {
104
+ this.document.removeEventListener(MOUSEMOVE, this.storedMoveHandler);
105
+ this.document.removeEventListener(MOUSEUP, this.storedStopHandler);
106
+ this.deleteStoredHandlers();
107
+ }
94
108
  this.subscribeSvc.clearAll(this);
95
- this.containerList.length = 0;
96
- this.containerList = null;
97
109
  this.lytContainerElm = null;
98
110
  this.boundsManager.destroy();
99
111
  this.boundsManager = null;
112
+ this.containerList.length = 0;
113
+ this.containerList = null;
100
114
  }
101
115
  /**
102
116
  * Forces the layout of all `BorderLayoutContainer` objects associated with the main container.
@@ -139,32 +153,36 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
139
153
  const region = constraints.region;
140
154
  const minSize = constraints.minSize;
141
155
  const maxSize = constraints.maxSize;
156
+ const doc = this.document;
142
157
  let size = 0;
143
158
  this.boundsManager.setOrigin(bounds.x, bounds.y);
144
159
  let resizeMethod = this.boundsManager.getResizeMethod(region);
145
160
  container.selected = true;
146
161
  const onMoveHandler = (event) => {
147
- event.preventDefault();
148
162
  event.stopPropagation();
163
+ event.preventDefault();
149
164
  size = resizeMethod(event, width, height, minSize, maxSize);
150
165
  container.setSize(size);
151
166
  this.render(width);
152
167
  this.fireEvent(container, LayoutDragEventType.DRAGGING);
153
168
  };
154
169
  const onStopHandler = (event) => {
155
- event.preventDefault();
156
170
  event.stopPropagation();
157
- lytNativeElm.removeEventListener(MOUSEMOVE, onMoveHandler);
158
- lytNativeElm.removeEventListener(MOUSEUP, onStopHandler);
171
+ event.preventDefault();
172
+ doc.removeEventListener(MOUSEMOVE, onMoveHandler);
173
+ doc.removeEventListener(MOUSEUP, onStopHandler);
174
+ this.deleteStoredHandlers();
159
175
  container.selected = false;
160
176
  size = resizeMethod(event, width, height, minSize, maxSize);
161
177
  container.setSize(size);
162
178
  this.render(width);
163
179
  this.fireEvent(container, LayoutDragEventType.DRAG_STOP);
164
180
  };
165
- lytNativeElm.addEventListener(MOUSEMOVE, onMoveHandler);
166
- lytNativeElm.addEventListener(MOUSEUP, onStopHandler);
181
+ this.storedMoveHandler = onMoveHandler;
182
+ this.storedStopHandler = onStopHandler;
167
183
  this.fireEvent(container, LayoutDragEventType.DRAG_START);
184
+ doc.addEventListener(MOUSEMOVE, onMoveHandler);
185
+ doc.addEventListener(MOUSEUP, onStopHandler);
168
186
  }
169
187
  /**
170
188
  * @private
@@ -182,31 +200,46 @@ export class BorderLayoutRenderer extends IdentifiableComponent {
182
200
  const bottom = bounds.bottom;
183
201
  const left = bounds.left;
184
202
  const right = bounds.right;
185
- this.containerList.forEach((cont) => {
203
+ const cList = this.containerList;
204
+ let cursor = cList.length - 1;
205
+ while (cursor >= 0) {
206
+ const cont = cList[cursor];
186
207
  const r = cont.constraints.region;
208
+ cursor--;
187
209
  if (r === LayoutRegion.WEST) {
188
210
  cont.setTopPos(top);
189
211
  cont.setRightPos(width - left);
190
212
  cont.setBottomPos(bottom - top);
191
- return;
213
+ continue;
192
214
  }
193
215
  if (r === LayoutRegion.CENTER) {
194
216
  cont.setTopPos(top);
195
217
  cont.setLeftPos(left);
196
218
  cont.setRightPos(right - left);
197
219
  cont.setBottomPos(bottom - top);
198
- return;
220
+ continue;
199
221
  }
200
222
  if (r === LayoutRegion.EAST) {
201
223
  cont.setTopPos(top);
202
224
  cont.setLeftPos(width - (right - left));
203
225
  cont.setBottomPos(bottom - top);
226
+ continue;
204
227
  }
205
- });
228
+ }
229
+ ;
206
230
  }
231
+ /**
232
+ * @private
233
+ */
207
234
  checkLytContainer() {
208
235
  if (!this.lytContainerElm)
209
236
  throw new ReferenceError(LAYOUT_ERR_MSG);
210
237
  }
238
+ /**
239
+ * @private
240
+ */
241
+ deleteStoredHandlers() {
242
+ this.storedMoveHandler = this.storedStopHandler = null;
243
+ }
211
244
  }
212
- //# 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(false);\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  constructor(private subscribeSvc: SubscriptionService) {\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    this.subscribeSvc.clearAll(this);\n    this.containerList.length = 0;\n    this.containerList = null as any;\n    this.lytContainerElm = null as any;\n    this.boundsManager.destroy();\n    this.boundsManager = 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    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.preventDefault();\n      event.stopPropagation();\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.preventDefault();\n      event.stopPropagation();\n      lytNativeElm.removeEventListener(MOUSEMOVE, onMoveHandler);\n      lytNativeElm.removeEventListener(MOUSEUP, onStopHandler);\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    lytNativeElm.addEventListener(MOUSEMOVE, onMoveHandler);\n    lytNativeElm.addEventListener(MOUSEUP, onStopHandler);\n    this.fireEvent(container, LayoutDragEventType.DRAG_START);\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    this.containerList.forEach((cont: BorderLayoutContainer) => {\n      const r: LayoutRegion = cont.constraints.region as LayoutRegion;\n      if (r === LayoutRegion.WEST) {\n        cont.setTopPos(top);\n        cont.setRightPos(width - left);\n        cont.setBottomPos(bottom - top);\n        return;\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        return;\n      }\n      if (r === LayoutRegion.EAST) {\n        cont.setTopPos(top);\n        cont.setLeftPos(width - (right - left));\n        cont.setBottomPos(bottom - top);\n      }\n    });\n  }\n\n  private checkLytContainer(): void {\n    if (!this.lytContainerElm) throw new ReferenceError(LAYOUT_ERR_MSG);\n  }\n}\n"]}
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"]}
@@ -129,11 +129,11 @@ export class BorderLayoutContainer {
129
129
  this.resizable = true;
130
130
  }
131
131
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BorderLayoutContainer, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
132
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: BorderLayoutContainer, isStandalone: true, selector: "atx-border-layout-container", inputs: { constraints: "constraints" }, host: { properties: { "class": "this.class" } }, 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<ng-content></ng-content>\n@if (resizable) {\n <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n", styles: [":host{box-sizing:border-box;padding:0;margin:0}\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"] }); }
132
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: BorderLayoutContainer, isStandalone: true, selector: "atx-border-layout-container", inputs: { constraints: "constraints" }, host: { properties: { "class": "this.class" } }, 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<ng-content></ng-content>\n@if (resizable) {\n <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n", styles: [":host{box-sizing:border-box;padding:0;margin:0}:host.north{position:absolute;z-index:10;top:0;left:0;right:0}:host.north>.atx-handle{left:0;right:0;bottom:0;height:4px;cursor:ns-resize}:host.west{position:absolute;z-index:5;left:0;height:unset!important}:host.west>.atx-handle{right:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host.east{position:absolute;z-index:5;right:0;height:unset!important}:host.east>.atx-handle{left:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host.south{position:absolute;z-index:10;bottom:0;left:0;right:0}:host.south>.atx-handle{left:0;right:0;top:0;height:4px;cursor:ns-resize}:host.center{position:absolute}.atx-handle{position:absolute}.atx-handle:hover,.atx-handle.atx-handle-selected{background-color:var(--atx-handle-color, #469afa)}\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"] }); }
133
133
  }
134
134
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: BorderLayoutContainer, decorators: [{
135
135
  type: Component,
136
- args: [{ selector: 'atx-border-layout-container', standalone: true, 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<ng-content></ng-content>\n@if (resizable) {\n <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n", styles: [":host{box-sizing:border-box;padding:0;margin:0}\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"] }]
136
+ args: [{ selector: 'atx-border-layout-container', standalone: true, 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<ng-content></ng-content>\n@if (resizable) {\n <div class=\"atx-handle\" [class.atx-handle-selected]=\"selected\" (mousedown)=\"resizetart()\"></div>\n}\n", styles: [":host{box-sizing:border-box;padding:0;margin:0}:host.north{position:absolute;z-index:10;top:0;left:0;right:0}:host.north>.atx-handle{left:0;right:0;bottom:0;height:4px;cursor:ns-resize}:host.west{position:absolute;z-index:5;left:0;height:unset!important}:host.west>.atx-handle{right:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host.east{position:absolute;z-index:5;right:0;height:unset!important}:host.east>.atx-handle{left:0;bottom:0;top:0;width:4px;cursor:ew-resize}:host.south{position:absolute;z-index:10;bottom:0;left:0;right:0}:host.south>.atx-handle{left:0;right:0;top:0;height:4px;cursor:ns-resize}:host.center{position:absolute}.atx-handle{position:absolute}.atx-handle:hover,.atx-handle.atx-handle-selected{background-color:var(--atx-handle-color, #469afa)}\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"] }]
137
137
  }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { class: [{
138
138
  type: HostBinding,
139
139
  args: ['class']
@@ -1,4 +1,5 @@
1
1
  export * from './mock/http';
2
2
  export * from './mock/http-monitoring-console';
3
+ export * from './mock/documentation';
3
4
  export * from './logging';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9mcmFtZXdvcmsvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5leHBvcnQgKiBmcm9tICcuL21vY2svaHR0cCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9jay9odHRwLW1vbml0b3JpbmctY29uc29sZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbG9nZ2luZyc7Il19
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9mcmFtZXdvcmsvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmV4cG9ydCAqIGZyb20gJy4vbW9jay9odHRwJztcclxuZXhwb3J0ICogZnJvbSAnLi9tb2NrL2h0dHAtbW9uaXRvcmluZy1jb25zb2xlJztcclxuZXhwb3J0ICogZnJvbSAnLi9tb2NrL2RvY3VtZW50YXRpb24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2xvZ2dpbmcnOyJdfQ==
@@ -0,0 +1,27 @@
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
6
+ * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license
7
+ */
8
+ import { Component, Input } from '@angular/core';
9
+ import { SafeHtmlPipe } from '../../../../../pipe';
10
+ import * as i0 from "@angular/core";
11
+ /**
12
+ * @private
13
+ * A conmponent that renders mock config description ppoperties.
14
+ */
15
+ export class AtxMockDescriptionComponent {
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockDescriptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AtxMockDescriptionComponent, isStandalone: true, selector: "atx-mock-description", inputs: { description: "description" }, 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 [innerHTML]=\"description | safeHtml\"></div>\r\n", dependencies: [{ kind: "pipe", type: SafeHtmlPipe, name: "safeHtml" }] }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockDescriptionComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: 'atx-mock-description', standalone: true, imports: [
22
+ SafeHtmlPipe
23
+ ], 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 [innerHTML]=\"description | safeHtml\"></div>\r\n" }]
24
+ }], propDecorators: { description: [{
25
+ type: Input
26
+ }] } });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR4LW1vY2stZGVzY3JpcHRpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10b29sYm94L3NyYy9saWIvZnJhbWV3b3JrL21vY2svZG9jdW1lbnRhdGlvbi9jb21wb25lbnQvYXR4LW1vY2stZGVzY3JpcHRpb24vYXR4LW1vY2stZGVzY3JpcHRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10b29sYm94L3NyYy9saWIvZnJhbWV3b3JrL21vY2svZG9jdW1lbnRhdGlvbi9jb21wb25lbnQvYXR4LW1vY2stZGVzY3JpcHRpb24vYXR4LW1vY2stZGVzY3JpcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUVuRDs7O0dBR0c7QUFTSCxNQUFNLE9BQU8sMkJBQTJCOzhHQUEzQiwyQkFBMkI7a0dBQTNCLDJCQUEyQix3SEN2QnhDLG1VQVNBLHVDRFVJLFlBQVk7OzJGQUlILDJCQUEyQjtrQkFSdkMsU0FBUzsrQkFDRSxzQkFBc0IsY0FDcEIsSUFBSSxXQUNQO3dCQUNQLFlBQVk7cUJBQ2I7OEJBVU0sV0FBVztzQkFEakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAbGljZW5zZVxyXG4gKiBDb3B5cmlnaHQgUGFzY2FsIEVDSEVNQU5OLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxyXG4gKlxyXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxyXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vcGFzY2FsZWNoZW1hbm4uY29tL2FuZ3VsYXItdG9vbGJveC9yZXNvdXJjZXMvbGljZW5zZVxyXG4gKi9cclxuXHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2FmZUh0bWxQaXBlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vcGlwZSc7XHJcblxyXG4vKipcclxuICogQHByaXZhdGVcclxuICogQSBjb25tcG9uZW50IHRoYXQgcmVuZGVycyBtb2NrIGNvbmZpZyBkZXNjcmlwdGlvbiBwcG9wZXJ0aWVzLlxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhdHgtbW9jay1kZXNjcmlwdGlvbicsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBTYWZlSHRtbFBpcGVcclxuICBdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hdHgtbW9jay1kZXNjcmlwdGlvbi5jb21wb25lbnQuaHRtbCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEF0eE1vY2tEZXNjcmlwdGlvbkNvbXBvbmVudCB7XHJcblxyXG4gIC8qKlxyXG4gICAqIEBwcml2YXRlXHJcbiAgICogVGhlIGRlc2NyaXB0aW9uIHRvIHJlbmRlci4gQ2FuIGNvbnRhaW5zIEhUTUwgdGFncy5cclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkZXNjcmlwdGlvbiE6IHN0cmluZztcclxufVxyXG4iLCI8IS0tXHJcbiAqIExJQ0VOU0VcclxuICogQ29weXJpZ2h0IFBhc2NhbCBFQ0hFTUFOTi4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cclxuICpcclxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcclxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL3Bhc2NhbGVjaGVtYW5uLmNvbS9hbmd1bGFyLXRvb2xib3gvcmVzb3VyY2VzL2xpY2Vuc2VcclxuLS0+XHJcblxyXG48ZGl2IFtpbm5lckhUTUxdPVwiZGVzY3JpcHRpb24gfCBzYWZlSHRtbFwiPjwvZGl2PlxyXG4iXX0=
@@ -0,0 +1,77 @@
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
6
+ * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license
7
+ */
8
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
9
+ import { EMPTY_STRING } from '../../../../../util';
10
+ import { AtxMockParamComponent } from '../atx-mock-param/atx-mock-param.component';
11
+ import { AtxMockDescriptionComponent } from '../atx-mock-description/atx-mock-description.component';
12
+ import { AtxMockFullDescriptionComponent } from '../atx-mock-full-description/atx-mock-full-description.component';
13
+ import { AtxMockMethodsComponent } from '../atx-mock-methods/atx-mock-methods.component';
14
+ import * as i0 from "@angular/core";
15
+ /**
16
+ * @private
17
+ */
18
+ const OPEN = "open";
19
+ /**
20
+ * @private
21
+ */
22
+ const DETAILS = "details";
23
+ /**
24
+ * An easy-to-use component that displays the documentation of a `HttpMockConfig` object.
25
+ */
26
+ export class AtxMockDocumentation {
27
+ /**
28
+ * Gets or sets the `HttpMockConfig` object for which to display documentation.
29
+ */
30
+ set config(value) {
31
+ this.configApi = value;
32
+ this.expanded = false;
33
+ }
34
+ get config() {
35
+ return this.configApi;
36
+ }
37
+ /**
38
+ * @private
39
+ */
40
+ constructor(elmRef) {
41
+ this.elmRef = elmRef;
42
+ /**
43
+ * @private
44
+ */
45
+ this.expanded = false;
46
+ /**
47
+ * Specifies the title of the current display.
48
+ */
49
+ this.title = "HTTP Mock API";
50
+ }
51
+ /**
52
+ * @private
53
+ */
54
+ toggleExpandState() {
55
+ const details = this.elmRef.nativeElement.querySelectorAll(DETAILS);
56
+ this.expanded = !this.expanded;
57
+ if (this.expanded)
58
+ return details.forEach((elm) => elm.setAttribute(OPEN, EMPTY_STRING));
59
+ details.forEach((elm) => elm.removeAttribute(OPEN));
60
+ }
61
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockDocumentation, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
62
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: AtxMockDocumentation, isStandalone: true, selector: "atx-mock-documentation", inputs: { title: "title", config: "config" }, 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@if (configApi) {\r\n <section>\r\n <h1>{{ title }}</h1>\r\n <h2>Description</h2>\r\n @if (configApi.description || configApi.origin) {\r\n <atx-mock-full-description [config]=\"configApi\"/>\r\n }\r\n </section>\r\n <section>\r\n <h2>Interceptors</h2>\r\n <button (click)=\"toggleExpandState()\">{{ expanded ? 'Collapse' : 'Expand' }} all</button>\r\n @if (configApi.interceptors) {\r\n @for (inteceptor of configApi.interceptors; track inteceptor) {\r\n <details>\r\n <summary>\r\n {{ inteceptor.id }}\r\n </summary>\r\n @if (inteceptor.description || inteceptor.origin) {\r\n <atx-mock-full-description [config]=\"inteceptor\"/>\r\n }\r\n @for (endpoint of inteceptor.endpoints; track endpoint; let last = $last) {\r\n <section class=\"endpoint\">\r\n <dl>\r\n <dt>route:</dt>\r\n <dd><code>{{ endpoint.route }}</code></dd>\r\n </dl>\r\n @if (endpoint.descriptor) {\r\n @if (endpoint.descriptor.description) {\r\n <atx-mock-description [description]=\"endpoint.descriptor.description\"/>\r\n }\r\n @if (endpoint.descriptor.params) {\r\n <h3>Parameters</h3>\r\n <atx-mock-param [params]=\"endpoint.descriptor.params\"/>\r\n }\r\n }\r\n <atx-mock-methods [endpoint]=\"endpoint\"/>\r\n </section>\r\n @if (!last) {\r\n <hr>\r\n }\r\n }\r\n </details>\r\n }\r\n }\r\n </section>\r\n}\r\n", styles: [":host,:host::ng-deep{font-family:Arial,Helvetica,sans-serif;line-height:1.5;-webkit-text-size-adjust:100%;margin:0;font-size:.95em}:host h1,:host h2,:host h3,:host h4,:host::ng-deep h1,:host::ng-deep h2,:host::ng-deep h3,:host::ng-deep h4{font-weight:700}:host h1,:host::ng-deep h1{font-size:1.5em;margin:.67em 0}:host h2,:host::ng-deep h2{font-size:1.25em}:host h3,:host::ng-deep h3{font-size:1em;text-decoration:underline}:host h4,:host::ng-deep h4{font-size:1em;margin:1em 0 0}:host hr,:host::ng-deep hr{box-sizing:content-box;height:0;overflow:visible}:host div,:host::ng-deep div{margin-top:1em;margin-bottom:1em}:host a,:host::ng-deep a{background-color:transparent}:host code,:host::ng-deep code{font-family:monospace,monospace;font-size:1.05em;color:orchid}:host button,:host::ng-deep button{font-family:inherit;font-size:.9em;line-height:1.15;margin:-45px 0 0;text-transform:none;padding:5px 10px;border:1px solid #aaa;border-radius:5px;float:right}:host details,:host::ng-deep details{display:block;border:1px solid #aaa;border-radius:4px;padding:.5em .5em 0;margin-bottom:.5em}:host summary,:host::ng-deep summary{display:list-item;font-weight:700;margin:-.5em -.5em 0;padding:.5em}:host details[open],:host::ng-deep details[open]{padding:.5em 1.5em}:host details[open] summary,:host::ng-deep details[open] summary{border-bottom:1px solid #aaa;margin-bottom:1em;padding:.5em 0}:host dl,:host::ng-deep dl{display:flex;margin:.5em 0}:host dt,:host::ng-deep dt{margin:0;font-weight:700}:host dd,:host::ng-deep dd{margin:0;margin-inline-start:10px}:host ul,:host::ng-deep ul{margin:0;padding-inline-start:40px;margin-block-start:1em;margin-block-end:1em}:host li,:host::ng-deep li{margin:0;display:flex;align-items:baseline}:host .endpoint,:host::ng-deep .endpoint{padding:.25em 1em;background-color:#eee;color:#000}:host .description,:host::ng-deep .description{margin-bottom:1em}:host span,:host::ng-deep span{text-transform:uppercase;display:inline-block;width:80px}:host .method-descriptor,:host::ng-deep .method-descriptor{line-height:.95em;margin:0}:host .method-descriptor dt,:host::ng-deep .method-descriptor dt{width:80px}:host .atx-mock-param-container,:host::ng-deep .atx-mock-param-container{padding-inline-start:40px;line-height:.95em}\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"], dependencies: [{ kind: "component", type: AtxMockParamComponent, selector: "atx-mock-param", inputs: ["params"] }, { kind: "component", type: AtxMockDescriptionComponent, selector: "atx-mock-description", inputs: ["description"] }, { kind: "component", type: AtxMockFullDescriptionComponent, selector: "atx-mock-full-description", inputs: ["config"] }, { kind: "component", type: AtxMockMethodsComponent, selector: "atx-mock-methods", inputs: ["endpoint"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
63
+ }
64
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockDocumentation, decorators: [{
65
+ type: Component,
66
+ args: [{ selector: 'atx-mock-documentation', standalone: true, imports: [
67
+ AtxMockParamComponent,
68
+ AtxMockDescriptionComponent,
69
+ AtxMockFullDescriptionComponent,
70
+ AtxMockMethodsComponent
71
+ ], changeDetection: ChangeDetectionStrategy.OnPush, 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@if (configApi) {\r\n <section>\r\n <h1>{{ title }}</h1>\r\n <h2>Description</h2>\r\n @if (configApi.description || configApi.origin) {\r\n <atx-mock-full-description [config]=\"configApi\"/>\r\n }\r\n </section>\r\n <section>\r\n <h2>Interceptors</h2>\r\n <button (click)=\"toggleExpandState()\">{{ expanded ? 'Collapse' : 'Expand' }} all</button>\r\n @if (configApi.interceptors) {\r\n @for (inteceptor of configApi.interceptors; track inteceptor) {\r\n <details>\r\n <summary>\r\n {{ inteceptor.id }}\r\n </summary>\r\n @if (inteceptor.description || inteceptor.origin) {\r\n <atx-mock-full-description [config]=\"inteceptor\"/>\r\n }\r\n @for (endpoint of inteceptor.endpoints; track endpoint; let last = $last) {\r\n <section class=\"endpoint\">\r\n <dl>\r\n <dt>route:</dt>\r\n <dd><code>{{ endpoint.route }}</code></dd>\r\n </dl>\r\n @if (endpoint.descriptor) {\r\n @if (endpoint.descriptor.description) {\r\n <atx-mock-description [description]=\"endpoint.descriptor.description\"/>\r\n }\r\n @if (endpoint.descriptor.params) {\r\n <h3>Parameters</h3>\r\n <atx-mock-param [params]=\"endpoint.descriptor.params\"/>\r\n }\r\n }\r\n <atx-mock-methods [endpoint]=\"endpoint\"/>\r\n </section>\r\n @if (!last) {\r\n <hr>\r\n }\r\n }\r\n </details>\r\n }\r\n }\r\n </section>\r\n}\r\n", styles: [":host,:host::ng-deep{font-family:Arial,Helvetica,sans-serif;line-height:1.5;-webkit-text-size-adjust:100%;margin:0;font-size:.95em}:host h1,:host h2,:host h3,:host h4,:host::ng-deep h1,:host::ng-deep h2,:host::ng-deep h3,:host::ng-deep h4{font-weight:700}:host h1,:host::ng-deep h1{font-size:1.5em;margin:.67em 0}:host h2,:host::ng-deep h2{font-size:1.25em}:host h3,:host::ng-deep h3{font-size:1em;text-decoration:underline}:host h4,:host::ng-deep h4{font-size:1em;margin:1em 0 0}:host hr,:host::ng-deep hr{box-sizing:content-box;height:0;overflow:visible}:host div,:host::ng-deep div{margin-top:1em;margin-bottom:1em}:host a,:host::ng-deep a{background-color:transparent}:host code,:host::ng-deep code{font-family:monospace,monospace;font-size:1.05em;color:orchid}:host button,:host::ng-deep button{font-family:inherit;font-size:.9em;line-height:1.15;margin:-45px 0 0;text-transform:none;padding:5px 10px;border:1px solid #aaa;border-radius:5px;float:right}:host details,:host::ng-deep details{display:block;border:1px solid #aaa;border-radius:4px;padding:.5em .5em 0;margin-bottom:.5em}:host summary,:host::ng-deep summary{display:list-item;font-weight:700;margin:-.5em -.5em 0;padding:.5em}:host details[open],:host::ng-deep details[open]{padding:.5em 1.5em}:host details[open] summary,:host::ng-deep details[open] summary{border-bottom:1px solid #aaa;margin-bottom:1em;padding:.5em 0}:host dl,:host::ng-deep dl{display:flex;margin:.5em 0}:host dt,:host::ng-deep dt{margin:0;font-weight:700}:host dd,:host::ng-deep dd{margin:0;margin-inline-start:10px}:host ul,:host::ng-deep ul{margin:0;padding-inline-start:40px;margin-block-start:1em;margin-block-end:1em}:host li,:host::ng-deep li{margin:0;display:flex;align-items:baseline}:host .endpoint,:host::ng-deep .endpoint{padding:.25em 1em;background-color:#eee;color:#000}:host .description,:host::ng-deep .description{margin-bottom:1em}:host span,:host::ng-deep span{text-transform:uppercase;display:inline-block;width:80px}:host .method-descriptor,:host::ng-deep .method-descriptor{line-height:.95em;margin:0}:host .method-descriptor dt,:host::ng-deep .method-descriptor dt{width:80px}:host .atx-mock-param-container,:host::ng-deep .atx-mock-param-container{padding-inline-start:40px;line-height:.95em}\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"] }]
72
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { title: [{
73
+ type: Input
74
+ }], config: [{
75
+ type: Input
76
+ }] } });
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atx-mock-documentation.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/angular-toolbox/src/lib/framework/mock/documentation/component/atx-mock-documentation/atx-mock-documentation.component.ts","../../../../../../../../../projects/angular-toolbox/src/lib/framework/mock/documentation/component/atx-mock-documentation/atx-mock-documentation.component.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtF,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACnF,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,+BAA+B,EAAE,MAAM,kEAAkE,CAAC;AACnH,OAAO,EAAE,uBAAuB,EAAE,MAAM,gDAAgD,CAAC;;AAEzF;;GAEG;AACH,MAAM,IAAI,GAAW,MAAM,CAAC;AAE5B;;GAEG;AACH,MAAM,OAAO,GAAW,SAAS,CAAC;AAElC;;GAEG;AAcH,MAAM,OAAO,oBAAoB;IAkB/B;;OAEG;IACH,IACW,MAAM,CAAC,KAAqB;QACrC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED;;OAEG;IACH,YAAoB,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;QA1BtC;;WAEG;QACO,aAAQ,GAAY,KAAK,CAAC;QAEpC;;WAEG;QAEI,UAAK,GAAW,eAAe,CAAC;IAiBE,CAAC;IAE1C;;OAEG;IACO,iBAAiB;QACzB,MAAM,OAAO,GAAyB,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC1F,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,GAAuB,EAAE,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC,CAAC;QAC7G,OAAO,CAAC,OAAO,CAAC,CAAC,GAAuB,EAAE,EAAE,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,CAAC;8GA3CU,oBAAoB;kGAApB,oBAAoB,gIC1CjC,w1EAsDA,ogFDrBI,qBAAqB,+EACrB,2BAA2B,0FAC3B,+BAA+B,0FAC/B,uBAAuB;;2FAMd,oBAAoB;kBAbhC,SAAS;+BACE,wBAAwB,cACtB,IAAI,WACP;wBACP,qBAAqB;wBACrB,2BAA2B;wBAC3B,+BAA+B;wBAC/B,uBAAuB;qBACxB,mBAGgB,uBAAuB,CAAC,MAAM;+EAkBxC,KAAK;sBADX,KAAK;gBAOK,MAAM;sBADhB,KAAK","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 { ChangeDetectionStrategy, Component, ElementRef, Input } from '@angular/core';\r\nimport { HttpMockConfig } from '../../../../../model';\r\nimport { EMPTY_STRING } from '../../../../../util';\r\nimport { AtxMockParamComponent } from '../atx-mock-param/atx-mock-param.component';\r\nimport { AtxMockDescriptionComponent } from '../atx-mock-description/atx-mock-description.component';\r\nimport { AtxMockFullDescriptionComponent } from '../atx-mock-full-description/atx-mock-full-description.component';\r\nimport { AtxMockMethodsComponent } from '../atx-mock-methods/atx-mock-methods.component';\r\n\r\n/**\r\n * @private\r\n */\r\nconst OPEN: string = \"open\";\r\n\r\n/**\r\n * @private\r\n */\r\nconst DETAILS: string = \"details\";\r\n\r\n/**\r\n * An easy-to-use component that displays the documentation of a `HttpMockConfig` object.\r\n */\r\n@Component({\r\n  selector: 'atx-mock-documentation',\r\n  standalone: true,\r\n  imports: [\r\n    AtxMockParamComponent,\r\n    AtxMockDescriptionComponent,\r\n    AtxMockFullDescriptionComponent,\r\n    AtxMockMethodsComponent\r\n  ],\r\n  templateUrl: './atx-mock-documentation.component.html',\r\n  styleUrl: './atx-mock-documentation.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class AtxMockDocumentation {\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected configApi!: HttpMockConfig;\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected expanded: boolean = false;\r\n\r\n  /**\r\n   * Specifies the title of the current display.\r\n   */\r\n  @Input()\r\n  public title: string = \"HTTP Mock API\";\r\n\r\n  /**\r\n   * Gets or sets the `HttpMockConfig` object for which to display documentation.\r\n   */\r\n  @Input()\r\n  public set config(value: HttpMockConfig) {\r\n    this.configApi = value;\r\n    this.expanded = false;\r\n  }\r\n  public get config(): HttpMockConfig {\r\n    return this.configApi;\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  constructor(private elmRef: ElementRef) {}\r\n\r\n  /**\r\n   * @private\r\n   */\r\n  protected toggleExpandState(): void {\r\n    const details: HTMLDetailsElement[] = this.elmRef.nativeElement.querySelectorAll(DETAILS);\r\n    this.expanded = !this.expanded;\r\n    if (this.expanded) return details.forEach((elm: HTMLDetailsElement) => elm.setAttribute(OPEN, EMPTY_STRING));\r\n    details.forEach((elm: HTMLDetailsElement) => elm.removeAttribute(OPEN));\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@if (configApi) {\r\n    <section>\r\n        <h1>{{ title }}</h1>\r\n        <h2>Description</h2>\r\n        @if (configApi.description || configApi.origin) {\r\n            <atx-mock-full-description [config]=\"configApi\"/>\r\n        }\r\n    </section>\r\n    <section>\r\n        <h2>Interceptors</h2>\r\n        <button (click)=\"toggleExpandState()\">{{ expanded ? 'Collapse' : 'Expand' }} all</button>\r\n        @if (configApi.interceptors) {\r\n            @for (inteceptor of configApi.interceptors; track inteceptor) {\r\n                <details>\r\n                    <summary>\r\n                        {{ inteceptor.id }}\r\n                    </summary>\r\n                    @if (inteceptor.description || inteceptor.origin) {\r\n                        <atx-mock-full-description [config]=\"inteceptor\"/>\r\n                    }\r\n                    @for (endpoint of inteceptor.endpoints; track endpoint; let last = $last) {\r\n                        <section class=\"endpoint\">\r\n                            <dl>\r\n                                <dt>route:</dt>\r\n                                <dd><code>{{ endpoint.route }}</code></dd>\r\n                            </dl>\r\n                            @if (endpoint.descriptor) {\r\n                                @if (endpoint.descriptor.description) {\r\n                                    <atx-mock-description [description]=\"endpoint.descriptor.description\"/>\r\n                                }\r\n                                @if (endpoint.descriptor.params) {\r\n                                    <h3>Parameters</h3>\r\n                                    <atx-mock-param [params]=\"endpoint.descriptor.params\"/>\r\n                                }\r\n                            }\r\n                            <atx-mock-methods [endpoint]=\"endpoint\"/>\r\n                        </section>\r\n                        @if (!last) {\r\n                            <hr>\r\n                        }\r\n                    }\r\n                </details>\r\n            }\r\n        }\r\n    </section>\r\n}\r\n"]}
@@ -0,0 +1,27 @@
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
6
+ * found in the LICENSE file at https://pascalechemann.com/angular-toolbox/resources/license
7
+ */
8
+ import { Component, Input } from '@angular/core';
9
+ import { AtxMockDescriptionComponent } from '../atx-mock-description/atx-mock-description.component';
10
+ import * as i0 from "@angular/core";
11
+ /**
12
+ * @private
13
+ * A convenient component that displays the description and the origin of a mock config section.
14
+ */
15
+ export class AtxMockFullDescriptionComponent {
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockFullDescriptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: AtxMockFullDescriptionComponent, isStandalone: true, selector: "atx-mock-full-description", inputs: { config: "config" }, 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@if (config) {\r\n <div class=\"description\">\r\n @if (config.description) {\r\n <atx-mock-description [description]=\"config.description\"/>\r\n }\r\n @if (config.origin) {\r\n <dl>\r\n <dt>origin:</dt>\r\n <dd><a [href]=\"config.origin\" [title]=\"config.origin\"><code>{{ config.origin }}</code></a></dd>\r\n </dl>\r\n }\r\n </div>\r\n}\r\n", dependencies: [{ kind: "component", type: AtxMockDescriptionComponent, selector: "atx-mock-description", inputs: ["description"] }] }); }
18
+ }
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AtxMockFullDescriptionComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: 'atx-mock-full-description', standalone: true, imports: [
22
+ AtxMockDescriptionComponent
23
+ ], 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@if (config) {\r\n <div class=\"description\">\r\n @if (config.description) {\r\n <atx-mock-description [description]=\"config.description\"/>\r\n }\r\n @if (config.origin) {\r\n <dl>\r\n <dt>origin:</dt>\r\n <dd><a [href]=\"config.origin\" [title]=\"config.origin\"><code>{{ config.origin }}</code></a></dd>\r\n </dl>\r\n }\r\n </div>\r\n}\r\n" }]
24
+ }], propDecorators: { config: [{
25
+ type: Input
26
+ }] } });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR4LW1vY2stZnVsbC1kZXNjcmlwdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9mcmFtZXdvcmsvbW9jay9kb2N1bWVudGF0aW9uL2NvbXBvbmVudC9hdHgtbW9jay1mdWxsLWRlc2NyaXB0aW9uL2F0eC1tb2NrLWZ1bGwtZGVzY3JpcHRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10b29sYm94L3NyYy9saWIvZnJhbWV3b3JrL21vY2svZG9jdW1lbnRhdGlvbi9jb21wb25lbnQvYXR4LW1vY2stZnVsbC1kZXNjcmlwdGlvbi9hdHgtbW9jay1mdWxsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDOztBQUdyRzs7O0dBR0c7QUFTSCxNQUFNLE9BQU8sK0JBQStCOzhHQUEvQiwrQkFBK0I7a0dBQS9CLCtCQUErQixtSEN4QjVDLHVzQkFxQkEsNENEREksMkJBQTJCOzsyRkFJbEIsK0JBQStCO2tCQVIzQyxTQUFTOytCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1A7d0JBQ1AsMkJBQTJCO3FCQUM1Qjs4QkFVTSxNQUFNO3NCQURaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQGxpY2Vuc2VcclxuICogQ29weXJpZ2h0IFBhc2NhbCBFQ0hFTUFOTi4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cclxuICpcclxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcclxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL3Bhc2NhbGVjaGVtYW5uLmNvbS9hbmd1bGFyLXRvb2xib3gvcmVzb3VyY2VzL2xpY2Vuc2VcclxuICovXHJcblxyXG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEF0eE1vY2tEZXNjcmlwdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL2F0eC1tb2NrLWRlc2NyaXB0aW9uL2F0eC1tb2NrLWRlc2NyaXB0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZ1bGxEZXNjcmlwdGlvbiB9IGZyb20gJy4uLy4uL21vZGVsL2J1c2luZXNzL2Z1bGwtZGVzY3JpcHRpb24udHlwZSc7XHJcblxyXG4vKipcclxuICogQHByaXZhdGVcclxuICogQSBjb252ZW5pZW50IGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIHRoZSBkZXNjcmlwdGlvbiBhbmQgdGhlIG9yaWdpbiBvZiBhIG1vY2sgY29uZmlnIHNlY3Rpb24uXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F0eC1tb2NrLWZ1bGwtZGVzY3JpcHRpb24nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQXR4TW9ja0Rlc2NyaXB0aW9uQ29tcG9uZW50XHJcbiAgXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXR4LW1vY2stZnVsbC1kZXNjcmlwdGlvbi5jb21wb25lbnQuaHRtbCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEF0eE1vY2tGdWxsRGVzY3JpcHRpb25Db21wb25lbnQge1xyXG5cclxuICAvKipcclxuICAgKiBAcHVibGljXHJcbiAgICogVGhlIGNvbmZpZyBvYmplY3QgdGFodCBjb250YWlucyB0aGUgZGVzY3JpcHRpb24gdG8gZGlzcGxheS5cclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb25maWchOiBGdWxsRGVzY3JpcHRpb247XHJcbn1cclxuIiwiPCEtLVxyXG4gKiBMSUNFTlNFXHJcbiAqIENvcHlyaWdodCBQYXNjYWwgRUNIRU1BTk4uIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXHJcbiAqXHJcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXHJcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9wYXNjYWxlY2hlbWFubi5jb20vYW5ndWxhci10b29sYm94L3Jlc291cmNlcy9saWNlbnNlXHJcbi0tPlxyXG4gXHJcbkBpZiAoY29uZmlnKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwiZGVzY3JpcHRpb25cIj5cclxuICAgICAgICBAaWYgKGNvbmZpZy5kZXNjcmlwdGlvbikge1xyXG4gICAgICAgICAgICA8YXR4LW1vY2stZGVzY3JpcHRpb24gW2Rlc2NyaXB0aW9uXT1cImNvbmZpZy5kZXNjcmlwdGlvblwiLz5cclxuICAgICAgICB9XHJcbiAgICAgICAgQGlmIChjb25maWcub3JpZ2luKSB7XHJcbiAgICAgICAgICAgIDxkbD5cclxuICAgICAgICAgICAgICAgIDxkdD5vcmlnaW46PC9kdD5cclxuICAgICAgICAgICAgICAgIDxkZD48YSBbaHJlZl09XCJjb25maWcub3JpZ2luXCIgW3RpdGxlXT1cImNvbmZpZy5vcmlnaW5cIj48Y29kZT57eyBjb25maWcub3JpZ2luIH19PC9jb2RlPjwvYT48L2RkPlxyXG4gICAgICAgICAgICA8L2RsPlxyXG4gICAgICAgIH1cclxuICAgIDwvZGl2PlxyXG59XHJcbiJdfQ==