@ali-hm/angular-tree-component 18.0.0 → 18.0.1

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 (64) hide show
  1. package/{esm2022 → esm2020}/ali-hm-angular-tree-component.mjs +4 -4
  2. package/{esm2022 → esm2020}/lib/angular-tree-component.module.mjs +100 -100
  3. package/{esm2022 → esm2020}/lib/components/loading.component.mjs +21 -21
  4. package/{esm2022 → esm2020}/lib/components/tree-node-checkbox.component.mjs +15 -15
  5. package/esm2020/lib/components/tree-node-collection.component.mjs +284 -0
  6. package/{esm2022 → esm2020}/lib/components/tree-node-content.component.mjs +23 -23
  7. package/{esm2022 → esm2020}/lib/components/tree-node-drop-slot.component.mjs +26 -26
  8. package/{esm2022 → esm2020}/lib/components/tree-node-expander.component.mjs +16 -16
  9. package/{esm2022 → esm2020}/lib/components/tree-node-wrapper.component.mjs +24 -24
  10. package/{esm2022 → esm2020}/lib/components/tree-viewport.component.mjs +55 -55
  11. package/esm2020/lib/components/tree.component.mjs +186 -0
  12. package/{esm2022 → esm2020}/lib/constants/events.mjs +19 -19
  13. package/{esm2022 → esm2020}/lib/constants/keys.mjs +9 -9
  14. package/{esm2022 → esm2020}/lib/defs/api.mjs +1 -1
  15. package/esm2020/lib/directives/tree-animate-open.directive.mjs +101 -0
  16. package/{esm2022 → esm2020}/lib/directives/tree-drag.directive.mjs +65 -65
  17. package/esm2020/lib/directives/tree-drop.directive.mjs +127 -0
  18. package/{esm2022 → esm2020}/lib/mobx-angular/mobx-proxy.mjs +16 -16
  19. package/esm2020/lib/mobx-angular/tree-mobx-autorun.directive.mjs +40 -0
  20. package/{esm2022 → esm2020}/lib/models/tree-dragged-element.model.mjs +25 -25
  21. package/esm2020/lib/models/tree-node.model.mjs +390 -0
  22. package/esm2020/lib/models/tree-options.model.mjs +150 -0
  23. package/esm2020/lib/models/tree-virtual-scroll.model.mjs +197 -0
  24. package/esm2020/lib/models/tree.model.mjs +546 -0
  25. package/{esm2022 → esm2020}/public-api.mjs +4 -4
  26. package/fesm2015/ali-hm-angular-tree-component.mjs +2511 -0
  27. package/fesm2015/ali-hm-angular-tree-component.mjs.map +1 -0
  28. package/{fesm2022 → fesm2020}/ali-hm-angular-tree-component.mjs +2080 -2080
  29. package/{fesm2022 → fesm2020}/ali-hm-angular-tree-component.mjs.map +1 -1
  30. package/index.d.ts +5 -5
  31. package/lib/angular-tree-component.module.d.ts +43 -43
  32. package/lib/components/loading.component.d.ts +9 -9
  33. package/lib/components/tree-node-checkbox.component.d.ts +7 -7
  34. package/lib/components/tree-node-collection.component.d.ts +34 -34
  35. package/lib/components/tree-node-content.component.d.ts +10 -10
  36. package/lib/components/tree-node-drop-slot.component.d.ts +10 -10
  37. package/lib/components/tree-node-expander.component.d.ts +7 -7
  38. package/lib/components/tree-node-wrapper.component.d.ts +9 -9
  39. package/lib/components/tree-viewport.component.d.ts +17 -17
  40. package/lib/components/tree.component.d.ts +47 -47
  41. package/lib/constants/events.d.ts +19 -19
  42. package/lib/constants/keys.d.ts +9 -9
  43. package/lib/defs/api.d.ts +611 -611
  44. package/lib/directives/tree-animate-open.directive.d.ts +20 -20
  45. package/lib/directives/tree-drag.directive.d.ts +21 -21
  46. package/lib/directives/tree-drop.directive.d.ts +33 -33
  47. package/lib/mobx-angular/mobx-proxy.d.ts +7 -7
  48. package/lib/mobx-angular/tree-mobx-autorun.directive.d.ts +17 -17
  49. package/lib/models/tree-dragged-element.model.d.ts +9 -9
  50. package/lib/models/tree-node.model.d.ts +83 -83
  51. package/lib/models/tree-options.model.d.ts +77 -77
  52. package/lib/models/tree-virtual-scroll.model.d.ts +27 -27
  53. package/lib/models/tree.model.d.ts +91 -91
  54. package/package.json +16 -10
  55. package/public-api.d.ts +1 -1
  56. package/esm2022/lib/components/tree-node-collection.component.mjs +0 -284
  57. package/esm2022/lib/components/tree.component.mjs +0 -186
  58. package/esm2022/lib/directives/tree-animate-open.directive.mjs +0 -101
  59. package/esm2022/lib/directives/tree-drop.directive.mjs +0 -127
  60. package/esm2022/lib/mobx-angular/tree-mobx-autorun.directive.mjs +0 -40
  61. package/esm2022/lib/models/tree-node.model.mjs +0 -390
  62. package/esm2022/lib/models/tree-options.model.mjs +0 -150
  63. package/esm2022/lib/models/tree-virtual-scroll.model.mjs +0 -197
  64. package/esm2022/lib/models/tree.model.mjs +0 -546
