@acorex/components 7.4.7 → 7.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (135) hide show
  1. package/button/lib/button.module.d.ts +2 -1
  2. package/common/lib/classes/datalist.class.d.ts +3 -3
  3. package/common/lib/components/selection-base.component.class.d.ts +3 -9
  4. package/datetime-box/lib/datetime-box.component.d.ts +2 -1
  5. package/dialog/lib/dialog.class.d.ts +4 -2
  6. package/dialog/lib/dialog.service.d.ts +3 -2
  7. package/dropdown/lib/dropdown-box.component.d.ts +1 -0
  8. package/esm2022/action-sheet/lib/action-sheet.component.mjs +2 -2
  9. package/esm2022/alert/lib/alert.component.mjs +12 -12
  10. package/esm2022/avatar/lib/avatar.component.mjs +2 -2
  11. package/esm2022/button/lib/button.component.mjs +2 -2
  12. package/esm2022/button/lib/button.module.mjs +4 -3
  13. package/esm2022/common/lib/classes/datalist.class.mjs +52 -1
  14. package/esm2022/common/lib/components/selection-base.component.class.mjs +13 -36
  15. package/esm2022/common/lib/components/value-component.class.mjs +3 -3
  16. package/esm2022/datetime-box/lib/datetime-box.component.mjs +8 -6
  17. package/esm2022/decorators/lib/components/generic-content.component.mjs +21 -21
  18. package/esm2022/decorators/lib/components/icon.component.mjs +3 -3
  19. package/esm2022/dialog/lib/dialog.class.mjs +1 -1
  20. package/esm2022/dialog/lib/dialog.component.mjs +3 -17
  21. package/esm2022/dialog/lib/dialog.service.mjs +47 -24
  22. package/esm2022/dropdown/lib/dropdown-box.component.mjs +8 -5
  23. package/esm2022/dropdown/lib/dropdown-panel.component.mjs +3 -3
  24. package/esm2022/form/lib/form-field.component.mjs +2 -2
  25. package/esm2022/label/lib/label.component.mjs +2 -2
  26. package/esm2022/list/acorex-components-list.mjs +5 -0
  27. package/esm2022/list/index.mjs +3 -0
  28. package/esm2022/list/lib/list.component.mjs +221 -0
  29. package/esm2022/list/lib/list.module.mjs +22 -0
  30. package/esm2022/loading/lib/loading.module.mjs +22 -8
  31. package/esm2022/loading/lib/loading.service.mjs +9 -13
  32. package/esm2022/menu/index.mjs +4 -1
  33. package/esm2022/menu/lib/class/root-menu.class.mjs +3 -0
  34. package/esm2022/menu/lib/menu-item/menu-item.component.mjs +96 -0
  35. package/esm2022/menu/lib/menu.component.mjs +4 -4
  36. package/esm2022/menu/lib/menu.module.mjs +11 -16
  37. package/esm2022/menu/lib/menu2.component.mjs +45 -0
  38. package/esm2022/mixin/lib/datalist.class.mjs +46 -2
  39. package/esm2022/notification/lib/notification.component.mjs +7 -7
  40. package/esm2022/popover/lib/popover.component.mjs +8 -5
  41. package/esm2022/popup/lib/popup.component.mjs +1 -2
  42. package/esm2022/popup/lib/popup.service.mjs +1 -2
  43. package/esm2022/progress-bar/lib/progress-bar.component.mjs +2 -2
  44. package/esm2022/result/lib/result.component.mjs +2 -2
  45. package/esm2022/select-box/index.mjs +2 -1
  46. package/esm2022/select-box/lib/select-box.component.mjs +3 -3
  47. package/esm2022/select-box/lib/select-box.module.mjs +15 -6
  48. package/esm2022/select-box/lib/select-box2.component.mjs +97 -0
  49. package/esm2022/selection-list/lib/selection-list.component.mjs +22 -7
  50. package/esm2022/tabs/lib/tabs.component.mjs +2 -2
  51. package/esm2022/text-area/lib/text-area.component.mjs +14 -6
  52. package/esm2022/toast/lib/toast.component.mjs +5 -5
  53. package/fesm2022/acorex-components-action-sheet.mjs +2 -2
  54. package/fesm2022/acorex-components-action-sheet.mjs.map +1 -1
  55. package/fesm2022/acorex-components-alert.mjs +11 -11
  56. package/fesm2022/acorex-components-alert.mjs.map +1 -1
  57. package/fesm2022/acorex-components-avatar.mjs +2 -2
  58. package/fesm2022/acorex-components-button.mjs +5 -4
  59. package/fesm2022/acorex-components-button.mjs.map +1 -1
  60. package/fesm2022/acorex-components-common.mjs +65 -37
  61. package/fesm2022/acorex-components-common.mjs.map +1 -1
  62. package/fesm2022/acorex-components-datetime-box.mjs +7 -5
  63. package/fesm2022/acorex-components-datetime-box.mjs.map +1 -1
  64. package/fesm2022/acorex-components-decorators.mjs +22 -22
  65. package/fesm2022/acorex-components-decorators.mjs.map +1 -1
  66. package/fesm2022/acorex-components-dialog.mjs +47 -38
  67. package/fesm2022/acorex-components-dialog.mjs.map +1 -1
  68. package/fesm2022/acorex-components-dropdown.mjs +9 -7
  69. package/fesm2022/acorex-components-dropdown.mjs.map +1 -1
  70. package/fesm2022/acorex-components-form.mjs +2 -2
  71. package/fesm2022/acorex-components-form.mjs.map +1 -1
  72. package/fesm2022/acorex-components-label.mjs +2 -2
  73. package/fesm2022/acorex-components-label.mjs.map +1 -1
  74. package/fesm2022/acorex-components-list.mjs +246 -0
  75. package/fesm2022/acorex-components-list.mjs.map +1 -0
  76. package/fesm2022/acorex-components-loading.mjs +23 -15
  77. package/fesm2022/acorex-components-loading.mjs.map +1 -1
  78. package/fesm2022/acorex-components-menu.mjs +148 -21
  79. package/fesm2022/acorex-components-menu.mjs.map +1 -1
  80. package/fesm2022/acorex-components-mixin.mjs +46 -1
  81. package/fesm2022/acorex-components-mixin.mjs.map +1 -1
  82. package/fesm2022/acorex-components-notification.mjs +7 -7
  83. package/fesm2022/acorex-components-notification.mjs.map +1 -1
  84. package/fesm2022/acorex-components-popover.mjs +7 -4
  85. package/fesm2022/acorex-components-popover.mjs.map +1 -1
  86. package/fesm2022/acorex-components-popup.mjs +0 -2
  87. package/fesm2022/acorex-components-popup.mjs.map +1 -1
  88. package/fesm2022/acorex-components-progress-bar.mjs +2 -2
  89. package/fesm2022/acorex-components-progress-bar.mjs.map +1 -1
  90. package/fesm2022/acorex-components-result.mjs +2 -2
  91. package/fesm2022/acorex-components-select-box.mjs +116 -18
  92. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  93. package/fesm2022/acorex-components-selection-list.mjs +21 -6
  94. package/fesm2022/acorex-components-selection-list.mjs.map +1 -1
  95. package/fesm2022/acorex-components-tabs.mjs +2 -2
  96. package/fesm2022/acorex-components-tabs.mjs.map +1 -1
  97. package/fesm2022/acorex-components-text-area.mjs +13 -5
  98. package/fesm2022/acorex-components-text-area.mjs.map +1 -1
  99. package/fesm2022/acorex-components-toast.mjs +3 -3
  100. package/fesm2022/acorex-components-toast.mjs.map +1 -1
  101. package/list/README.md +3 -0
  102. package/list/index.d.ts +2 -0
  103. package/list/lib/list.component.d.ts +59 -0
  104. package/list/lib/list.module.d.ts +9 -0
  105. package/loading/lib/loading.module.d.ts +3 -2
  106. package/menu/index.d.ts +3 -0
  107. package/menu/lib/class/root-menu.class.d.ts +4 -0
  108. package/menu/lib/menu-item/menu-item.component.d.ts +22 -0
  109. package/menu/lib/menu.component.d.ts +3 -3
  110. package/menu/lib/menu.module.d.ts +10 -7
  111. package/menu/lib/menu2.component.d.ts +12 -0
  112. package/mixin/lib/base-components.class.d.ts +2 -2
  113. package/mixin/lib/base-menu-mixin.class.d.ts +5 -5
  114. package/mixin/lib/button-mixin.class.d.ts +2 -2
  115. package/mixin/lib/clickable-mixin.class.d.ts +2 -2
  116. package/mixin/lib/color-look-mixing.class.d.ts +2 -2
  117. package/mixin/lib/datalist-component.class.d.ts +10 -10
  118. package/mixin/lib/datalist.class.d.ts +38 -0
  119. package/mixin/lib/dropdown-mixin.class.d.ts +2 -2
  120. package/mixin/lib/interactive-mixin.class.d.ts +4 -4
  121. package/mixin/lib/mixin.class.d.ts +61 -61
  122. package/mixin/lib/page-component.class.d.ts +2 -2
  123. package/mixin/lib/selection-component.class.d.ts +2 -2
  124. package/mixin/lib/sizable-mixin.class.d.ts +2 -2
  125. package/mixin/lib/textbox-mixin.class.d.ts +2 -2
  126. package/mixin/lib/value-mixin.class.d.ts +8 -8
  127. package/notification/lib/notification.component.d.ts +3 -3
  128. package/package.json +7 -1
  129. package/popover/lib/popover.component.d.ts +2 -1
  130. package/select-box/index.d.ts +1 -0
  131. package/select-box/lib/select-box.module.d.ts +15 -12
  132. package/select-box/lib/select-box2.component.d.ts +25 -0
  133. package/selection-list/lib/selection-list.component.d.ts +5 -1
  134. package/text-area/lib/text-area.component.d.ts +10 -3
  135. package/toast/lib/toast.component.d.ts +3 -3
