angular-toolbox 1.4.1 → 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.
- package/README.md +1 -1
- package/esm2022/lib/component/layout/border-layout/border-layout.component.mjs +15 -11
- package/esm2022/lib/component/layout/border-layout/util/border-layout-renderer.mjs +48 -15
- package/esm2022/lib/component/layout/border-layout-container/border-layout-container.component.mjs +2 -2
- package/esm2022/lib/model/service/version/angular-toolbox-version.service.mjs +3 -3
- package/fesm2022/angular-toolbox.mjs +63 -27
- package/fesm2022/angular-toolbox.mjs.map +1 -1
- package/lib/component/layout/border-layout/border-layout.component.d.ts +1 -1
- package/lib/component/layout/border-layout/util/border-layout-renderer.d.ts +17 -1
- 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
|
-
[]()
|
|
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(
|
|
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(
|
|
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(
|
|
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
|
|
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
|
|
110
|
-
}], ctorParameters: () => [{ type: i1.SubscriptionService }
|
|
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,
|
|
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(
|
|
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
|
-
|
|
158
|
-
|
|
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
|
-
|
|
166
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
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"]}
|
package/esm2022/lib/component/layout/border-layout-container/border-layout-container.component.mjs
CHANGED
|
@@ -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']
|
|
@@ -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:
|
|
19
|
-
buildTimestamp:
|
|
18
|
+
patch: 2,
|
|
19
|
+
buildTimestamp: 1728546812271
|
|
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,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10b29sYm94LXZlcnNpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdG9vbGJveC9zcmMvbGliL21vZGVsL3NlcnZpY2UvdmVyc2lvbi9hbmd1bGFyLXRvb2xib3gtdmVyc2lvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUd2RDs7O0dBR0c7QUFDSCxNQUFNLGtCQUFrQixHQUFrQjtJQUN4QyxLQUFLLEVBQUUsQ0FBQztJQUNSLEtBQUssRUFBRSxDQUFDO0lBQ1IsS0FBSyxFQUFFLENBQUM7SUFDUixjQUFjLEVBQUUsYUFBYTtDQUM5QixDQUFDO0FBRUY7O0dBRUc7QUFFSCxNQUFNLE9BQU8sNEJBQTZCLFNBQVEsc0JBQXNCO0lBRXRFOztPQUVHO0lBQ0g7UUFDRSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUM1QixDQUFDOzhHQVBVLDRCQUE0QjtrSEFBNUIsNEJBQTRCOzsyRkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEBsaWNlbnNlXHJcbiAqIENvcHlyaWdodCBQYXNjYWwgRUNIRU1BTk4uIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXHJcbiAqXHJcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlIGZvdW5kIGluXHJcbiAqIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9wYXNjYWxlY2hlbWFubi5jb20vYW5ndWxhci10b29sYm94L3Jlc291cmNlcy9saWNlbnNlXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdFZlcnNpb25NYW5hZ2VyIH0gZnJvbSAnLi4vLi4vLi4vY29yZSc7XHJcbmltcG9ydCB7IFZlcnNpb25Db25maWcgfSBmcm9tICcuLi8uLi9idXNpbmVzcyc7XHJcblxyXG4vKipcclxuICogQHByaXZhdGVcclxuICogVGhlIGN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgQW5ndWxhciBUb29sYm94IGxpYnJhcnkuXHJcbiAqL1xyXG5jb25zdCBBVFhfVkVSU0lPTl9DT05GSUc6IFZlcnNpb25Db25maWcgPSB7XHJcbiAgbWFqb3I6IDEsXHJcbiAgbWlub3I6IDQsXHJcbiAgcGF0Y2g6IDIsXHJcbiAgYnVpbGRUaW1lc3RhbXA6IDE3Mjg1NDY4MTIyNzFcclxufTtcclxuXHJcbi8qKlxyXG4gKiBUaGUgcHVibGljIHNlcnZpY2UgdGhhdCBleHBvc2VzIHRoZSBjdXJyZW50IHZlcnNpb24gb2YgdGhlIEFuZ3VsYXIgVG9vbGJveCBsaWJyYXJ5LlxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclRvb2xib3hWZXJzaW9uU2VydmljZSBleHRlbmRzIEFic3RyYWN0VmVyc2lvbk1hbmFnZXIge1xyXG5cclxuICAvKipcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgc3VwZXIoQVRYX1ZFUlNJT05fQ09ORklHKTtcclxuICB9XHJcbn1cclxuIl19
|