@@ -1,186 +0,0 @@
1
- import { Component, ContentChild, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
2
- import { TreeModel } from '../models/tree.model';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../models/tree.model";
5
- import * as i2 from "../models/tree-dragged-element.model";
6
- import * as i3 from "@angular/common";
7
- import * as i4 from "./tree-node-drop-slot.component";
8
- import * as i5 from "./tree-node-collection.component";
9
- import * as i6 from "./tree-viewport.component";
10
- export class TreeComponent {
11
- // Will be handled in ngOnChanges
12
- set nodes(nodes) {
13
- }
14
- ;
15
- set options(options) {
16
- }
17
- ;
18
- set focused(value) {
19
- this.treeModel.setFocus(value);
20
- }
21
- set state(state) {
22
- this.treeModel.setState(state);
23
- }
24
- constructor(treeModel, treeDraggedElement) {
25
- this.treeModel = treeModel;
26
- this.treeDraggedElement = treeDraggedElement;
27
- treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());
28
- treeModel.subscribeToState((state) => this.stateChange.emit(state));
29
- }
30
- onKeydown($event) {
31
- if (!this.treeModel.isFocused)
32
- return;
33
- if (['input', 'textarea'].includes(document.activeElement.tagName.toLowerCase()))
34
- return;
35
- const focusedNode = this.treeModel.getFocusedNode();
36
- this.treeModel.performKeyAction(focusedNode, $event);
37
- }
38
- onMousedown($event) {
39
- function isOutsideClick(startElement, nodeName) {
40
- return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);
41
- }
42
- if (isOutsideClick($event.target, 'tree-root')) {
43
- this.treeModel.setFocus(false);
44
- }
45
- }
46
- ngOnChanges(changes) {
47
- if (changes.options || changes.nodes) {
48
- this.treeModel.setData({
49
- options: changes.options && changes.options.currentValue,
50
- nodes: changes.nodes && changes.nodes.currentValue,
51
- events: this.pick(this, this.treeModel.eventNames)
52
- });
53
- }
54
- }
55
- sizeChanged() {
56
- this.viewportComponent.setViewport();
57
- }
58
- pick(object, keys) {
59
- return keys.reduce((obj, key) => {
60
- if (object && object.hasOwnProperty(key)) {
61
- obj[key] = object[key];
62
- }
63
- return obj;
64
- }, {});
65
- }
66
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeComponent, deps: [{ token: i1.TreeModel }, { token: i2.TreeDraggedElement }], target: i0.ɵɵFactoryTarget.Component }); }
67
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: TreeComponent, selector: "Tree, tree-root", inputs: { nodes: "nodes", options: "options", focused: "focused", state: "state" }, outputs: { toggleExpanded: "toggleExpanded", activate: "activate", deactivate: "deactivate", nodeActivate: "nodeActivate", nodeDeactivate: "nodeDeactivate", select: "select", deselect: "deselect", focus: "focus", blur: "blur", updateData: "updateData", initialized: "initialized", moveNode: "moveNode", copyNode: "copyNode", loadNodeChildren: "loadNodeChildren", changeFilter: "changeFilter", event: "event", stateChange: "stateChange" }, host: { listeners: { "body: keydown": "onKeydown($event)", "body: mousedown": "onMousedown($event)" } }, providers: [TreeModel], queries: [{ propertyName: "loadingTemplate", first: true, predicate: ["loadingTemplate"], descendants: true }, { propertyName: "treeNodeTemplate", first: true, predicate: ["treeNodeTemplate"], descendants: true }, { propertyName: "treeNodeWrapperTemplate", first: true, predicate: ["treeNodeWrapperTemplate"], descendants: true }, { propertyName: "treeNodeFullTemplate", first: true, predicate: ["treeNodeFullTemplate"], descendants: true }], viewQueries: [{ propertyName: "viewportComponent", first: true, predicate: ["viewport"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
68
- <tree-viewport #viewport>
69
- <div
70
- class="angular-tree-component"
71
- [class.node-dragging]="treeDraggedElement.isDragging()"
72
- [class.angular-tree-component-rtl]="treeModel.options.rtl">
73
- <tree-node-collection
74
- *ngIf="treeModel.roots"
75
- [nodes]="treeModel.roots"
76
- [treeModel]="treeModel"
77
- [templates]="{
78
- loadingTemplate: loadingTemplate,
79
- treeNodeTemplate: treeNodeTemplate,
80
- treeNodeWrapperTemplate: treeNodeWrapperTemplate,
81
- treeNodeFullTemplate: treeNodeFullTemplate
82
- }">
83
- </tree-node-collection>
84
- <tree-node-drop-slot
85
- class="empty-tree-drop-slot"
86
- *ngIf="treeModel.isEmptyTree()"
87
- [dropIndex]="0"
88
- [node]="treeModel.virtualRoot">
89
- </tree-node-drop-slot>
90
- </div>
91
- </tree-viewport>
92
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TreeNodeDropSlot, selector: "TreeNodeDropSlot, tree-node-drop-slot", inputs: ["node", "dropIndex"] }, { kind: "component", type: i5.TreeNodeCollectionComponent, selector: "tree-node-collection", inputs: ["nodes", "treeModel", "templates"] }, { kind: "component", type: i6.TreeViewportComponent, selector: "tree-viewport" }] }); }
93
- }
94
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeComponent, decorators: [{
95
- type: Component,
96
- args: [{ selector: 'Tree, tree-root', providers: [TreeModel], template: `
97
- <tree-viewport #viewport>
98
- <div
99
- class="angular-tree-component"
100
- [class.node-dragging]="treeDraggedElement.isDragging()"
101
- [class.angular-tree-component-rtl]="treeModel.options.rtl">
102
- <tree-node-collection
103
- *ngIf="treeModel.roots"
104
- [nodes]="treeModel.roots"
105
- [treeModel]="treeModel"
106
- [templates]="{
107
- loadingTemplate: loadingTemplate,
108
- treeNodeTemplate: treeNodeTemplate,
109
- treeNodeWrapperTemplate: treeNodeWrapperTemplate,
110
- treeNodeFullTemplate: treeNodeFullTemplate
111
- }">
112
- </tree-node-collection>
113
- <tree-node-drop-slot
114
- class="empty-tree-drop-slot"
115
- *ngIf="treeModel.isEmptyTree()"
116
- [dropIndex]="0"
117
- [node]="treeModel.virtualRoot">
118
- </tree-node-drop-slot>
119
- </div>
120
- </tree-viewport>
121
- ` }]
122
- }], ctorParameters: () => [{ type: i1.TreeModel }, { type: i2.TreeDraggedElement }], propDecorators: { loadingTemplate: [{
123
- type: ContentChild,
124
- args: ['loadingTemplate', { static: false }]
125
- }], treeNodeTemplate: [{
126
- type: ContentChild,
127
- args: ['treeNodeTemplate', { static: false }]
128
- }], treeNodeWrapperTemplate: [{
129
- type: ContentChild,
130
- args: ['treeNodeWrapperTemplate', { static: false }]
131
- }], treeNodeFullTemplate: [{
132
- type: ContentChild,
133
- args: ['treeNodeFullTemplate', { static: false }]
134
- }], viewportComponent: [{
135
- type: ViewChild,
136
- args: ['viewport', { static: false }]
137
- }], nodes: [{
138
- type: Input
139
- }], options: [{
140
- type: Input
141
- }], focused: [{
142
- type: Input
143
- }], state: [{
144
- type: Input
145
- }], toggleExpanded: [{
146
- type: Output
147
- }], activate: [{
148
- type: Output
149
- }], deactivate: [{
150
- type: Output
151
- }], nodeActivate: [{
152
- type: Output
153
- }], nodeDeactivate: [{
154
- type: Output
155
- }], select: [{
156
- type: Output
157
- }], deselect: [{
158
- type: Output
159
- }], focus: [{
160
- type: Output
161
- }], blur: [{
162
- type: Output
163
- }], updateData: [{
164
- type: Output
165
- }], initialized: [{
166
- type: Output
167
- }], moveNode: [{
168
- type: Output
169
- }], copyNode: [{
170
- type: Output
171
- }], loadNodeChildren: [{
172
- type: Output
173
- }], changeFilter: [{
174
- type: Output
175
- }], event: [{
176
- type: Output
177
- }], stateChange: [{
178
- type: Output
179
- }], onKeydown: [{
180
- type: HostListener,
181
- args: ['body: keydown', ['$event']]
182
- }], onMousedown: [{
183
- type: HostListener,
184
- args: ['body: mousedown', ['$event']]
185
- }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/components/tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, HostListener, Input, OnChanges, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { TreeModel } from '../models/tree.model';\r\nimport { TreeDraggedElement } from '../models/tree-dragged-element.model';\r\nimport { TreeOptions } from '../models/tree-options.model';\r\nimport { ITreeOptions } from '../defs/api';\r\nimport { TreeViewportComponent } from './tree-viewport.component';\r\n\r\n@Component({\r\n  selector: 'Tree, tree-root',\r\n  providers: [TreeModel],\r\n  styles: [],\r\n  template: `\r\n      <tree-viewport #viewport>\r\n          <div\r\n                  class=\"angular-tree-component\"\r\n                  [class.node-dragging]=\"treeDraggedElement.isDragging()\"\r\n                  [class.angular-tree-component-rtl]=\"treeModel.options.rtl\">\r\n              <tree-node-collection\r\n                      *ngIf=\"treeModel.roots\"\r\n                      [nodes]=\"treeModel.roots\"\r\n                      [treeModel]=\"treeModel\"\r\n                      [templates]=\"{\r\n            loadingTemplate: loadingTemplate,\r\n            treeNodeTemplate: treeNodeTemplate,\r\n            treeNodeWrapperTemplate: treeNodeWrapperTemplate,\r\n            treeNodeFullTemplate: treeNodeFullTemplate\r\n          }\">\r\n              </tree-node-collection>\r\n              <tree-node-drop-slot\r\n                      class=\"empty-tree-drop-slot\"\r\n                      *ngIf=\"treeModel.isEmptyTree()\"\r\n                      [dropIndex]=\"0\"\r\n                      [node]=\"treeModel.virtualRoot\">\r\n              </tree-node-drop-slot>\r\n          </div>\r\n      </tree-viewport>\r\n  `\r\n})\r\nexport class TreeComponent implements OnChanges {\r\n  _nodes: any[];\r\n  _options: TreeOptions;\r\n\r\n  @ContentChild('loadingTemplate', { static: false }) loadingTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeTemplate', { static: false }) treeNodeTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeWrapperTemplate', { static: false }) treeNodeWrapperTemplate: TemplateRef<any>;\r\n  @ContentChild('treeNodeFullTemplate', { static: false }) treeNodeFullTemplate: TemplateRef<any>;\r\n  @ViewChild('viewport', { static: false }) viewportComponent: TreeViewportComponent;\r\n\r\n  // Will be handled in ngOnChanges\r\n  @Input() set nodes(nodes: any[]) {\r\n  };\r\n\r\n  @Input() set options(options: ITreeOptions) {\r\n  };\r\n\r\n  @Input() set focused(value: boolean) {\r\n    this.treeModel.setFocus(value);\r\n  }\r\n\r\n  @Input() set state(state) {\r\n    this.treeModel.setState(state);\r\n  }\r\n\r\n  @Output() toggleExpanded;\r\n  @Output() activate;\r\n  @Output() deactivate;\r\n  @Output() nodeActivate;\r\n  @Output() nodeDeactivate;\r\n  @Output() select;\r\n  @Output() deselect;\r\n  @Output() focus;\r\n  @Output() blur;\r\n  @Output() updateData;\r\n  @Output() initialized;\r\n  @Output() moveNode;\r\n  @Output() copyNode;\r\n  @Output() loadNodeChildren;\r\n  @Output() changeFilter;\r\n  @Output() event;\r\n  @Output() stateChange;\r\n\r\n  constructor(\r\n    public treeModel: TreeModel,\r\n    public treeDraggedElement: TreeDraggedElement) {\r\n\r\n    treeModel.eventNames.forEach((name) => this[name] = new EventEmitter());\r\n    treeModel.subscribeToState((state) => this.stateChange.emit(state));\r\n  }\r\n\r\n  @HostListener('body: keydown', ['$event'])\r\n  onKeydown($event) {\r\n    if (!this.treeModel.isFocused) return;\r\n    if (['input', 'textarea'].includes(document.activeElement.tagName.toLowerCase())) return;\r\n\r\n    const focusedNode = this.treeModel.getFocusedNode();\r\n\r\n    this.treeModel.performKeyAction(focusedNode, $event);\r\n  }\r\n\r\n  @HostListener('body: mousedown', ['$event'])\r\n  onMousedown($event) {\r\n    function isOutsideClick(startElement: Element, nodeName: string) {\r\n      return !startElement ? true : startElement.localName === nodeName ? false : isOutsideClick(startElement.parentElement, nodeName);\r\n    }\r\n\r\n    if (isOutsideClick($event.target, 'tree-root')) {\r\n      this.treeModel.setFocus(false);\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes) {\r\n    if (changes.options || changes.nodes) {\r\n      this.treeModel.setData({\r\n        options: changes.options && changes.options.currentValue,\r\n        nodes: changes.nodes && changes.nodes.currentValue,\r\n        events: this.pick(this, this.treeModel.eventNames)\r\n      });\r\n    }\r\n  }\r\n\r\n  sizeChanged() {\r\n    this.viewportComponent.setViewport();\r\n  }\r\n\r\n  private pick(object, keys) {\r\n    return keys.reduce((obj, key) => {\r\n      if (object && object.hasOwnProperty(key)) {\r\n        obj[key] = object[key];\r\n      }\r\n      return obj;\r\n    }, {});\r\n  }\r\n}\r\n"]}
@@ -1,101 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- const EASE_ACCELERATION = 1.005;
4
- export class TreeAnimateOpenDirective {
5
- set isOpen(value) {
6
- if (value) {
7
- this._show();
8
- if (this.isEnabled && this._isOpen === false) {
9
- this._animateOpen();
10
- }
11
- }
12
- else {
13
- this.isEnabled ? this._animateClose() : this._hide();
14
- }
15
- this._isOpen = !!value;
16
- }
17
- ;
18
- constructor(renderer, templateRef, viewContainerRef) {
19
- this.renderer = renderer;
20
- this.templateRef = templateRef;
21
- this.viewContainerRef = viewContainerRef;
22
- }
23
- _show() {
24
- if (this.innerElement)
25
- return;
26
- // create child view
27
- this.innerElement = this.viewContainerRef.createEmbeddedView(this.templateRef).rootNodes[0];
28
- }
29
- _hide() {
30
- this.viewContainerRef.clear();
31
- this.innerElement = null;
32
- }
33
- _animateOpen() {
34
- let delta = this.animateSpeed;
35
- let ease = this.animateAcceleration;
36
- let maxHeight = 0;
37
- // set height to 0
38
- this.renderer.setStyle(this.innerElement, 'max-height', `0`);
39
- // increase maxHeight until height doesn't change
40
- setTimeout(() => {
41
- const i = setInterval(() => {
42
- if (!this._isOpen || !this.innerElement)
43
- return clearInterval(i);
44
- maxHeight += delta;
45
- const roundedMaxHeight = Math.round(maxHeight);
46
- this.renderer.setStyle(this.innerElement, 'max-height', `${roundedMaxHeight}px`);
47
- const height = this.innerElement.getBoundingClientRect ? this.innerElement.getBoundingClientRect().height : 0; // TBD use renderer
48
- delta *= ease;
49
- ease *= EASE_ACCELERATION;
50
- if (height < roundedMaxHeight) {
51
- // Make maxHeight auto because animation finished and container might change height later on
52
- this.renderer.setStyle(this.innerElement, 'max-height', null);
53
- clearInterval(i);
54
- }
55
- }, 17);
56
- });
57
- }
58
- _animateClose() {
59
- if (!this.innerElement)
60
- return;
61
- let delta = this.animateSpeed;
62
- let ease = this.animateAcceleration;
63
- let height = this.innerElement.getBoundingClientRect().height; // TBD use renderer
64
- // slowly decrease maxHeight to 0, starting from current height
65
- const i = setInterval(() => {
66
- if (this._isOpen || !this.innerElement)
67
- return clearInterval(i);
68
- height -= delta;
69
- this.renderer.setStyle(this.innerElement, 'max-height', `${height}px`);
70
- delta *= ease;
71
- ease *= EASE_ACCELERATION;
72
- if (height <= 0) {
73
- // after animation complete - remove child element
74
- this.viewContainerRef.clear();
75
- this.innerElement = null;
76
- clearInterval(i);
77
- }
78
- }, 17);
79
- }
80
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeAnimateOpenDirective, deps: [{ token: i0.Renderer2 }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
81
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: TreeAnimateOpenDirective, selector: "[treeAnimateOpen]", inputs: { animateSpeed: ["treeAnimateOpenSpeed", "animateSpeed"], animateAcceleration: ["treeAnimateOpenAcceleration", "animateAcceleration"], isEnabled: ["treeAnimateOpenEnabled", "isEnabled"], isOpen: ["treeAnimateOpen", "isOpen"] }, ngImport: i0 }); }
82
- }
83
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeAnimateOpenDirective, decorators: [{
84
- type: Directive,
85
- args: [{
86
- selector: '[treeAnimateOpen]'
87
- }]
88
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }], propDecorators: { animateSpeed: [{
89
- type: Input,
90
- args: ['treeAnimateOpenSpeed']
91
- }], animateAcceleration: [{
92
- type: Input,
93
- args: ['treeAnimateOpenAcceleration']
94
- }], isEnabled: [{
95
- type: Input,
96
- args: ['treeAnimateOpenEnabled']
97
- }], isOpen: [{
98
- type: Input,
99
- args: ['treeAnimateOpen']
100
- }] } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-animate-open.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/directives/tree-animate-open.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, Renderer2, TemplateRef, ViewContainerRef } from '@angular/core';\r\n\r\nconst EASE_ACCELERATION = 1.005;\r\n\r\n@Directive({\r\n  selector: '[treeAnimateOpen]'\r\n})\r\nexport class TreeAnimateOpenDirective {\r\n  private _isOpen: boolean;\r\n\r\n  @Input('treeAnimateOpenSpeed') animateSpeed: number;\r\n  @Input('treeAnimateOpenAcceleration') animateAcceleration: number;\r\n  @Input('treeAnimateOpenEnabled') isEnabled: boolean;\r\n\r\n  @Input('treeAnimateOpen')\r\n  set isOpen(value: boolean) {\r\n    if (value) {\r\n      this._show();\r\n      if (this.isEnabled && this._isOpen === false) {\r\n        this._animateOpen();\r\n      }\r\n    } else {\r\n      this.isEnabled ? this._animateClose() : this._hide();\r\n    }\r\n    this._isOpen = !!value;\r\n  };\r\n\r\n  private innerElement: any;\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private templateRef: TemplateRef<any>,\r\n    private viewContainerRef: ViewContainerRef) {\r\n  }\r\n\r\n  private _show() {\r\n    if (this.innerElement) return;\r\n\r\n    // create child view\r\n    this.innerElement = this.viewContainerRef.createEmbeddedView(this.templateRef).rootNodes[0];\r\n  }\r\n\r\n  private _hide() {\r\n    this.viewContainerRef.clear();\r\n    this.innerElement = null;\r\n  }\r\n\r\n  private _animateOpen() {\r\n    let delta = this.animateSpeed;\r\n    let ease = this.animateAcceleration;\r\n    let maxHeight = 0;\r\n\r\n    // set height to 0\r\n    this.renderer.setStyle(this.innerElement, 'max-height', `0`);\r\n\r\n    // increase maxHeight until height doesn't change\r\n    setTimeout(() => { // Allow inner element to create its content\r\n      const i = setInterval(() => {\r\n        if (!this._isOpen || !this.innerElement) return clearInterval(i);\r\n\r\n        maxHeight += delta;\r\n        const roundedMaxHeight = Math.round(maxHeight);\r\n\r\n        this.renderer.setStyle(this.innerElement, 'max-height', `${roundedMaxHeight}px`);\r\n        const height = this.innerElement.getBoundingClientRect ? this.innerElement.getBoundingClientRect().height : 0; // TBD use renderer\r\n\r\n        delta *= ease;\r\n        ease *= EASE_ACCELERATION;\r\n        if (height < roundedMaxHeight) {\r\n          // Make maxHeight auto because animation finished and container might change height later on\r\n          this.renderer.setStyle(this.innerElement, 'max-height', null);\r\n          clearInterval(i);\r\n        }\r\n      }, 17);\r\n    });\r\n  }\r\n\r\n  private _animateClose() {\r\n    if (!this.innerElement) return;\r\n\r\n    let delta = this.animateSpeed;\r\n    let ease = this.animateAcceleration;\r\n    let height = this.innerElement.getBoundingClientRect().height; // TBD use renderer\r\n\r\n    // slowly decrease maxHeight to 0, starting from current height\r\n    const i = setInterval(() => {\r\n      if (this._isOpen || !this.innerElement) return clearInterval(i);\r\n\r\n      height -= delta;\r\n      this.renderer.setStyle(this.innerElement, 'max-height', `${height}px`);\r\n      delta *= ease;\r\n      ease *= EASE_ACCELERATION;\r\n\r\n      if (height <= 0) {\r\n        // after animation complete - remove child element\r\n        this.viewContainerRef.clear();\r\n        this.innerElement = null;\r\n        clearInterval(i);\r\n      }\r\n    }, 17);\r\n  }\r\n}\r\n"]}
@@ -1,127 +0,0 @@
1
- import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../models/tree-dragged-element.model";
4
- const DRAG_OVER_CLASS = 'is-dragging-over';
5
- const DRAG_DISABLED_CLASS = 'is-dragging-over-disabled';
6
- export class TreeDropDirective {
7
- set treeAllowDrop(allowDrop) {
8
- if (allowDrop instanceof Function) {
9
- this._allowDrop = allowDrop;
10
- }
11
- else
12
- this._allowDrop = (element, $event) => allowDrop;
13
- }
14
- allowDrop($event) {
15
- return this._allowDrop(this.treeDraggedElement.get(), $event);
16
- }
17
- constructor(el, renderer, treeDraggedElement, ngZone) {
18
- this.el = el;
19
- this.renderer = renderer;
20
- this.treeDraggedElement = treeDraggedElement;
21
- this.ngZone = ngZone;
22
- this.allowDragoverStyling = true;
23
- this.onDropCallback = new EventEmitter();
24
- this.onDragOverCallback = new EventEmitter();
25
- this.onDragLeaveCallback = new EventEmitter();
26
- this.onDragEnterCallback = new EventEmitter();
27
- this._allowDrop = (element, $event) => true;
28
- this.dragOverEventHandler = this.onDragOver.bind(this);
29
- this.dragEnterEventHandler = this.onDragEnter.bind(this);
30
- this.dragLeaveEventHandler = this.onDragLeave.bind(this);
31
- }
32
- ngAfterViewInit() {
33
- let el = this.el.nativeElement;
34
- this.ngZone.runOutsideAngular(() => {
35
- el.addEventListener('dragover', this.dragOverEventHandler);
36
- el.addEventListener('dragenter', this.dragEnterEventHandler);
37
- el.addEventListener('dragleave', this.dragLeaveEventHandler);
38
- });
39
- }
40
- ngOnDestroy() {
41
- let el = this.el.nativeElement;
42
- el.removeEventListener('dragover', this.dragOverEventHandler);
43
- el.removeEventListener('dragenter', this.dragEnterEventHandler);
44
- el.removeEventListener('dragleave', this.dragLeaveEventHandler);
45
- }
46
- onDragOver($event) {
47
- if (!this.allowDrop($event)) {
48
- if (this.allowDragoverStyling) {
49
- return this.addDisabledClass();
50
- }
51
- return;
52
- }
53
- this.onDragOverCallback.emit({ event: $event, element: this.treeDraggedElement.get() });
54
- $event.preventDefault();
55
- if (this.allowDragoverStyling) {
56
- this.addClass();
57
- }
58
- }
59
- onDragEnter($event) {
60
- if (!this.allowDrop($event))
61
- return;
62
- $event.preventDefault();
63
- this.onDragEnterCallback.emit({ event: $event, element: this.treeDraggedElement.get() });
64
- }
65
- onDragLeave($event) {
66
- if (!this.allowDrop($event)) {
67
- if (this.allowDragoverStyling) {
68
- return this.removeDisabledClass();
69
- }
70
- return;
71
- }
72
- this.onDragLeaveCallback.emit({ event: $event, element: this.treeDraggedElement.get() });
73
- if (this.allowDragoverStyling) {
74
- this.removeClass();
75
- }
76
- }
77
- onDrop($event) {
78
- if (!this.allowDrop($event))
79
- return;
80
- $event.preventDefault();
81
- this.onDropCallback.emit({ event: $event, element: this.treeDraggedElement.get() });
82
- if (this.allowDragoverStyling) {
83
- this.removeClass();
84
- }
85
- this.treeDraggedElement.set(null);
86
- }
87
- addClass() {
88
- this.renderer.addClass(this.el.nativeElement, DRAG_OVER_CLASS);
89
- }
90
- removeClass() {
91
- this.renderer.removeClass(this.el.nativeElement, DRAG_OVER_CLASS);
92
- }
93
- addDisabledClass() {
94
- this.renderer.addClass(this.el.nativeElement, DRAG_DISABLED_CLASS);
95
- }
96
- removeDisabledClass() {
97
- this.renderer.removeClass(this.el.nativeElement, DRAG_DISABLED_CLASS);
98
- }
99
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeDropDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.TreeDraggedElement }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
100
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: TreeDropDirective, selector: "[treeDrop]", inputs: { allowDragoverStyling: "allowDragoverStyling", treeAllowDrop: "treeAllowDrop" }, outputs: { onDropCallback: "treeDrop", onDragOverCallback: "treeDropDragOver", onDragLeaveCallback: "treeDropDragLeave", onDragEnterCallback: "treeDropDragEnter" }, host: { listeners: { "drop": "onDrop($event)" } }, ngImport: i0 }); }
101
- }
102
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeDropDirective, decorators: [{
103
- type: Directive,
104
- args: [{
105
- selector: '[treeDrop]'
106
- }]
107
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.TreeDraggedElement }, { type: i0.NgZone }], propDecorators: { allowDragoverStyling: [{
108
- type: Input
109
- }], onDropCallback: [{
110
- type: Output,
111
- args: ['treeDrop']
112
- }], onDragOverCallback: [{
113
- type: Output,
114
- args: ['treeDropDragOver']
115
- }], onDragLeaveCallback: [{
116
- type: Output,
117
- args: ['treeDropDragLeave']
118
- }], onDragEnterCallback: [{
119
- type: Output,
120
- args: ['treeDropDragEnter']
121
- }], treeAllowDrop: [{
122
- type: Input
123
- }], onDrop: [{
124
- type: HostListener,
125
- args: ['drop', ['$event']]
126
- }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-drop.directive.js","sourceRoot":"","sources":["../../../../../projects/angular-tree-component/src/lib/directives/tree-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2\r\n} from '@angular/core';\r\nimport { TreeDraggedElement } from '../models/tree-dragged-element.model';\r\n\r\nconst DRAG_OVER_CLASS = 'is-dragging-over';\r\nconst DRAG_DISABLED_CLASS = 'is-dragging-over-disabled';\r\n\r\n@Directive({\r\n  selector: '[treeDrop]'\r\n})\r\nexport class TreeDropDirective implements AfterViewInit, OnDestroy {\r\n  @Input() allowDragoverStyling = true;\r\n  @Output('treeDrop') onDropCallback = new EventEmitter();\r\n  @Output('treeDropDragOver') onDragOverCallback = new EventEmitter();\r\n  @Output('treeDropDragLeave') onDragLeaveCallback = new EventEmitter();\r\n  @Output('treeDropDragEnter') onDragEnterCallback = new EventEmitter();\r\n  private readonly dragOverEventHandler: (ev: DragEvent) => void;\r\n  private readonly dragEnterEventHandler: (ev: DragEvent) => void;\r\n  private readonly dragLeaveEventHandler: (ev: DragEvent) => void;\r\n\r\n  private _allowDrop = (element, $event) => true;\r\n\r\n  @Input() set treeAllowDrop(allowDrop) {\r\n    if (allowDrop instanceof Function) {\r\n      this._allowDrop = allowDrop;\r\n    }\r\n    else this._allowDrop = (element, $event) => allowDrop;\r\n  }\r\n\r\n  allowDrop($event) {\r\n    return this._allowDrop(this.treeDraggedElement.get(), $event);\r\n  }\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2, private treeDraggedElement: TreeDraggedElement, private ngZone: NgZone) {\r\n    this.dragOverEventHandler = this.onDragOver.bind(this);\r\n    this.dragEnterEventHandler = this.onDragEnter.bind(this);\r\n    this.dragLeaveEventHandler = this.onDragLeave.bind(this);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    let el: HTMLElement = this.el.nativeElement;\r\n    this.ngZone.runOutsideAngular(() => {\r\n      el.addEventListener('dragover', this.dragOverEventHandler);\r\n      el.addEventListener('dragenter', this.dragEnterEventHandler);\r\n      el.addEventListener('dragleave', this.dragLeaveEventHandler);\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    let el: HTMLElement = this.el.nativeElement;\r\n    el.removeEventListener('dragover', this.dragOverEventHandler);\r\n    el.removeEventListener('dragenter', this.dragEnterEventHandler);\r\n    el.removeEventListener('dragleave', this.dragLeaveEventHandler);\r\n  }\r\n\r\n  onDragOver($event) {\r\n    if (!this.allowDrop($event)) {\r\n      if (this.allowDragoverStyling) {\r\n        return this.addDisabledClass();\r\n      }\r\n      return;\r\n    }\r\n\r\n    this.onDragOverCallback.emit({event: $event, element: this.treeDraggedElement.get()});\r\n\r\n    $event.preventDefault();\r\n    if (this.allowDragoverStyling) {\r\n      this.addClass();\r\n    }\r\n  }\r\n\r\n  onDragEnter($event) {\r\n    if (!this.allowDrop($event)) return;\r\n\r\n    $event.preventDefault();\r\n    this.onDragEnterCallback.emit({event: $event, element: this.treeDraggedElement.get()});\r\n  }\r\n\r\n  onDragLeave($event) {\r\n    if (!this.allowDrop($event)) {\r\n      if (this.allowDragoverStyling) {\r\n        return this.removeDisabledClass();\r\n      }\r\n      return;\r\n    }\r\n    this.onDragLeaveCallback.emit({event: $event, element: this.treeDraggedElement.get()});\r\n\r\n    if (this.allowDragoverStyling) {\r\n      this.removeClass();\r\n    }\r\n  }\r\n\r\n  @HostListener('drop', ['$event']) onDrop($event) {\r\n    if (!this.allowDrop($event)) return;\r\n\r\n    $event.preventDefault();\r\n    this.onDropCallback.emit({event: $event, element: this.treeDraggedElement.get()});\r\n\r\n    if (this.allowDragoverStyling) {\r\n      this.removeClass();\r\n    }\r\n    this.treeDraggedElement.set(null);\r\n  }\r\n\r\n  private addClass() {\r\n    this.renderer.addClass(this.el.nativeElement, DRAG_OVER_CLASS);\r\n  }\r\n\r\n  private removeClass() {\r\n    this.renderer.removeClass(this.el.nativeElement, DRAG_OVER_CLASS);\r\n  }\r\n\r\n  private addDisabledClass() {\r\n    this.renderer.addClass(this.el.nativeElement, DRAG_DISABLED_CLASS);\r\n  }\r\n\r\n  private removeDisabledClass() {\r\n    this.renderer.removeClass(this.el.nativeElement, DRAG_DISABLED_CLASS);\r\n  }\r\n}\r\n"]}
@@ -1,40 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { autorun } from 'mobx';
3
- import * as i0 from "@angular/core";
4
- export class TreeMobxAutorunDirective {
5
- constructor(templateRef, viewContainer) {
6
- this.templateRef = templateRef;
7
- this.viewContainer = viewContainer;
8
- this.templateBindings = {};
9
- }
10
- ngOnInit() {
11
- this.view = this.viewContainer.createEmbeddedView(this.templateRef);
12
- if (this.dispose) {
13
- this.dispose();
14
- }
15
- if (this.shouldDetach()) {
16
- this.view.detach();
17
- }
18
- this.autoDetect(this.view);
19
- }
20
- shouldDetach() {
21
- return this.treeMobxAutorun && this.treeMobxAutorun.detach;
22
- }
23
- autoDetect(view) {
24
- this.dispose = autorun(() => view.detectChanges());
25
- }
26
- ngOnDestroy() {
27
- if (this.dispose) {
28
- this.dispose();
29
- }
30
- }
31
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeMobxAutorunDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
32
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: TreeMobxAutorunDirective, selector: "[treeMobxAutorun]", inputs: { treeMobxAutorun: "treeMobxAutorun" }, ngImport: i0 }); }
33
- }
34
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TreeMobxAutorunDirective, decorators: [{
35
- type: Directive,
36
- args: [{ selector: '[treeMobxAutorun]' }]
37
- }], ctorParameters: () => [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }], propDecorators: { treeMobxAutorun: [{
38
- type: Input
39
- }] } });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1tb2J4LWF1dG9ydW4uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci10cmVlLWNvbXBvbmVudC9zcmMvbGliL21vYngtYW5ndWxhci90cmVlLW1vYngtYXV0b3J1bi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFLVCxLQUFLLEVBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFHL0IsTUFBTSxPQUFPLHdCQUF3QjtJQU1uQyxZQUNZLFdBQTZCLEVBQzdCLGFBQStCO1FBRC9CLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQUM3QixrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFQakMscUJBQWdCLEdBQUcsRUFBRSxDQUFDO0lBUTdCLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUVwRSxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDakIsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLFlBQVksRUFBRSxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNyQixDQUFDO1FBQ0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELFlBQVk7UUFDVixPQUFPLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUM7SUFDN0QsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUEwQjtRQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztJQUNyRCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQixDQUFDO0lBQ0gsQ0FBQztpSUFwQ1Usd0JBQXdCO3FIQUF4Qix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBRHBDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsbUJBQW1CLEVBQUU7K0dBS2pDLGVBQWU7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIERpcmVjdGl2ZSxcclxuICBWaWV3Q29udGFpbmVyUmVmLFxyXG4gIFRlbXBsYXRlUmVmLFxyXG4gIE9uSW5pdCxcclxuICBPbkRlc3Ryb3ksXHJcbiAgSW5wdXQsXHJcbiAgRW1iZWRkZWRWaWV3UmVmXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGF1dG9ydW4gfSBmcm9tICdtb2J4JztcclxuXHJcbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1t0cmVlTW9ieEF1dG9ydW5dJyB9KVxyXG5leHBvcnQgY2xhc3MgVHJlZU1vYnhBdXRvcnVuRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gIHByb3RlY3RlZCB0ZW1wbGF0ZUJpbmRpbmdzID0ge307XHJcbiAgcHJvdGVjdGVkIGRpc3Bvc2U6IGFueTtcclxuICBwcm90ZWN0ZWQgdmlldzogRW1iZWRkZWRWaWV3UmVmPGFueT47XHJcbiAgQElucHV0KCkgdHJlZU1vYnhBdXRvcnVuO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcclxuICAgIHByb3RlY3RlZCB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmXHJcbiAgKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMudmlldyA9IHRoaXMudmlld0NvbnRhaW5lci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XHJcblxyXG4gICAgaWYgKHRoaXMuZGlzcG9zZSkge1xyXG4gICAgICB0aGlzLmRpc3Bvc2UoKTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAodGhpcy5zaG91bGREZXRhY2goKSkge1xyXG4gICAgICB0aGlzLnZpZXcuZGV0YWNoKCk7XHJcbiAgICB9XHJcbiAgICB0aGlzLmF1dG9EZXRlY3QodGhpcy52aWV3KTtcclxuICB9XHJcblxyXG4gIHNob3VsZERldGFjaCgpIHtcclxuICAgIHJldHVybiB0aGlzLnRyZWVNb2J4QXV0b3J1biAmJiB0aGlzLnRyZWVNb2J4QXV0b3J1bi5kZXRhY2g7XHJcbiAgfVxyXG5cclxuICBhdXRvRGV0ZWN0KHZpZXc6IEVtYmVkZGVkVmlld1JlZjxhbnk+KSB7XHJcbiAgICB0aGlzLmRpc3Bvc2UgPSBhdXRvcnVuKCgpID0+IHZpZXcuZGV0ZWN0Q2hhbmdlcygpKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgaWYgKHRoaXMuZGlzcG9zZSkge1xyXG4gICAgICB0aGlzLmRpc3Bvc2UoKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19