@@ -0,0 +1,221 @@
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, TemplateRef, HostBinding, HostListener, forwardRef } from '@angular/core';
2
+ import { MXSelectionValueComponent, AXComponent, AXFocusableComponent, AXValuableComponent } from '@acorex/components/common';
3
+ import { BehaviorSubject, Subscription, debounceTime, distinctUntilChanged } from 'rxjs';
4
+ import { DataSource } from '@angular/cdk/collections';
5
+ import { CdkVirtualScrollableElement } from '@angular/cdk/scrolling';
6
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/cdk/scrolling";
9
+ import * as i2 from "@angular/common";
10
+ export class AXListDataSource extends DataSource {
11
+ get cachedItems() {
12
+ return this._cachedData || [];
13
+ }
14
+ /**
15
+ * @ignore
16
+ */
17
+ constructor(config) {
18
+ super();
19
+ this.config = config;
20
+ this.pageSize = 20;
21
+ this.debounceTime = 300;
22
+ this._cachedData = new Array(this.config.pageSize);
23
+ this.fetchedPages = new Set();
24
+ this.subscription = new Subscription();
25
+ this.initiated = false;
26
+ this.dataStream = new BehaviorSubject(this._cachedData);
27
+ this.loadingState = new BehaviorSubject(true);
28
+ this.source = config.source;
29
+ if (config.pageSize)
30
+ this.pageSize = config.pageSize;
31
+ if (config.debounceTime)
32
+ this.debounceTime = config.debounceTime;
33
+ }
34
+ connect(collectionViewer) {
35
+ this.subscription.add(collectionViewer.viewChange
36
+ .pipe(debounceTime(this.debounceTime))
37
+ .pipe(distinctUntilChanged())
38
+ .subscribe(range => {
39
+ const startPage = this.getPageForIndex(range.start);
40
+ const endPage = this.getPageForIndex(range.end - 1);
41
+ for (let i = startPage; i <= endPage; i++) {
42
+ this.fetchPage(i);
43
+ }
44
+ }));
45
+ return this.dataStream;
46
+ }
47
+ disconnect() {
48
+ this.subscription.unsubscribe();
49
+ }
50
+ getPageForIndex(index) {
51
+ return Math.floor(index / this.pageSize);
52
+ }
53
+ fetchPage(page) {
54
+ if (this.fetchedPages.has(page)) {
55
+ return;
56
+ }
57
+ this.loadingState.next(true);
58
+ this.fetchedPages.add(page);
59
+ if (Array.isArray(this.source)) {
60
+ this._cachedData = this.source;
61
+ this.dataStream.next(this._cachedData);
62
+ this.loadingState.next(false);
63
+ }
64
+ else if (typeof this.source == 'function') {
65
+ const promise = this.source({
66
+ take: this.pageSize,
67
+ skip: this.pageSize * page
68
+ });
69
+ promise.then(result => {
70
+ if (!this.initiated) {
71
+ this._cachedData = new Array(result.total);
72
+ this.initiated = true;
73
+ }
74
+ this._cachedData.splice(page * this.pageSize, this.pageSize, ...result.items);
75
+ this.dataStream.next(this._cachedData);
76
+ }).finally(() => {
77
+ this.loadingState.next(false);
78
+ });
79
+ }
80
+ }
81
+ }
82
+ export class AXListComponent extends MXSelectionValueComponent {
83
+ constructor() {
84
+ super(...arguments);
85
+ this.source = [];
86
+ this.itemHeight = 40;
87
+ this.checkbox = true;
88
+ this.isLoading = true;
89
+ this.hasItems = false;
90
+ }
91
+ trackByIdx(i) {
92
+ return i;
93
+ }
94
+ ngOnInit() {
95
+ super.ngOnInit();
96
+ this.dataSource = new AXListDataSource({
97
+ source: this.source
98
+ });
99
+ this.dataSource.loadingState.subscribe(data => {
100
+ this.isLoading = data;
101
+ });
102
+ this.dataSource.dataStream.subscribe(data => {
103
+ this.hasItems = data.length > 0;
104
+ });
105
+ }
106
+ ngAfterViewInit() {
107
+ super.ngAfterViewInit();
108
+ }
109
+ _handleOnItemClick(e, item) {
110
+ if (this.readonly || this.disabled) {
111
+ e.preventDefault();
112
+ e.stopPropagation();
113
+ return;
114
+ }
115
+ if (this.isItemDisabled(item)) {
116
+ return;
117
+ }
118
+ this.toggleSelect(item);
119
+ }
120
+ _handleKeydown(e) {
121
+ if ((e.code === 'ArrowDown' || e.code === 'ArrowUp') && this.hasItems) {
122
+ this.focusItemByNav(e.key === 'ArrowDown' ? 1 : -1);
123
+ e.preventDefault();
124
+ }
125
+ if ((e.code === 'Space' || e.code === 'Enter') && this.hasItems) {
126
+ if (this.readonly || this.disabled) {
127
+ e.preventDefault();
128
+ e.stopPropagation();
129
+ return;
130
+ }
131
+ const id = document.activeElement?.closest('li')?.dataset?.id;
132
+ this.toggleSelect(id);
133
+ e.preventDefault();
134
+ e.stopPropagation();
135
+ }
136
+ }
137
+ focusItemByNav(sign) {
138
+ const list = this.getHostElement().querySelector('ul');
139
+ const fn = (s) => list.querySelector(s);
140
+ const itemDiv = document.activeElement?.closest('li') ||
141
+ fn(`li.ax-state-selected`) ||
142
+ fn(`li`);
143
+ const next = (sign == 1 ? itemDiv.nextElementSibling : itemDiv.previousElementSibling);
144
+ if (next) {
145
+ next.focus();
146
+ }
147
+ }
148
+ /**
149
+ * @ignore
150
+ */
151
+ get __hostClass() {
152
+ const _class = `ax-default`;
153
+ return this.itemTemplate ? '' : _class;
154
+ }
155
+ getItemByKey(key) {
156
+ const cachedItem = this.dataSource.cachedItems.find(c => c && c[this.valueField] == key);
157
+ return cachedItem || { [this.valueField]: key, [this.textField]: key };
158
+ }
159
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXListComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
160
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.9", type: AXListComponent, selector: "ax-list", inputs: { id: "id", name: "name", disabled: "disabled", readonly: "readonly", valueField: "valueField", textField: "textField", disabledField: "disabledField", multiple: "multiple", source: "source", itemHeight: "itemHeight", itemTemplate: "itemTemplate", emptyTemplate: "emptyTemplate", loadingTemplate: "loadingTemplate", checkbox: "checkbox" }, outputs: { onValueChanged: "onValueChanged", disabledChange: "disabledChange", readOnlyChange: "readOnlyChange", onBlur: "onBlur", onFocus: "onFocus" }, host: { listeners: { "keydown": "_handleKeydown($event)" }, properties: { "class": "this.__hostClass" } }, providers: [
161
+ { provide: AXComponent, useExisting: AXListComponent },
162
+ { provide: AXFocusableComponent, useExisting: AXListComponent },
163
+ { provide: AXValuableComponent, useExisting: AXListComponent },
164
+ {
165
+ provide: NG_VALUE_ACCESSOR,
166
+ useExisting: forwardRef(() => AXListComponent),
167
+ multi: true,
168
+ },
169
+ ], usesInheritance: true, hostDirectives: [{ directive: i1.CdkVirtualScrollableElement }], ngImport: i0, template: "<ng-content select=\"ax-header\"></ng-content>\n<cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight+'px'\"\n class=\"ax-list-items-container\">\n <ul>\n <!-- Item Template -->\n <ng-container *cdkVirtualFor=\"let item of dataSource;let i = index; trackBy: trackByIdx\">\n <ng-container *ngIf=\"item;else loadingTpl\">\n <li [class.ax-state-selected]=\"isItemSelected(item)\" [class.ax-state-disabled]=\"isItemDisabled(item)\"\n [attr.tabindex]=\"i\" (click)=\"_handleOnItemClick($event, item)\" [attr.data-id]=\"item\">\n <!-- Custom Item Template -->\n <ng-container *ngIf=\"itemTemplate;else defaultItemTpl\">\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: { data:item } }\">\n </ng-container>\n </ng-container>\n <!-- Default Item Template -->\n <ng-template #defaultItemTpl>\n <ng-container *ngIf=\"item;else loadingTpl\">\n <div class=\"ax-label-container\">\n <input class=\"ax-checkbox\" *ngIf=\"multiple && checkbox\" type=\"checkbox\"\n [checked]=\"isItemSelected(item)\" [disabled]=\"isItemDisabled(item)\" tabindex=\"0\" />\n <span [class.ax-checkbox-label]=\"multiple && checkbox\">{{getDisplayText(item)}}</span>\n </div>\n <i class=\"ax-icon ax-icon-done ax-selected-icon\" *ngIf=\"isItemSelected(item) \"></i>\n </ng-container>\n </ng-template>\n </li>\n </ng-container>\n </ng-container>\n </ul>\n</cdk-virtual-scroll-viewport>\n<!-- Empty Template -->\n<ng-container *ngIf=\"emptyTemplate && !hasItems && isLoading===false\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n</ng-container>\n<!-- Loading Template -->\n<ng-template #loadingTpl>\n <!-- Custom Loading Template -->\n <ng-container *ngIf=\"loadingTemplate;else defaultLoadingTpl\">\n <ng-container *ngTemplateOutlet=\"loadingTemplate\">\n </ng-container>\n </ng-container>\n <!-- Default Loading Template -->\n <ng-template #defaultLoadingTpl>\n <li>Loading...</li>\n </ng-template>\n</ng-template>\n<ng-content select=\"ax-footer\"></ng-content>", styles: ["ax-list{width:100%;height:100%;display:flex;flex-direction:column}ax-list.ax-default .cdk-virtual-scroll-viewport li{padding-inline-start:.75rem;padding-inline-end:1rem;position:relative;height:var(--ax-size-default);display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;cursor:pointer}ax-list.ax-default .cdk-virtual-scroll-viewport li:focus,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-within,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-visible{outline:transparent;background-color:rgba(var(--ax-color-primary-100))}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-label-container{display:flex;align-items:center}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-checkbox-label{margin-inline-start:.5rem}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-selected-icon{color:rgba(var(--ax-color-primary-500));font-size:1.5rem}ax-list.ax-default .cdk-virtual-scroll-viewport li.ax-state-selected:not(ax-list.ax-default .cdk-virtual-scroll-viewport li:focus,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-within,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-visible){background-color:rgba(var(--ax-color-default))!important;color:rgba(var(--ax-color-default-fore))!important}ax-list.ax-default .cdk-virtual-scroll-viewport li.ax-state-disabled{cursor:not-allowed;opacity:.5}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i1.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i1.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
170
+ }
171
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXListComponent, decorators: [{
172
+ type: Component,
173
+ args: [{ selector: 'ax-list', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, inputs: [
174
+ 'id',
175
+ 'name',
176
+ 'disabled',
177
+ 'readonly',
178
+ 'valueField',
179
+ 'textField',
180
+ 'disabledField',
181
+ 'multiple'
182
+ ], outputs: [
183
+ 'onValueChanged',
184
+ 'disabledChange',
185
+ 'readOnlyChange',
186
+ 'onBlur',
187
+ 'onFocus'
188
+ ], hostDirectives: [
189
+ {
190
+ directive: CdkVirtualScrollableElement
191
+ }
192
+ ], providers: [
193
+ { provide: AXComponent, useExisting: AXListComponent },
194
+ { provide: AXFocusableComponent, useExisting: AXListComponent },
195
+ { provide: AXValuableComponent, useExisting: AXListComponent },
196
+ {
197
+ provide: NG_VALUE_ACCESSOR,
198
+ useExisting: forwardRef(() => AXListComponent),
199
+ multi: true,
200
+ },
201
+ ], template: "<ng-content select=\"ax-header\"></ng-content>\n<cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight+'px'\"\n class=\"ax-list-items-container\">\n <ul>\n <!-- Item Template -->\n <ng-container *cdkVirtualFor=\"let item of dataSource;let i = index; trackBy: trackByIdx\">\n <ng-container *ngIf=\"item;else loadingTpl\">\n <li [class.ax-state-selected]=\"isItemSelected(item)\" [class.ax-state-disabled]=\"isItemDisabled(item)\"\n [attr.tabindex]=\"i\" (click)=\"_handleOnItemClick($event, item)\" [attr.data-id]=\"item\">\n <!-- Custom Item Template -->\n <ng-container *ngIf=\"itemTemplate;else defaultItemTpl\">\n <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: { data:item } }\">\n </ng-container>\n </ng-container>\n <!-- Default Item Template -->\n <ng-template #defaultItemTpl>\n <ng-container *ngIf=\"item;else loadingTpl\">\n <div class=\"ax-label-container\">\n <input class=\"ax-checkbox\" *ngIf=\"multiple && checkbox\" type=\"checkbox\"\n [checked]=\"isItemSelected(item)\" [disabled]=\"isItemDisabled(item)\" tabindex=\"0\" />\n <span [class.ax-checkbox-label]=\"multiple && checkbox\">{{getDisplayText(item)}}</span>\n </div>\n <i class=\"ax-icon ax-icon-done ax-selected-icon\" *ngIf=\"isItemSelected(item) \"></i>\n </ng-container>\n </ng-template>\n </li>\n </ng-container>\n </ng-container>\n </ul>\n</cdk-virtual-scroll-viewport>\n<!-- Empty Template -->\n<ng-container *ngIf=\"emptyTemplate && !hasItems && isLoading===false\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n</ng-container>\n<!-- Loading Template -->\n<ng-template #loadingTpl>\n <!-- Custom Loading Template -->\n <ng-container *ngIf=\"loadingTemplate;else defaultLoadingTpl\">\n <ng-container *ngTemplateOutlet=\"loadingTemplate\">\n </ng-container>\n </ng-container>\n <!-- Default Loading Template -->\n <ng-template #defaultLoadingTpl>\n <li>Loading...</li>\n </ng-template>\n</ng-template>\n<ng-content select=\"ax-footer\"></ng-content>", styles: ["ax-list{width:100%;height:100%;display:flex;flex-direction:column}ax-list.ax-default .cdk-virtual-scroll-viewport li{padding-inline-start:.75rem;padding-inline-end:1rem;position:relative;height:var(--ax-size-default);display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;cursor:pointer}ax-list.ax-default .cdk-virtual-scroll-viewport li:focus,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-within,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-visible{outline:transparent;background-color:rgba(var(--ax-color-primary-100))}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-label-container{display:flex;align-items:center}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-checkbox-label{margin-inline-start:.5rem}ax-list.ax-default .cdk-virtual-scroll-viewport li .ax-selected-icon{color:rgba(var(--ax-color-primary-500));font-size:1.5rem}ax-list.ax-default .cdk-virtual-scroll-viewport li.ax-state-selected:not(ax-list.ax-default .cdk-virtual-scroll-viewport li:focus,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-within,ax-list.ax-default .cdk-virtual-scroll-viewport li:focus-visible){background-color:rgba(var(--ax-color-default))!important;color:rgba(var(--ax-color-default-fore))!important}ax-list.ax-default .cdk-virtual-scroll-viewport li.ax-state-disabled{cursor:not-allowed;opacity:.5}\n"] }]
202
+ }], propDecorators: { source: [{
203
+ type: Input
204
+ }], itemHeight: [{
205
+ type: Input
206
+ }], itemTemplate: [{
207
+ type: Input
208
+ }], emptyTemplate: [{
209
+ type: Input
210
+ }], loadingTemplate: [{
211
+ type: Input
212
+ }], checkbox: [{
213
+ type: Input
214
+ }], _handleKeydown: [{
215
+ type: HostListener,
216
+ args: ['keydown', ['$event']]
217
+ }], __hostClass: [{
218
+ type: HostBinding,
219
+ args: ['class']
220
+ }] } });
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../../../libs/components/list/src/lib/list.component.ts","../../../../../../libs/components/list/src/lib/list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, OnInit, AfterViewInit, Input, TemplateRef, HostBinding, HostListener, forwardRef } from '@angular/core';\nimport { AXDataListFetchCallbackResult, AXDataListItems, MXSelectionValueComponent, AXComponent, AXFocusableComponent, AXValuableComponent } from '@acorex/components/common';\nimport { BehaviorSubject, Observable, Subscription, debounceTime, distinctUntilChanged, of } from 'rxjs';\nimport { CollectionViewer, DataSource } from '@angular/cdk/collections';\nimport { CdkVirtualScrollableElement } from '@angular/cdk/scrolling';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n\nexport class AXListDataSource<T = any> extends DataSource<T> {\n    private pageSize = 20;\n    private debounceTime = 300;\n    private _cachedData: T[] = new Array(this.config.pageSize);\n    private fetchedPages = new Set<number>();\n    private subscription = new Subscription();\n    private initiated = false;\n    private source: AXDataListItems;\n\n    public dataStream = new BehaviorSubject<T[]>(this._cachedData);\n    public loadingState = new BehaviorSubject<boolean>(true);\n    public get cachedItems(): T[] {\n        return this._cachedData || [];\n    }\n\n\n\n    /**\n     * @ignore\n     */\n    constructor(public config: { source: AXDataListItems, pageSize?: number, debounceTime?: number }) {\n        super();\n        this.source = config.source;\n        if (config.pageSize)\n            this.pageSize = config.pageSize;\n        if (config.debounceTime)\n            this.debounceTime = config.debounceTime;\n    }\n\n    connect(collectionViewer: CollectionViewer): Observable<T[]> {\n        this.subscription.add(\n            collectionViewer.viewChange\n                .pipe(debounceTime(this.debounceTime))\n                .pipe(distinctUntilChanged())\n                .subscribe(range => {\n                    const startPage = this.getPageForIndex(range.start);\n                    const endPage = this.getPageForIndex(range.end - 1);\n                    for (let i = startPage; i <= endPage; i++) {\n                        this.fetchPage(i);\n                    }\n                }));\n        return this.dataStream;\n    }\n\n    disconnect(): void {\n        this.subscription.unsubscribe();\n    }\n\n    private getPageForIndex(index: number): number {\n        return Math.floor(index / this.pageSize);\n    }\n\n    private fetchPage(page: number) {\n        if (this.fetchedPages.has(page)) {\n            return;\n        }\n        this.loadingState.next(true);\n        this.fetchedPages.add(page);\n        if (Array.isArray(this.source)) {\n            this._cachedData = this.source;\n            this.dataStream.next(this._cachedData);\n            this.loadingState.next(false);\n        }\n        else if (typeof this.source == 'function') {\n            const promise = this.source({\n                take: this.pageSize,\n                skip: this.pageSize * page\n            }) as Promise<AXDataListFetchCallbackResult>;\n            promise.then(result => {\n                if (!this.initiated) {\n                    this._cachedData = new Array(result.total);\n                    this.initiated = true;\n                }\n                this._cachedData.splice(page * this.pageSize, this.pageSize,\n                    ...result.items);\n                this.dataStream.next(this._cachedData);\n            }).finally(() => {\n                this.loadingState.next(false);\n            });\n        }\n    }\n}\n\n\n@Component({\n    selector: 'ax-list',\n    templateUrl: './list.component.html',\n    styleUrls: ['./list.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    inputs: [\n        'id',\n        'name',\n        'disabled',\n        'readonly',\n        'valueField',\n        'textField',\n        'disabledField',\n        'multiple'\n    ],\n    outputs: [\n        'onValueChanged',\n        'disabledChange',\n        'readOnlyChange',\n        'onBlur',\n        'onFocus'\n    ],\n    hostDirectives: [\n        {\n            directive: CdkVirtualScrollableElement\n        }\n    ],\n    providers: [\n        { provide: AXComponent, useExisting: AXListComponent },\n        { provide: AXFocusableComponent, useExisting: AXListComponent },\n        { provide: AXValuableComponent, useExisting: AXListComponent },\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => AXListComponent),\n            multi: true,\n        },\n    ],\n})\nexport class AXListComponent extends MXSelectionValueComponent implements OnInit, AfterViewInit {\n\n    @Input()\n    source: AXDataListItems = [];\n\n    @Input()\n    itemHeight: number | 'auto' = 40;\n\n    @Input()\n    itemTemplate: TemplateRef<unknown>\n\n    @Input()\n    emptyTemplate: TemplateRef<unknown>\n\n    @Input()\n    loadingTemplate: TemplateRef<unknown>\n\n\n    @Input()\n    checkbox = true;\n\n    protected dataSource: AXListDataSource<unknown>;\n    protected isLoading = true;\n    protected hasItems = false;\n\n    trackByIdx(i) {\n        return i;\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.dataSource = new AXListDataSource<unknown>({\n            source: this.source\n        });\n        this.dataSource.loadingState.subscribe(data => {\n            this.isLoading = data;\n        });\n        this.dataSource.dataStream.subscribe(data => {\n            this.hasItems = data.length > 0;\n        });\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n    }\n\n    _handleOnItemClick(e: MouseEvent, item: any) {\n        if (this.readonly || this.disabled) {\n            e.preventDefault();\n            e.stopPropagation();\n            return;\n        }\n        if (this.isItemDisabled(item)) {\n            return;\n        }\n        this.toggleSelect(item);\n    }\n\n\n    @HostListener('keydown', ['$event'])\n    _handleKeydown(e: KeyboardEvent) {\n        if ((e.code === 'ArrowDown' || e.code === 'ArrowUp') && this.hasItems) {\n            this.focusItemByNav(e.key === 'ArrowDown' ? 1 : -1);\n            e.preventDefault();\n        }\n        if ((e.code === 'Space' || e.code === 'Enter') && this.hasItems) {\n            if (this.readonly || this.disabled) {\n                e.preventDefault();\n                e.stopPropagation();\n                return;\n            }\n            const id = document.activeElement?.closest('li')?.dataset?.id;\n            this.toggleSelect(id);\n            e.preventDefault();\n            e.stopPropagation()\n        }\n    }\n\n\n    private focusItemByNav(sign: -1 | 1): void {\n        const list = this.getHostElement().querySelector('ul');\n        const fn = (s) => list.querySelector<HTMLDivElement>(s);\n        const itemDiv: HTMLElement =\n            document.activeElement?.closest('li') ||\n            fn(`li.ax-state-selected`) ||\n            fn(`li`);\n        const next = (sign == 1 ? itemDiv.nextElementSibling : itemDiv.previousElementSibling) as HTMLElement;\n        if (next) {\n            next.focus();\n        }\n    }\n\n    /**\n     *  @ignore\n     */\n    @HostBinding('class')\n    get __hostClass(): string {\n        const _class = `ax-default`;\n        return this.itemTemplate ? '' : _class;\n    }\n\n    getItemByKey(key: unknown): unknown {\n        const cachedItem = this.dataSource.cachedItems.find(c => c && c[this.valueField] == key);\n        return cachedItem || { [this.valueField]: key, [this.textField]: key };\n    }\n\n}\n","<ng-content select=\"ax-header\"></ng-content>\n<cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight+'px'\"\n    class=\"ax-list-items-container\">\n    <ul>\n        <!--  Item Template  -->\n        <ng-container *cdkVirtualFor=\"let item of dataSource;let i = index; trackBy: trackByIdx\">\n            <ng-container *ngIf=\"item;else loadingTpl\">\n                <li [class.ax-state-selected]=\"isItemSelected(item)\" [class.ax-state-disabled]=\"isItemDisabled(item)\"\n                    [attr.tabindex]=\"i\" (click)=\"_handleOnItemClick($event, item)\" [attr.data-id]=\"item\">\n                    <!--  Custom Item Template  -->\n                    <ng-container *ngIf=\"itemTemplate;else defaultItemTpl\">\n                        <ng-container *ngTemplateOutlet=\"itemTemplate;context: { $implicit: { data:item } }\">\n                        </ng-container>\n                    </ng-container>\n                    <!--  Default Item Template  -->\n                    <ng-template #defaultItemTpl>\n                        <ng-container *ngIf=\"item;else loadingTpl\">\n                            <div class=\"ax-label-container\">\n                                <input class=\"ax-checkbox\" *ngIf=\"multiple && checkbox\" type=\"checkbox\"\n                                    [checked]=\"isItemSelected(item)\" [disabled]=\"isItemDisabled(item)\" tabindex=\"0\" />\n                                <span [class.ax-checkbox-label]=\"multiple && checkbox\">{{getDisplayText(item)}}</span>\n                            </div>\n                            <i class=\"ax-icon ax-icon-done ax-selected-icon\" *ngIf=\"isItemSelected(item) \"></i>\n                        </ng-container>\n                    </ng-template>\n                </li>\n            </ng-container>\n        </ng-container>\n    </ul>\n</cdk-virtual-scroll-viewport>\n<!--  Empty Template  -->\n<ng-container *ngIf=\"emptyTemplate && !hasItems && isLoading===false\">\n    <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n</ng-container>\n<!--  Loading Template  -->\n<ng-template #loadingTpl>\n    <!--  Custom Loading Template  -->\n    <ng-container *ngIf=\"loadingTemplate;else defaultLoadingTpl\">\n        <ng-container *ngTemplateOutlet=\"loadingTemplate\">\n        </ng-container>\n    </ng-container>\n    <!--  Default Loading Template  -->\n    <ng-template #defaultLoadingTpl>\n        <li>Loading...</li>\n    </ng-template>\n</ng-template>\n<ng-content select=\"ax-footer\"></ng-content>"]}
@@ -0,0 +1,22 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { AXListComponent } from './list.component';
4
+ import { ScrollingModule } from '@angular/cdk/scrolling';
5
+ import * as i0 from "@angular/core";
6
+ const COMPONENT = [AXListComponent];
7
+ const MODULES = [CommonModule, ScrollingModule];
8
+ export class AXListModule {
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.9", ngImport: i0, type: AXListModule, declarations: [AXListComponent], imports: [CommonModule, ScrollingModule], exports: [AXListComponent] }); }
11
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXListModule, imports: [MODULES] }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXListModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ declarations: [...COMPONENT],
17
+ imports: [...MODULES],
18
+ exports: [...COMPONENT],
19
+ providers: [],
20
+ }]
21
+ }] });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdC9zcmMvbGliL2xpc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBRXpELE1BQU0sU0FBUyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7QUFDcEMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLENBQUM7QUFRaEQsTUFBTSxPQUFPLFlBQVk7OEdBQVosWUFBWTsrR0FBWixZQUFZLGlCQVROLGVBQWUsYUFDakIsWUFBWSxFQUFFLGVBQWUsYUFEM0IsZUFBZTsrR0FTckIsWUFBWSxZQUpSLE9BQU87OzJGQUlYLFlBQVk7a0JBTnhCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBBWExpc3RDb21wb25lbnQgfSBmcm9tICcuL2xpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IFNjcm9sbGluZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9zY3JvbGxpbmcnO1xuXG5jb25zdCBDT01QT05FTlQgPSBbQVhMaXN0Q29tcG9uZW50XTtcbmNvbnN0IE1PRFVMRVMgPSBbQ29tbW9uTW9kdWxlLCBTY3JvbGxpbmdNb2R1bGVdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXG4gICAgaW1wb3J0czogWy4uLk1PRFVMRVNdLFxuICAgIGV4cG9ydHM6IFsuLi5DT01QT05FTlRdLFxuICAgIHByb3ZpZGVyczogW10sXG59KVxuZXhwb3J0IGNsYXNzIEFYTGlzdE1vZHVsZSB7IH1cbiJdfQ==
@@ -1,17 +1,30 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
1
+ import { DialogModule } from '@angular/cdk/dialog';
3
2
  import { OverlayModule } from '@angular/cdk/overlay';
4
3
  import { PortalModule } from '@angular/cdk/portal';
4
+ import { CommonModule } from '@angular/common';
5
+ import { NgModule } from '@angular/core';
6
+ import { AXLoadingSpinnerComponent } from './loading-spinner.component';
5
7
  import { AXLoadingComponent } from './loading.component';
6
8
  import { AXLoadingDirective } from './loading.directive';
7
- import { AXLoadingSpinnerComponent } from './loading-spinner.component';
9
+ import { AXLoadingService } from './loading.service';
8
10
  import * as i0 from "@angular/core";
9
- const COMPONENT = [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent, AXLoadingSpinnerComponent];
10
- const MODULES = [CommonModule, OverlayModule, PortalModule];
11
+ const COMPONENT = [
12
+ AXLoadingComponent,
13
+ AXLoadingDirective,
14
+ AXLoadingSpinnerComponent,
15
+ AXLoadingSpinnerComponent,
16
+ ];
17
+ const MODULES = [CommonModule, OverlayModule, DialogModule, PortalModule];
11
18
  export class AXLoadingModule {
12
19
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
13
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, declarations: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent, AXLoadingSpinnerComponent], imports: [CommonModule, OverlayModule, PortalModule], exports: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent, AXLoadingSpinnerComponent] }); }
14
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, imports: [MODULES] }); }
20
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, declarations: [AXLoadingComponent,
21
+ AXLoadingDirective,
22
+ AXLoadingSpinnerComponent,
23
+ AXLoadingSpinnerComponent], imports: [CommonModule, OverlayModule, DialogModule, PortalModule], exports: [AXLoadingComponent,
24
+ AXLoadingDirective,
25
+ AXLoadingSpinnerComponent,
26
+ AXLoadingSpinnerComponent] }); }
27
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, providers: [AXLoadingService], imports: [MODULES] }); }
15
28
  }
16
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingModule, decorators: [{
17
30
  type: NgModule,
@@ -19,6 +32,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImpor
19
32
  declarations: [...COMPONENT],
20
33
  imports: [...MODULES],
21
34
  exports: [...COMPONENT],
35
+ providers: [AXLoadingService],
22
36
  }]
23
37
  }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbG9hZGluZy9zcmMvbGliL2xvYWRpbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7O0FBRXhFLE1BQU0sU0FBUyxHQUFHLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUseUJBQXlCLEVBQUUseUJBQXlCLENBQUMsQ0FBQztBQUNqSCxNQUFNLE9BQU8sR0FBRyxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxDQUFDLENBQUM7QUFPNUQsTUFBTSxPQUFPLGVBQWU7OEdBQWYsZUFBZTsrR0FBZixlQUFlLGlCQVJULGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLHlCQUF5QixFQUFFLHlCQUF5QixhQUM5RixZQUFZLEVBQUUsYUFBYSxFQUFFLFlBQVksYUFEdkMsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUseUJBQXlCLEVBQUUseUJBQXlCOytHQVFsRyxlQUFlLFlBSFgsT0FBTzs7MkZBR1gsZUFBZTtrQkFMM0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IFBvcnRhbE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgQVhMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBWExvYWRpbmdEaXJlY3RpdmUgfSBmcm9tICcuL2xvYWRpbmcuZGlyZWN0aXZlJztcbmltcG9ydCB7IEFYTG9hZGluZ1NwaW5uZXJDb21wb25lbnQgfSBmcm9tICcuL2xvYWRpbmctc3Bpbm5lci5jb21wb25lbnQnO1xuXG5jb25zdCBDT01QT05FTlQgPSBbQVhMb2FkaW5nQ29tcG9uZW50LCBBWExvYWRpbmdEaXJlY3RpdmUsIEFYTG9hZGluZ1NwaW5uZXJDb21wb25lbnQsIEFYTG9hZGluZ1NwaW5uZXJDb21wb25lbnRdO1xuY29uc3QgTU9EVUxFUyA9IFtDb21tb25Nb2R1bGUsIE92ZXJsYXlNb2R1bGUsIFBvcnRhbE1vZHVsZV07XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQ09NUE9ORU5UXSxcbiAgICBpbXBvcnRzOiBbLi4uTU9EVUxFU10sXG4gICAgZXhwb3J0czogWy4uLkNPTVBPTkVOVF0sXG59KVxuZXhwb3J0IGNsYXNzIEFYTG9hZGluZ01vZHVsZSB7XG59XG4iXX0=
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbG9hZGluZy9zcmMvbGliL2xvYWRpbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUVyRCxNQUFNLFNBQVMsR0FBRztJQUNoQixrQkFBa0I7SUFDbEIsa0JBQWtCO0lBQ2xCLHlCQUF5QjtJQUN6Qix5QkFBeUI7Q0FDMUIsQ0FBQztBQUNGLE1BQU0sT0FBTyxHQUFHLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsWUFBWSxDQUFDLENBQUM7QUFRMUUsTUFBTSxPQUFPLGVBQWU7OEdBQWYsZUFBZTsrR0FBZixlQUFlLGlCQWIxQixrQkFBa0I7WUFDbEIsa0JBQWtCO1lBQ2xCLHlCQUF5QjtZQUN6Qix5QkFBeUIsYUFFVixZQUFZLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxZQUFZLGFBTHRFLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIseUJBQXlCO1lBQ3pCLHlCQUF5QjsrR0FVZCxlQUFlLGFBRmYsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUZoQixPQUFPOzsyRkFJVCxlQUFlO2tCQU4zQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxHQUFHLE9BQU8sQ0FBQztvQkFDckIsT0FBTyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQ3ZCLFNBQVMsRUFBRSxDQUFDLGdCQUFnQixDQUFDO2lCQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IFBvcnRhbE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWExvYWRpbmdTcGlubmVyQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nLXNwaW5uZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEFYTG9hZGluZ0NvbXBvbmVudCB9IGZyb20gJy4vbG9hZGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhMb2FkaW5nRGlyZWN0aXZlIH0gZnJvbSAnLi9sb2FkaW5nLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBBWExvYWRpbmdTZXJ2aWNlIH0gZnJvbSAnLi9sb2FkaW5nLnNlcnZpY2UnO1xuXG5jb25zdCBDT01QT05FTlQgPSBbXG4gIEFYTG9hZGluZ0NvbXBvbmVudCxcbiAgQVhMb2FkaW5nRGlyZWN0aXZlLFxuICBBWExvYWRpbmdTcGlubmVyQ29tcG9uZW50LFxuICBBWExvYWRpbmdTcGlubmVyQ29tcG9uZW50LFxuXTtcbmNvbnN0IE1PRFVMRVMgPSBbQ29tbW9uTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBEaWFsb2dNb2R1bGUsIFBvcnRhbE1vZHVsZV07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXG4gIGltcG9ydHM6IFsuLi5NT0RVTEVTXSxcbiAgZXhwb3J0czogWy4uLkNPTVBPTkVOVF0sXG4gIHByb3ZpZGVyczogW0FYTG9hZGluZ1NlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBBWExvYWRpbmdNb2R1bGUge31cbiJdfQ==
@@ -1,8 +1,8 @@
1
+ import { Dialog } from '@angular/cdk/dialog';
1
2
  import { Injectable, inject } from '@angular/core';
2
- import { asyncScheduler, BehaviorSubject } from 'rxjs';
3
+ import { BehaviorSubject, asyncScheduler } from 'rxjs';
3
4
  import { finalize, observeOn } from 'rxjs/operators';
4
5
  import { AXLoadingComponent } from './loading.component';
5
- import { Dialog } from '@angular/cdk/dialog';
6
6
  import * as i0 from "@angular/core";
7
7
  const DEFAULT_LOADER_ID = '_DEFAULT';
8
8
  export class AXLoadingService {
@@ -35,18 +35,18 @@ export class AXLoadingService {
35
35
  const bg = dialogRef.overlayRef.backdropElement;
36
36
  const ov = dialogRef.overlayRef.overlayElement;
37
37
  ce.style.position = 'relative';
38
- ov.style.position = "absolute";
38
+ ov.style.position = 'absolute';
39
39
  ce.appendChild(bg);
40
40
  ce.appendChild(ov);
41
41
  setTimeout(() => {
42
- ov.style.position = "absolute";
42
+ ov.style.position = 'absolute';
43
43
  }, 0);
44
44
  }
45
45
  return id;
46
46
  // TODO: diabled focus and click, maybe we need a service and directive for it
47
47
  }
48
48
  hide(id) {
49
- const f = this.dialog.openDialogs.find(c => c.componentInstance.id === id.toString());
49
+ const f = this.dialog.openDialogs.find((c) => c.componentInstance.id === id.toString());
50
50
  if (f) {
51
51
  f.close();
52
52
  }
@@ -65,7 +65,7 @@ export class AXLoadingService {
65
65
  return loaderStates.get(this.getLoaderId(loaderId)) ?? false;
66
66
  }
67
67
  else {
68
- return [...loaderStates.values()].filter(state => state).length > 0;
68
+ return [...loaderStates.values()].filter((state) => state).length > 0;
69
69
  }
70
70
  }
71
71
  }
@@ -98,7 +98,6 @@ export class AXLoadingService {
98
98
  }
99
99
  }
100
100
  else {
101
- // @ts-ignore - loadingStates[context] is surely defined in this branch
102
101
  this.loadingStates.get(context).set(loaderId, state);
103
102
  this.loadingStates$.get(context).get(loaderId).next(state);
104
103
  }
@@ -116,12 +115,9 @@ export class AXLoadingService {
116
115
  return loaderId ?? DEFAULT_LOADER_ID;
117
116
  }
118
117
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
119
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingService, providedIn: 'root' }); }
118
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingService }); }
120
119
  }
121
120
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXLoadingService, decorators: [{
122
- type: Injectable,
123
- args: [{
124
- providedIn: 'root',
125
- }]
121
+ type: Injectable
126
122
  }] });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.service.js","sourceRoot":"","sources":["../../../../../../libs/components/loading/src/lib/loading.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { asyncScheduler, BehaviorSubject, Observable } from 'rxjs';\nimport { finalize, observeOn } from 'rxjs/operators';\nimport { AXLoadingComponent } from './loading.component';\nimport { Dialog } from '@angular/cdk/dialog';\n\ntype LoadingContext = object;\ntype LoaderId = string | number; // expected enum values\nconst DEFAULT_LOADER_ID: LoaderId = '_DEFAULT';\n\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class AXLoadingService {\n  // WeakMap will remove components from itself upon\n  // their garbage collection by JS runtime.\n  protected loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\n  // Both loading state maps are kept in-sync such that\n  // they can be used by both sync and async methods.\n  protected loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\n\n  private dialog = inject(Dialog);\n\n  show(config?: { location?: Element; type?: string; context?: unknown }): number {\n    const ce = (config?.location ?? document.body) as HTMLDivElement;\n    const dialogRef = this.dialog.open(AXLoadingComponent,\n      {\n        hasBackdrop: true,\n        disableClose: true,\n        restoreFocus: true,\n        closeOnDestroy: true,\n        closeOnNavigation: true,\n        ariaModal: true,\n        role: 'alertdialog',\n        panelClass: ['ax-loading-pane', 'ax-animate-fadeIn'],\n        backdropClass: ['ax-loading-overlay-backdrop', 'ax-animate-fadeIn'],\n      }\n    );\n    const id = new Date().getTime();\n    dialogRef.componentInstance.visible = true;\n    dialogRef.componentInstance.id = id.toString();\n    if (ce != document.body) {\n      const bg = dialogRef.overlayRef.backdropElement;\n      const ov = dialogRef.overlayRef.overlayElement;\n      ce.style.position = 'relative';\n      ov.style.position = \"absolute\";\n      ce.appendChild(bg);\n      ce.appendChild(ov);\n      setTimeout(() => {\n        ov.style.position = \"absolute\";\n      }, 0);\n    }\n    return id;\n    // TODO: diabled focus and click, maybe we need a service and directive for it\n  }\n\n  hide(id: number): void {\n    const f = this.dialog.openDialogs.find(c => c.componentInstance.id === id.toString());\n    if (f) {\n      f.close();\n    }\n  }\n\n  doLoading<V>(source$: Observable<V>, context: LoadingContext, loaderId?: LoaderId): Observable<V> {\n    this.startLoading(context, loaderId);\n    return source$.pipe(\n      observeOn(asyncScheduler),\n      finalize(() => this.endLoading(context, loaderId))\n    );\n  }\n\n\n  isLoading(context: LoadingContext, loaderId?: LoaderId): boolean {\n    const loaderStates = this.loadingStates.get(context);\n\n    if (!loaderStates) {\n      return false;\n    } else {\n      if (loaderId !== undefined) {\n        return loaderStates.get(this.getLoaderId(loaderId)) ?? false;\n      } else {\n        return [...loaderStates.values()].filter(state => state).length > 0;\n      }\n    }\n  }\n\n\n  isLoading$(context: LoadingContext, loaderId?: LoaderId | any): Observable<boolean> {\n    const coalescedLoaderId = this.getLoaderId(loaderId);\n\n    if (!this.hasLoadingStates(context, coalescedLoaderId)) {\n      this.setLoadingState(context, false, loaderId);\n    }\n\n    return this.loadingStates$.get(context).get(coalescedLoaderId);\n  }\n\n\n  startLoading(context: LoadingContext, loaderId?: LoaderId): void {\n    this.setLoadingState(context, true, this.getLoaderId(loaderId));\n  }\n\n  endLoading(context: LoadingContext, loaderId?: LoaderId): void {\n    this.setLoadingState(context, false, this.getLoaderId(loaderId));\n  }\n\n\n  clearLoadings(): void {\n    this.loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\n    this.loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\n  }\n\n  protected setLoadingState(context: LoadingContext, state: boolean, loaderId: LoaderId): void {\n    if (!this.hasLoadingStates(context, loaderId)) {\n      if (this.hasContextLoadingState(context)) {\n        this.loadingStates.get(context).set(loaderId, state);\n        this.loadingStates$.get(context).set(loaderId, new BehaviorSubject<boolean>(state));\n      } else {\n        this.loadingStates.set(context, new Map<LoaderId, boolean>([[loaderId, state]]));\n        this.loadingStates$.set(context, new Map<LoaderId, BehaviorSubject<boolean>>([[loaderId, new BehaviorSubject<boolean>(state)]]));\n      }\n    } else {\n      // @ts-ignore - loadingStates[context] is surely defined in this branch\n      this.loadingStates.get(context).set(loaderId, state);\n      this.loadingStates$.get(context).get(loaderId).next(state);\n    }\n  }\n\n  protected hasLoadingStates(context: LoadingContext, loaderId: LoaderId) {\n    return this.hasContextLoadingState(context) && this.hasLoaderLoadingState(context, loaderId);\n  }\n\n  protected hasContextLoadingState(context: LoadingContext) {\n    return this.loadingStates.has(context) && this.loadingStates$.has(context);\n  }\n\n  protected hasLoaderLoadingState(context: LoadingContext, loaderId: LoaderId) {\n    return this.loadingStates.get(context).has(loaderId) && this.loadingStates$.get(context).has(loaderId);\n  }\n\n  protected getLoaderId(loaderId?: LoaderId): LoaderId {\n    return loaderId ?? DEFAULT_LOADER_ID;\n  }\n}\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.service.js","sourceRoot":"","sources":["../../../../../../libs/components/loading/src/lib/loading.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dialog } from '@angular/cdk/dialog';\nimport { Injectable, inject } from '@angular/core';\nimport { BehaviorSubject, Observable, asyncScheduler } from 'rxjs';\nimport { finalize, observeOn } from 'rxjs/operators';\nimport { AXLoadingComponent } from './loading.component';\n\ntype LoadingContext = object;\ntype LoaderId = string | number; // expected enum values\nconst DEFAULT_LOADER_ID: LoaderId = '_DEFAULT';\n\n@Injectable()\nexport class AXLoadingService {\n  // WeakMap will remove components from itself upon\n  // their garbage collection by JS runtime.\n  protected loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\n  // Both loading state maps are kept in-sync such that\n  // they can be used by both sync and async methods.\n  protected loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\n\n  private dialog = inject(Dialog);\n\n  show(config?: { location?: Element; type?: string; context?: unknown }): number {\n    const ce = (config?.location ?? document.body) as HTMLDivElement;\n    const dialogRef = this.dialog.open(AXLoadingComponent, {\n      hasBackdrop: true,\n      disableClose: true,\n      restoreFocus: true,\n      closeOnDestroy: true,\n      closeOnNavigation: true,\n      ariaModal: true,\n      role: 'alertdialog',\n      panelClass: ['ax-loading-pane', 'ax-animate-fadeIn'],\n      backdropClass: ['ax-loading-overlay-backdrop', 'ax-animate-fadeIn'],\n    });\n    const id = new Date().getTime();\n    dialogRef.componentInstance.visible = true;\n    dialogRef.componentInstance.id = id.toString();\n    if (ce != document.body) {\n      const bg = dialogRef.overlayRef.backdropElement;\n      const ov = dialogRef.overlayRef.overlayElement;\n      ce.style.position = 'relative';\n      ov.style.position = 'absolute';\n      ce.appendChild(bg);\n      ce.appendChild(ov);\n      setTimeout(() => {\n        ov.style.position = 'absolute';\n      }, 0);\n    }\n    return id;\n    // TODO: diabled focus and click, maybe we need a service and directive for it\n  }\n\n  hide(id: number): void {\n    const f = this.dialog.openDialogs.find((c) => c.componentInstance.id === id.toString());\n    if (f) {\n      f.close();\n    }\n  }\n\n  doLoading<V>(source$: Observable<V>, context: LoadingContext, loaderId?: LoaderId): Observable<V> {\n    this.startLoading(context, loaderId);\n    return source$.pipe(\n      observeOn(asyncScheduler),\n      finalize(() => this.endLoading(context, loaderId)),\n    );\n  }\n\n  isLoading(context: LoadingContext, loaderId?: LoaderId): boolean {\n    const loaderStates = this.loadingStates.get(context);\n\n    if (!loaderStates) {\n      return false;\n    } else {\n      if (loaderId !== undefined) {\n        return loaderStates.get(this.getLoaderId(loaderId)) ?? false;\n      } else {\n        return [...loaderStates.values()].filter((state) => state).length > 0;\n      }\n    }\n  }\n\n  isLoading$(context: LoadingContext, loaderId?: LoaderId | any): Observable<boolean> {\n    const coalescedLoaderId = this.getLoaderId(loaderId);\n\n    if (!this.hasLoadingStates(context, coalescedLoaderId)) {\n      this.setLoadingState(context, false, loaderId);\n    }\n\n    return this.loadingStates$.get(context).get(coalescedLoaderId);\n  }\n\n  startLoading(context: LoadingContext, loaderId?: LoaderId): void {\n    this.setLoadingState(context, true, this.getLoaderId(loaderId));\n  }\n\n  endLoading(context: LoadingContext, loaderId?: LoaderId): void {\n    this.setLoadingState(context, false, this.getLoaderId(loaderId));\n  }\n\n  clearLoadings(): void {\n    this.loadingStates = new WeakMap<LoadingContext, Map<LoaderId, boolean>>();\n    this.loadingStates$ = new WeakMap<LoadingContext, Map<LoaderId, BehaviorSubject<boolean>>>();\n  }\n\n  protected setLoadingState(context: LoadingContext, state: boolean, loaderId: LoaderId): void {\n    if (!this.hasLoadingStates(context, loaderId)) {\n      if (this.hasContextLoadingState(context)) {\n        this.loadingStates.get(context).set(loaderId, state);\n        this.loadingStates$.get(context).set(loaderId, new BehaviorSubject<boolean>(state));\n      } else {\n        this.loadingStates.set(context, new Map<LoaderId, boolean>([[loaderId, state]]));\n        this.loadingStates$.set(\n          context,\n          new Map<LoaderId, BehaviorSubject<boolean>>([[loaderId, new BehaviorSubject<boolean>(state)]]),\n        );\n      }\n    } else {\n      this.loadingStates.get(context).set(loaderId, state);\n      this.loadingStates$.get(context).get(loaderId).next(state);\n    }\n  }\n\n  protected hasLoadingStates(context: LoadingContext, loaderId: LoaderId) {\n    return this.hasContextLoadingState(context) && this.hasLoaderLoadingState(context, loaderId);\n  }\n\n  protected hasContextLoadingState(context: LoadingContext) {\n    return this.loadingStates.has(context) && this.loadingStates$.has(context);\n  }\n\n  protected hasLoaderLoadingState(context: LoadingContext, loaderId: LoaderId) {\n    return this.loadingStates.get(context).has(loaderId) && this.loadingStates$.get(context).has(loaderId);\n  }\n\n  protected getLoaderId(loaderId?: LoaderId): LoaderId {\n    return loaderId ?? DEFAULT_LOADER_ID;\n  }\n}\n"]}
@@ -1,3 +1,6 @@
1
+ export * from './lib/class/root-menu.class';
2
+ export * from './lib/menu-item/menu-item.component';
1
3
  export * from './lib/menu.component';
2
4
  export * from './lib/menu.module';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVudS5tb2R1bGUnO1xuIl19
5
+ export * from './lib/menu2.component';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2xhc3Mvcm9vdC1tZW51LmNsYXNzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUtaXRlbS9tZW51LWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUyLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export class AXRootMenu {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC1tZW51LmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21lbnUvc3JjL2xpYi9jbGFzcy9yb290LW1lbnUuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLFVBQVU7Q0FFdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWE9yaWVudGF0aW9uIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5cbmV4cG9ydCBjbGFzcyBBWFJvb3RNZW51IHtcbiAgb3JpYXRhdGlvbjogQVhPcmllbnRhdGlvbjtcbn1cbiJdfQ==
@@ -0,0 +1,96 @@
1
+ import { MXBaseComponent } from '@acorex/components/common';
2
+ import { AXPopoverComponent } from '@acorex/components/popover';
3
+ import { Component, ContentChildren, HostBinding, Input, QueryList, ViewChild, inject, } from '@angular/core';
4
+ import { AXRootMenu } from '../class/root-menu.class';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@acorex/components/popover";
8
+ export class AXMenuItemComponent extends MXBaseComponent {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.isRoot = false;
12
+ this.rootMenu = inject(AXRootMenu);
13
+ }
14
+ ngAfterViewInit() {
15
+ this.children.forEach((c) => {
16
+ c.parent = this;
17
+ });
18
+ }
19
+ close() {
20
+ this.popover?.close();
21
+ }
22
+ // @HostListener('mouseleave', ['$event'])
23
+ // private onMouseHover(e: MouseEvent) {
24
+ // console.log('a');
25
+ // this.children.forEach((c) => {
26
+ // c.close();
27
+ // });
28
+ // }
29
+ _handleOnOpened() {
30
+ // this.parent.children.forEach((c) => {
31
+ // if (c != this) {
32
+ // c.close();
33
+ // }
34
+ // });
35
+ }
36
+ _handleOnClosed() {
37
+ // this.children.forEach((c) => {
38
+ // c.close();
39
+ // });
40
+ }
41
+ getIcon() {
42
+ switch (this.rootMenu.oriatation) {
43
+ case 'vertical':
44
+ return 'ax-icon-arrow-right';
45
+ case 'horizontal':
46
+ return 'ax-icon-arrow-down';
47
+ }
48
+ }
49
+ getPlacement() {
50
+ debugger;
51
+ switch (this.rootMenu.oriatation) {
52
+ case 'horizontal':
53
+ if (this.isRoot) {
54
+ return 'bottom-start';
55
+ }
56
+ else {
57
+ return 'end-top';
58
+ }
59
+ break;
60
+ case 'vertical':
61
+ if (this.isRoot) {
62
+ return 'end-top';
63
+ }
64
+ else {
65
+ return 'end-top';
66
+ }
67
+ break;
68
+ default:
69
+ return 'bottom-start';
70
+ }
71
+ }
72
+ get __hostClass() {
73
+ return [`${this.disabled ? 'ax-state-disabled' : ''}`];
74
+ }
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXMenuItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
76
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.9", type: AXMenuItemComponent, selector: "ax-menu-item", inputs: { text: "text", disabled: "disabled" }, host: { properties: { "class": "this.__hostClass" } }, queries: [{ propertyName: "children", predicate: AXMenuItemComponent }], viewQueries: [{ propertyName: "popover", first: true, predicate: AXPopoverComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\"></ng-content>\n<div class=\"ax-menu-item-text\">{{ text }}</div>\n<ng-content select=\"ax-suffix\"></ng-content>\n<i class=\"ax-icon {{ getIcon() }} ax-menu-item-child-icon\" *ngIf=\"children.length\"></i>\n\n<ax-popover\n [closeOn]=\"'clickOut'\"\n [openOn]=\"'click'\"\n [target]=\"getHostElement()\"\n [offsetY]=\"isRoot ? 8 : 0\"\n [offsetX]=\"isRoot ? 0 : 4\"\n [placement]=\"getPlacement()\"\n (onOpened)=\"_handleOnOpened()\"\n (onClosed)=\"_handleOnClosed()\"\n>\n <div class=\"ax-menu-item-children ax-parent-{{ this.rootMenu.oriatation }}\">\n <ng-content select=\"ax-menu-item\"></ng-content>\n </div>\n</ax-popover>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["offsetX", "offsetY", "target", "placement", "content", "openOn", "closeOn", "hasBackdrop", "openAfter", "closeAfter", "backdropClass", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }] }); }
77
+ }
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.9", ngImport: i0, type: AXMenuItemComponent, decorators: [{
79
+ type: Component,
80
+ args: [{ selector: 'ax-menu-item', template: "<ng-content select=\"ax-prefix\"></ng-content>\n<div class=\"ax-menu-item-text\">{{ text }}</div>\n<ng-content select=\"ax-suffix\"></ng-content>\n<i class=\"ax-icon {{ getIcon() }} ax-menu-item-child-icon\" *ngIf=\"children.length\"></i>\n\n<ax-popover\n [closeOn]=\"'clickOut'\"\n [openOn]=\"'click'\"\n [target]=\"getHostElement()\"\n [offsetY]=\"isRoot ? 8 : 0\"\n [offsetX]=\"isRoot ? 0 : 4\"\n [placement]=\"getPlacement()\"\n (onOpened)=\"_handleOnOpened()\"\n (onClosed)=\"_handleOnClosed()\"\n>\n <div class=\"ax-menu-item-children ax-parent-{{ this.rootMenu.oriatation }}\">\n <ng-content select=\"ax-menu-item\"></ng-content>\n </div>\n</ax-popover>\n" }]
81
+ }], propDecorators: { popover: [{
82
+ type: ViewChild,
83
+ args: [AXPopoverComponent]
84
+ }], text: [{
85
+ type: Input,
86
+ args: [{ required: true }]
87
+ }], disabled: [{
88
+ type: Input
89
+ }], children: [{
90
+ type: ContentChildren,
91
+ args: [AXMenuItemComponent]
92
+ }], __hostClass: [{
93
+ type: HostBinding,
94
+ args: ['class']
95
+ }] } });
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tZW51L3NyYy9saWIvbWVudS1pdGVtL21lbnUtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvbGliL21lbnUtaXRlbS9tZW51LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ2hFLE9BQU8sRUFFTCxTQUFTLEVBQ1QsZUFBZSxFQUNmLFdBQVcsRUFDWCxLQUFLLEVBQ0wsU0FBUyxFQUNULFNBQVMsRUFDVCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBTXRELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxlQUFlO0lBSnhEOztRQVdFLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFHZixhQUFRLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBeUUvQjtJQXBFQyxlQUFlO1FBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUMxQixDQUFDLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQztRQUNsQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsMENBQTBDO0lBQzFDLHdDQUF3QztJQUN4QyxzQkFBc0I7SUFDdEIsbUNBQW1DO0lBQ25DLGlCQUFpQjtJQUNqQixRQUFRO0lBQ1IsSUFBSTtJQUVKLGVBQWU7UUFDYix3Q0FBd0M7UUFDeEMscUJBQXFCO1FBQ3JCLGlCQUFpQjtRQUNqQixNQUFNO1FBQ04sTUFBTTtJQUNSLENBQUM7SUFFRCxlQUFlO1FBQ2IsaUNBQWlDO1FBQ2pDLGVBQWU7UUFDZixNQUFNO0lBQ1IsQ0FBQztJQUVELE9BQU87UUFDTCxRQUFRLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFO1lBQ2hDLEtBQUssVUFBVTtnQkFDYixPQUFPLHFCQUFxQixDQUFDO1lBQy9CLEtBQUssWUFBWTtnQkFDZixPQUFPLG9CQUFvQixDQUFDO1NBQy9CO0lBQ0gsQ0FBQztJQUVELFlBQVk7UUFDVixRQUFRLENBQUM7UUFFVCxRQUFRLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFO1lBQ2hDLEtBQUssWUFBWTtnQkFDZixJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7b0JBQ2YsT0FBTyxjQUFjLENBQUM7aUJBQ3ZCO3FCQUFNO29CQUNMLE9BQU8sU0FBUyxDQUFDO2lCQUNsQjtnQkFDRCxNQUFNO1lBQ1IsS0FBSyxVQUFVO2dCQUNiLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtvQkFDZixPQUFPLFNBQVMsQ0FBQztpQkFDbEI7cUJBQU07b0JBQ0wsT0FBTyxTQUFTLENBQUM7aUJBQ2xCO2dCQUNELE1BQU07WUFDUjtnQkFDRSxPQUFPLGNBQWMsQ0FBQztTQUN6QjtJQUNILENBQUM7SUFFRCxJQUNJLFdBQVc7UUFDYixPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN6RCxDQUFDOzhHQWxGVSxtQkFBbUI7a0dBQW5CLG1CQUFtQixvTEFZYixtQkFBbUIsc0VBWHpCLGtCQUFrQix1RUNuQi9CLHFxQkFtQkE7OzJGRERhLG1CQUFtQjtrQkFKL0IsU0FBUzsrQkFDRSxjQUFjOzhCQUtoQixPQUFPO3NCQURkLFNBQVM7dUJBQUMsa0JBQWtCO2dCQUdGLElBQUk7c0JBQTlCLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNoQixRQUFRO3NCQUFoQixLQUFLO2dCQVFOLFFBQVE7c0JBRFAsZUFBZTt1QkFBQyxtQkFBbUI7Z0JBb0VoQyxXQUFXO3NCQURkLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1YQmFzZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgQVhQb3BvdmVyQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL3BvcG92ZXInO1xuaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIEhvc3RCaW5kaW5nLFxuICBJbnB1dCxcbiAgUXVlcnlMaXN0LFxuICBWaWV3Q2hpbGQsXG4gIGluamVjdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWFJvb3RNZW51IH0gZnJvbSAnLi4vY2xhc3Mvcm9vdC1tZW51LmNsYXNzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXgtbWVudS1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21lbnUtaXRlbS5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYTWVudUl0ZW1Db21wb25lbnQgZXh0ZW5kcyBNWEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgQFZpZXdDaGlsZChBWFBvcG92ZXJDb21wb25lbnQpXG4gIHByaXZhdGUgcG9wb3ZlcjogQVhQb3BvdmVyQ29tcG9uZW50O1xuXG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIHRleHQ6IHN0cmluZztcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW47XG5cbiAgaXNSb290ID0gZmFsc2U7XG4gIHBhcmVudD86IEFYTWVudUl0ZW1Db21wb25lbnQ7XG5cbiAgcm9vdE1lbnUgPSBpbmplY3QoQVhSb290TWVudSk7XG5cbiAgQENvbnRlbnRDaGlsZHJlbihBWE1lbnVJdGVtQ29tcG9uZW50KVxuICBjaGlsZHJlbjogUXVlcnlMaXN0PEFYTWVudUl0ZW1Db21wb25lbnQ+O1xuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICB0aGlzLmNoaWxkcmVuLmZvckVhY2goKGMpID0+IHtcbiAgICAgIGMucGFyZW50ID0gdGhpcztcbiAgICB9KTtcbiAgfVxuXG4gIGNsb3NlKCkge1xuICAgIHRoaXMucG9wb3Zlcj8uY2xvc2UoKTtcbiAgfVxuXG4gIC8vIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnLCBbJyRldmVudCddKVxuICAvLyBwcml2YXRlIG9uTW91c2VIb3ZlcihlOiBNb3VzZUV2ZW50KSB7XG4gIC8vICAgY29uc29sZS5sb2coJ2EnKTtcbiAgLy8gICB0aGlzLmNoaWxkcmVuLmZvckVhY2goKGMpID0+IHtcbiAgLy8gICAgIGMuY2xvc2UoKTtcbiAgLy8gICB9KTtcbiAgLy8gfVxuXG4gIF9oYW5kbGVPbk9wZW5lZCgpIHtcbiAgICAvLyB0aGlzLnBhcmVudC5jaGlsZHJlbi5mb3JFYWNoKChjKSA9PiB7XG4gICAgLy8gICBpZiAoYyAhPSB0aGlzKSB7XG4gICAgLy8gICAgIGMuY2xvc2UoKTtcbiAgICAvLyAgIH1cbiAgICAvLyB9KTtcbiAgfVxuXG4gIF9oYW5kbGVPbkNsb3NlZCgpIHtcbiAgICAvLyB0aGlzLmNoaWxkcmVuLmZvckVhY2goKGMpID0+IHtcbiAgICAvLyAgIGMuY2xvc2UoKTtcbiAgICAvLyB9KTtcbiAgfVxuXG4gIGdldEljb24oKSB7XG4gICAgc3dpdGNoICh0aGlzLnJvb3RNZW51Lm9yaWF0YXRpb24pIHtcbiAgICAgIGNhc2UgJ3ZlcnRpY2FsJzpcbiAgICAgICAgcmV0dXJuICdheC1pY29uLWFycm93LXJpZ2h0JztcbiAgICAgIGNhc2UgJ2hvcml6b250YWwnOlxuICAgICAgICByZXR1cm4gJ2F4LWljb24tYXJyb3ctZG93bic7XG4gICAgfVxuICB9XG5cbiAgZ2V0UGxhY2VtZW50KCkge1xuICAgIGRlYnVnZ2VyO1xuXG4gICAgc3dpdGNoICh0aGlzLnJvb3RNZW51Lm9yaWF0YXRpb24pIHtcbiAgICAgIGNhc2UgJ2hvcml6b250YWwnOlxuICAgICAgICBpZiAodGhpcy5pc1Jvb3QpIHtcbiAgICAgICAgICByZXR1cm4gJ2JvdHRvbS1zdGFydCc7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuICdlbmQtdG9wJztcbiAgICAgICAgfVxuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ3ZlcnRpY2FsJzpcbiAgICAgICAgaWYgKHRoaXMuaXNSb290KSB7XG4gICAgICAgICAgcmV0dXJuICdlbmQtdG9wJztcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm4gJ2VuZC10b3AnO1xuICAgICAgICB9XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuICdib3R0b20tc3RhcnQnO1xuICAgIH1cbiAgfVxuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBnZXQgX19ob3N0Q2xhc3MoKTogc3RyaW5nW10ge1xuICAgIHJldHVybiBbYCR7dGhpcy5kaXNhYmxlZCA/ICdheC1zdGF0ZS1kaXNhYmxlZCcgOiAnJ31gXTtcbiAgfVxufVxuIiwiPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtcHJlZml4XCI+PC9uZy1jb250ZW50PlxuPGRpdiBjbGFzcz1cImF4LW1lbnUtaXRlbS10ZXh0XCI+e3sgdGV4dCB9fTwvZGl2PlxuPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtc3VmZml4XCI+PC9uZy1jb250ZW50PlxuPGkgY2xhc3M9XCJheC1pY29uIHt7IGdldEljb24oKSB9fSBheC1tZW51LWl0ZW0tY2hpbGQtaWNvblwiICpuZ0lmPVwiY2hpbGRyZW4ubGVuZ3RoXCI+PC9pPlxuXG48YXgtcG9wb3ZlclxuICBbY2xvc2VPbl09XCInY2xpY2tPdXQnXCJcbiAgW29wZW5Pbl09XCInY2xpY2snXCJcbiAgW3RhcmdldF09XCJnZXRIb3N0RWxlbWVudCgpXCJcbiAgW29mZnNldFldPVwiaXNSb290ID8gOCA6IDBcIlxuICBbb2Zmc2V0WF09XCJpc1Jvb3QgPyAwIDogNFwiXG4gIFtwbGFjZW1lbnRdPVwiZ2V0UGxhY2VtZW50KClcIlxuICAob25PcGVuZWQpPVwiX2hhbmRsZU9uT3BlbmVkKClcIlxuICAob25DbG9zZWQpPVwiX2hhbmRsZU9uQ2xvc2VkKClcIlxuPlxuICA8ZGl2IGNsYXNzPVwiYXgtbWVudS1pdGVtLWNoaWxkcmVuIGF4LXBhcmVudC17eyB0aGlzLnJvb3RNZW51Lm9yaWF0YXRpb24gfX1cIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1tZW51LWl0ZW1cIj48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuPC9heC1wb3BvdmVyPlxuIl19