@acorex/components 18.16.0-next.0 → 18.16.0-next.1
Sign up to get free protection for your applications and to get access to all the features.
- package/audio-wave/lib/audio-wave.component.d.ts +1 -0
- package/comment/lib/comment-container/comment-container.component.d.ts +1 -0
- package/common/lib/components/value-component.class.d.ts +1 -0
- package/common/lib/directives/auto-focus.directive.d.ts +1 -0
- package/common/lib/directives/inverted-color.directive.d.ts +1 -0
- package/common/lib/directives/ripple.directive.d.ts +1 -0
- package/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.d.ts +1 -0
- package/data-table/lib/columns/data-table-column-resizable.directive.d.ts +1 -0
- package/data-table/lib/data-table/data-table.component.d.ts +1 -0
- package/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts +1 -0
- package/drawer/lib/drawer/drawer-item/drawer.component.d.ts +1 -0
- package/esm2022/audio-wave/lib/audio-wave.component.mjs +18 -14
- package/esm2022/button/lib/button-item-list.component.mjs +2 -2
- package/esm2022/calendar/lib/calendar.component.mjs +17 -14
- package/esm2022/comment/lib/comment-container/comment-container.component.mjs +18 -15
- package/esm2022/common/lib/components/value-component.class.mjs +5 -4
- package/esm2022/common/lib/directives/auto-focus.directive.mjs +8 -5
- package/esm2022/common/lib/directives/inverted-color.directive.mjs +23 -19
- package/esm2022/common/lib/directives/ripple.directive.mjs +18 -15
- package/esm2022/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.mjs +13 -9
- package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +19 -5
- package/esm2022/data-pager/lib/data-pager.component.mjs +3 -3
- package/esm2022/data-table/lib/columns/data-table-column-resizable.directive.mjs +13 -13
- package/esm2022/data-table/lib/data-table/data-table.component.mjs +14 -9
- package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +13 -10
- package/esm2022/drawer/lib/drawer/drawer-item/drawer.component.mjs +5 -4
- package/esm2022/list/lib/list.component.mjs +14 -9
- package/esm2022/menu/lib/context-menu.component.mjs +40 -32
- package/esm2022/password-box/lib/password-box.component.mjs +3 -11
- package/esm2022/password-box/lib/password-strength-validation/password-strength-validation.component.mjs +12 -4
- package/esm2022/picker/lib/picker.component.mjs +11 -4
- package/esm2022/popover/lib/popover.component.mjs +7 -6
- package/esm2022/range-slider/lib/range-slider.component.mjs +15 -9
- package/esm2022/rate-picker/lib/rate-picker.component.mjs +8 -2
- package/esm2022/select-box/lib/select-box.component.mjs +2 -5
- package/esm2022/tree-view/acorex-components-tree-view.mjs +5 -0
- package/esm2022/tree-view/index.mjs +4 -0
- package/esm2022/tree-view/lib/tree-view-item.component.mjs +86 -0
- package/esm2022/tree-view/lib/tree-view.class.mjs +4 -0
- package/esm2022/tree-view/lib/tree-view.component.mjs +299 -0
- package/esm2022/tree-view/lib/tree-view.component.module.mjs +50 -0
- package/esm2022/uploader/lib/uploader-zone.directive.mjs +21 -16
- package/fesm2022/acorex-components-audio-wave.mjs +18 -15
- package/fesm2022/acorex-components-audio-wave.mjs.map +1 -1
- package/fesm2022/acorex-components-button.mjs +2 -2
- package/fesm2022/acorex-components-button.mjs.map +1 -1
- package/fesm2022/acorex-components-calendar.mjs +16 -14
- package/fesm2022/acorex-components-calendar.mjs.map +1 -1
- package/fesm2022/acorex-components-comment.mjs +17 -14
- package/fesm2022/acorex-components-comment.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +44 -34
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-conversation.mjs +12 -9
- package/fesm2022/acorex-components-conversation.mjs.map +1 -1
- package/fesm2022/acorex-components-data-pager.mjs +20 -6
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +33 -25
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-drawer.mjs +4 -3
- package/fesm2022/acorex-components-drawer.mjs.map +1 -1
- package/fesm2022/acorex-components-list.mjs +14 -10
- package/fesm2022/acorex-components-list.mjs.map +1 -1
- package/fesm2022/acorex-components-menu.mjs +39 -31
- package/fesm2022/acorex-components-menu.mjs.map +1 -1
- package/fesm2022/acorex-components-password-box.mjs +12 -12
- package/fesm2022/acorex-components-password-box.mjs.map +1 -1
- package/fesm2022/acorex-components-picker.mjs +10 -4
- package/fesm2022/acorex-components-picker.mjs.map +1 -1
- package/fesm2022/acorex-components-popover.mjs +6 -5
- package/fesm2022/acorex-components-popover.mjs.map +1 -1
- package/fesm2022/acorex-components-range-slider.mjs +14 -8
- package/fesm2022/acorex-components-range-slider.mjs.map +1 -1
- package/fesm2022/acorex-components-rate-picker.mjs +7 -1
- package/fesm2022/acorex-components-rate-picker.mjs.map +1 -1
- package/fesm2022/acorex-components-select-box.mjs +1 -4
- package/fesm2022/acorex-components-select-box.mjs.map +1 -1
- package/fesm2022/acorex-components-tree-view.mjs +433 -0
- package/fesm2022/acorex-components-tree-view.mjs.map +1 -0
- package/fesm2022/acorex-components-uploader.mjs +20 -15
- package/fesm2022/acorex-components-uploader.mjs.map +1 -1
- package/menu/lib/context-menu.component.d.ts +1 -0
- package/package.json +7 -1
- package/password-box/lib/password-box.component.d.ts +1 -9
- package/password-box/lib/password-strength-validation/password-strength-validation.component.d.ts +9 -1
- package/picker/lib/picker.component.d.ts +1 -0
- package/popover/lib/popover.component.d.ts +1 -0
- package/rate-picker/lib/rate-picker.component.d.ts +1 -0
- package/tree-view/README.md +3 -0
- package/tree-view/index.d.ts +3 -0
- package/tree-view/lib/tree-view-item.component.d.ts +23 -0
- package/tree-view/lib/tree-view.class.d.ts +20 -0
- package/tree-view/lib/tree-view.component.d.ts +80 -0
- package/tree-view/lib/tree-view.component.module.d.ts +16 -0
- package/uploader/lib/uploader-zone.directive.d.ts +1 -0
@@ -0,0 +1,299 @@
|
|
1
|
+
import { NXComponent } from '@acorex/components/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, effect, input, output, signal, ViewEncapsulation, } from '@angular/core';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/common";
|
5
|
+
import * as i2 from "@acorex/components/decorators";
|
6
|
+
import * as i3 from "@acorex/components/check-box";
|
7
|
+
import * as i4 from "@angular/forms";
|
8
|
+
import * as i5 from "./tree-view-item.component";
|
9
|
+
export class AXTreeViewComponent extends NXComponent {
|
10
|
+
constructor() {
|
11
|
+
super();
|
12
|
+
this.itemsSignal = signal([]);
|
13
|
+
this.#effect = effect(() => {
|
14
|
+
const itemsInput = this.items();
|
15
|
+
if (typeof itemsInput === 'function') {
|
16
|
+
const result = itemsInput();
|
17
|
+
if (result instanceof Promise) {
|
18
|
+
this.itemsPromise = (options) => itemsInput(options);
|
19
|
+
this.fetchData();
|
20
|
+
}
|
21
|
+
else {
|
22
|
+
this.itemsSignal.set(result);
|
23
|
+
this.itemsPromise = null;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
else {
|
27
|
+
this.itemsSignal.set(itemsInput);
|
28
|
+
this.itemsPromise = null;
|
29
|
+
}
|
30
|
+
}, { allowSignalWrites: true });
|
31
|
+
this.items = input();
|
32
|
+
this.selectable = input(true);
|
33
|
+
this.selectionMode = input('single');
|
34
|
+
this.selectionBehavior = input(null);
|
35
|
+
this.showActiveNode = signal(true);
|
36
|
+
this.valueField = input('id');
|
37
|
+
this.textField = input('text');
|
38
|
+
this.visibleField = input('visible');
|
39
|
+
this.disableField = input('disabled');
|
40
|
+
this.hasChildField = input();
|
41
|
+
this.iconField = input('icon');
|
42
|
+
this.onSelectionChange = output();
|
43
|
+
this.onItemClick = output();
|
44
|
+
this.onNodeClick = output();
|
45
|
+
this.loadingState = signal({});
|
46
|
+
}
|
47
|
+
#effect;
|
48
|
+
get resolvedItems() {
|
49
|
+
return this.itemsSignal();
|
50
|
+
}
|
51
|
+
handleNodeSelectionClick(event, item) {
|
52
|
+
if (item[this.disableField()] || this.isNodeLoading(item.id)) {
|
53
|
+
return;
|
54
|
+
}
|
55
|
+
if (this.selectionMode() === 'single' && event.isUserInteraction) {
|
56
|
+
this.handleUnSelectNode(this.itemsSignal());
|
57
|
+
}
|
58
|
+
item.selected = event.value;
|
59
|
+
if (event.value != null) {
|
60
|
+
switch (this.selectionBehavior()) {
|
61
|
+
case 'autoExpand':
|
62
|
+
if (event.value) {
|
63
|
+
if (this.itemsPromise && item[this.hasChildField()] && !item?.childrens?.length) {
|
64
|
+
this.fetchData(item.id);
|
65
|
+
this.setNodeLoading(item.id, true);
|
66
|
+
}
|
67
|
+
this.toggleExpand(item);
|
68
|
+
}
|
69
|
+
break;
|
70
|
+
case 'expandAndSelectAllOrUnSelect':
|
71
|
+
if (this.itemsPromise) {
|
72
|
+
console.error('This mode only available client Side');
|
73
|
+
return;
|
74
|
+
}
|
75
|
+
this.expandAndToggleSelection(item, event.value);
|
76
|
+
break;
|
77
|
+
case 'indeterminate':
|
78
|
+
if (item?.childrens?.length) {
|
79
|
+
this.applySelectionToChildren(item, event.value, item[this.valueField()]);
|
80
|
+
}
|
81
|
+
this.updateParentSelection(item, event.value);
|
82
|
+
break;
|
83
|
+
default:
|
84
|
+
break;
|
85
|
+
}
|
86
|
+
}
|
87
|
+
if (event.isUserInteraction) {
|
88
|
+
const result = this.findSelectedNodes(this.itemsSignal());
|
89
|
+
this.onSelectionChange.emit({
|
90
|
+
component: this,
|
91
|
+
data: result,
|
92
|
+
nativeElement: this.nativeElement,
|
93
|
+
});
|
94
|
+
this.onItemClick.emit({ component: this, data: item, nativeElement: this.nativeElement });
|
95
|
+
}
|
96
|
+
}
|
97
|
+
/**
|
98
|
+
*
|
99
|
+
* auto expand
|
100
|
+
*
|
101
|
+
*/
|
102
|
+
toggleExpand(item) {
|
103
|
+
if (!item.isExpanded) {
|
104
|
+
item.isExpanded = true;
|
105
|
+
}
|
106
|
+
}
|
107
|
+
/**
|
108
|
+
*
|
109
|
+
* expand and change value parent change
|
110
|
+
*
|
111
|
+
*/
|
112
|
+
expandAndToggleSelection(item, selected) {
|
113
|
+
this.toggleExpand(item);
|
114
|
+
if (item.childrens?.length) {
|
115
|
+
this.applySelectionToChildren(item, selected, item[this.valueField()]);
|
116
|
+
}
|
117
|
+
}
|
118
|
+
applySelectionToChildren(item, isSelected, parentId) {
|
119
|
+
item.childrens.forEach((child) => {
|
120
|
+
child.parentId = parentId;
|
121
|
+
child.selected = isSelected;
|
122
|
+
if (child.childrens?.length) {
|
123
|
+
this.applySelectionToChildren(child, isSelected, child.id);
|
124
|
+
}
|
125
|
+
});
|
126
|
+
}
|
127
|
+
/**
|
128
|
+
*
|
129
|
+
* indeterminate logic
|
130
|
+
*
|
131
|
+
*/
|
132
|
+
updateParentSelection(item, selected) {
|
133
|
+
item.selected = selected;
|
134
|
+
let parent = this.findParent(item, this.itemsSignal());
|
135
|
+
while ((parent && parent.selected != false) || (parent && item.selected)) {
|
136
|
+
const allSelected = parent?.childrens?.every((child) => child.selected);
|
137
|
+
const someSelected = parent?.childrens?.some((child) => child.selected || child.indeterminate);
|
138
|
+
if (!allSelected && !someSelected) {
|
139
|
+
parent.selected = false;
|
140
|
+
parent.indeterminate = null;
|
141
|
+
}
|
142
|
+
else if (!allSelected) {
|
143
|
+
parent.indeterminate = true;
|
144
|
+
parent.selected = null;
|
145
|
+
}
|
146
|
+
else if (allSelected) {
|
147
|
+
parent.selected = true;
|
148
|
+
parent.indeterminate = false;
|
149
|
+
}
|
150
|
+
else {
|
151
|
+
parent.indeterminate = false;
|
152
|
+
parent.selected = true;
|
153
|
+
}
|
154
|
+
parent = this.findParent(parent, this.itemsSignal());
|
155
|
+
}
|
156
|
+
}
|
157
|
+
findParent(item, nodes) {
|
158
|
+
for (let node of nodes) {
|
159
|
+
if (node.childrens?.includes(item)) {
|
160
|
+
return node;
|
161
|
+
}
|
162
|
+
else if (node.childrens) {
|
163
|
+
const parent = this.findParent(item, node.childrens);
|
164
|
+
if (parent)
|
165
|
+
return parent;
|
166
|
+
}
|
167
|
+
}
|
168
|
+
return null;
|
169
|
+
}
|
170
|
+
/**
|
171
|
+
*
|
172
|
+
* find node selected true for emit Selections
|
173
|
+
*
|
174
|
+
*/
|
175
|
+
findSelectedNodes(nodes) {
|
176
|
+
let selectedNodes = [];
|
177
|
+
nodes.forEach((node) => {
|
178
|
+
if (node.selected) {
|
179
|
+
selectedNodes.push(node);
|
180
|
+
}
|
181
|
+
if (node.childrens) {
|
182
|
+
selectedNodes = selectedNodes.concat(this.findSelectedNodes(node.childrens));
|
183
|
+
}
|
184
|
+
});
|
185
|
+
return selectedNodes;
|
186
|
+
}
|
187
|
+
/**
|
188
|
+
*
|
189
|
+
* find for emit Selections single mode
|
190
|
+
*
|
191
|
+
*/
|
192
|
+
handleUnSelectNode(items) {
|
193
|
+
items.forEach((child) => {
|
194
|
+
child.selected = false;
|
195
|
+
if (child?.childrens?.length) {
|
196
|
+
this.handleUnSelectNode(child.childrens);
|
197
|
+
}
|
198
|
+
});
|
199
|
+
}
|
200
|
+
/**
|
201
|
+
*
|
202
|
+
* lazy load logic
|
203
|
+
*
|
204
|
+
*/
|
205
|
+
fetchData(parentId) {
|
206
|
+
this.itemsPromise({ parentId })
|
207
|
+
.then((data) => {
|
208
|
+
if (Array.isArray(data)) {
|
209
|
+
if (parentId) {
|
210
|
+
this.findNode(parentId, data, this.itemsSignal());
|
211
|
+
}
|
212
|
+
else {
|
213
|
+
this.itemsSignal.set(data);
|
214
|
+
}
|
215
|
+
}
|
216
|
+
})
|
217
|
+
.finally(() => {
|
218
|
+
this.setNodeLoading(parentId, false);
|
219
|
+
});
|
220
|
+
}
|
221
|
+
findNode(parentId, _children, source) {
|
222
|
+
if (source.length) {
|
223
|
+
source.forEach((element) => {
|
224
|
+
if (element[this.valueField()] == parentId) {
|
225
|
+
element.childrens = _children;
|
226
|
+
}
|
227
|
+
else {
|
228
|
+
if (element?.childrens)
|
229
|
+
this.findNode(parentId, _children, element.childrens);
|
230
|
+
}
|
231
|
+
});
|
232
|
+
}
|
233
|
+
}
|
234
|
+
/**
|
235
|
+
*
|
236
|
+
* emit when arrow click
|
237
|
+
*
|
238
|
+
*/
|
239
|
+
handleNodeExpandClick(node) {
|
240
|
+
const parentId = node.data.id;
|
241
|
+
if (this.itemsPromise && node.data.isExpanded && !node?.data.childrens?.length) {
|
242
|
+
this.fetchData(parentId);
|
243
|
+
this.setNodeLoading(node.data.id, true);
|
244
|
+
}
|
245
|
+
this.onItemClick.emit({ component: this, data: node.data, nativeElement: this.nativeElement });
|
246
|
+
}
|
247
|
+
handleNodeClick(node) {
|
248
|
+
if (node.data[this.disableField()]) {
|
249
|
+
return;
|
250
|
+
}
|
251
|
+
if (this.showActiveNode()) {
|
252
|
+
this.handleUnActiveNode(this.itemsSignal());
|
253
|
+
node.data.active = true;
|
254
|
+
}
|
255
|
+
///to do
|
256
|
+
// switch (this.selectionBehavior()) {
|
257
|
+
// case 'activeAndSelect':
|
258
|
+
// if (this.selectionMode() === 'single') {
|
259
|
+
// this.handleUnselectNode(this.itemsSignal());
|
260
|
+
// }
|
261
|
+
// node.selected = true;
|
262
|
+
// break;
|
263
|
+
// default:
|
264
|
+
// break;
|
265
|
+
// }
|
266
|
+
this.onNodeClick.emit({ component: this, data: node.data, nativeElement: this.nativeElement });
|
267
|
+
}
|
268
|
+
handleUnActiveNode(unActiveSource) {
|
269
|
+
unActiveSource.forEach((child) => {
|
270
|
+
child.active = false;
|
271
|
+
if (child?.childrens?.length) {
|
272
|
+
this.handleUnActiveNode(child.childrens);
|
273
|
+
}
|
274
|
+
});
|
275
|
+
}
|
276
|
+
handleNodeDbClick(node) {
|
277
|
+
if (this.itemsPromise) {
|
278
|
+
const nodeParentId = node.data.id;
|
279
|
+
this.fetchData(nodeParentId);
|
280
|
+
this.setNodeLoading(node.data.id, true);
|
281
|
+
}
|
282
|
+
}
|
283
|
+
isNodeLoading(nodeId) {
|
284
|
+
return this.loadingState()[nodeId] || false;
|
285
|
+
}
|
286
|
+
setNodeLoading(nodeId, isLoading) {
|
287
|
+
this.loadingState.update((state) => ({
|
288
|
+
...state,
|
289
|
+
[nodeId]: isLoading,
|
290
|
+
}));
|
291
|
+
}
|
292
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
293
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXTreeViewComponent, selector: "ax-tree-view", inputs: { items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, selectable: { classPropertyName: "selectable", publicName: "selectable", isSignal: true, isRequired: false, transformFunction: null }, selectionMode: { classPropertyName: "selectionMode", publicName: "selectionMode", isSignal: true, isRequired: false, transformFunction: null }, selectionBehavior: { classPropertyName: "selectionBehavior", publicName: "selectionBehavior", isSignal: true, isRequired: false, transformFunction: null }, valueField: { classPropertyName: "valueField", publicName: "valueField", isSignal: true, isRequired: false, transformFunction: null }, textField: { classPropertyName: "textField", publicName: "textField", isSignal: true, isRequired: false, transformFunction: null }, visibleField: { classPropertyName: "visibleField", publicName: "visibleField", isSignal: true, isRequired: false, transformFunction: null }, disableField: { classPropertyName: "disableField", publicName: "disableField", isSignal: true, isRequired: false, transformFunction: null }, hasChildField: { classPropertyName: "hasChildField", publicName: "hasChildField", isSignal: true, isRequired: false, transformFunction: null }, iconField: { classPropertyName: "iconField", publicName: "iconField", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onSelectionChange: "onSelectionChange", onItemClick: "onItemClick", onNodeClick: "onNodeClick" }, usesInheritance: true, ngImport: i0, template: "@for (node of resolvedItems; track $index) {\n <ng-container [ngTemplateOutlet]=\"Recursion\" [ngTemplateOutletContext]=\"{ $implicit: node }\"></ng-container>\n}\n\n<ng-template #Recursion let-item>\n @if (item[visibleField()] !== false) {\n <ax-tree-view-item\n [item]=\"item\"\n [(isExpanded)]=\"item.isExpanded\"\n [(isActive)]=\"item.active\"\n [isLoading]=\"isNodeLoading(item.id)\"\n [disableField]=\"disableField()\"\n [hasChildField]=\"hasChildField()\"\n (onNodeExpand)=\"handleNodeExpandClick($event)\"\n (onNodeClick)=\"handleNodeClick($event)\"\n (onNodeDbClick)=\"handleNodeDbClick($event)\"\n >\n @if (this.selectable()) {\n <ax-check-box\n [disabled]=\"item[disableField()]\"\n [indeterminate]=\"item.indeterminate\"\n [(ngModel)]=\"item.selected\"\n (onValueChanged)=\"handleNodeSelectionClick($event, item)\"\n ></ax-check-box>\n }\n <ax-prefix>\n @if (item[iconField()]) {\n <ax-icon [icon]=\"item[iconField()]\"></ax-icon>\n } @else {\n <i></i>\n }\n </ax-prefix>\n @if (item[textField()]) {\n <ax-text>{{ item[textField()] }}</ax-text>\n }\n\n <ax-suffix></ax-suffix>\n @for (child of item?.childrens; track $index) {\n <ng-container\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"\n ></ng-container>\n }\n </ax-tree-view-item>\n }\n</ng-template>\n", styles: ["ax-tree-view ax-tree-view-item .ax-tree-view-container{display:flex;align-items:center;margin-bottom:.125rem;cursor:pointer}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-checkbox-end-side{display:none!important}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-arrow{font-size:.875rem!important}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items{display:flex;align-items:center;gap:.5rem}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix{display:flex;align-items:center;gap:.5rem;padding:.375rem;padding-inline-end:.5rem!important;border-radius:.25rem}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.noselect-tree-view{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.ax-state-tree-view-active{background-color:rgba(var(--ax-color-primary-500));color:#fff}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.ax-state-tree-view-active:hover{background-color:rgba(var(--ax-color-primary-500))}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix:hover{background-color:rgba(var(--ax-color-on-surface))}ax-tree-view ax-tree-view-item .ax-state-tree-view-rtl{padding-inline-end:.5rem}ax-tree-view ax-tree-view-item .ax-state-tree-view-ltr{padding-inline-start:.5rem}ax-tree-view ax-tree-view-item .ax-state-disabled{cursor:not-allowed!important;opacity:.5!important}ax-tree-view ax-tree-view-item .arrow-container{position:relative;display:flex;align-items:center}ax-tree-view ax-tree-view-item .vertical-line{width:.125rem;height:100%;background-color:#ccc;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "component", type: i3.AXCheckBoxComponent, selector: "ax-check-box", inputs: ["disabled", "tabIndex", "readonly", "color", "value", "name", "id", "checked", "indeterminate"], outputs: ["onBlur", "onFocus", "valueChange", "onValueChanged"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.AXTreeViewItemComponent, selector: "ax-tree-view-item", inputs: ["item", "isExpanded", "hasChildField", "isActive", "isLoading", "disableField"], outputs: ["onNodeExpand", "onNodeClick", "isExpandedChange", "isActiveChange", "onNodeDbClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
294
|
+
}
|
295
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewComponent, decorators: [{
|
296
|
+
type: Component,
|
297
|
+
args: [{ selector: 'ax-tree-view', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "@for (node of resolvedItems; track $index) {\n <ng-container [ngTemplateOutlet]=\"Recursion\" [ngTemplateOutletContext]=\"{ $implicit: node }\"></ng-container>\n}\n\n<ng-template #Recursion let-item>\n @if (item[visibleField()] !== false) {\n <ax-tree-view-item\n [item]=\"item\"\n [(isExpanded)]=\"item.isExpanded\"\n [(isActive)]=\"item.active\"\n [isLoading]=\"isNodeLoading(item.id)\"\n [disableField]=\"disableField()\"\n [hasChildField]=\"hasChildField()\"\n (onNodeExpand)=\"handleNodeExpandClick($event)\"\n (onNodeClick)=\"handleNodeClick($event)\"\n (onNodeDbClick)=\"handleNodeDbClick($event)\"\n >\n @if (this.selectable()) {\n <ax-check-box\n [disabled]=\"item[disableField()]\"\n [indeterminate]=\"item.indeterminate\"\n [(ngModel)]=\"item.selected\"\n (onValueChanged)=\"handleNodeSelectionClick($event, item)\"\n ></ax-check-box>\n }\n <ax-prefix>\n @if (item[iconField()]) {\n <ax-icon [icon]=\"item[iconField()]\"></ax-icon>\n } @else {\n <i></i>\n }\n </ax-prefix>\n @if (item[textField()]) {\n <ax-text>{{ item[textField()] }}</ax-text>\n }\n\n <ax-suffix></ax-suffix>\n @for (child of item?.childrens; track $index) {\n <ng-container\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"\n ></ng-container>\n }\n </ax-tree-view-item>\n }\n</ng-template>\n", styles: ["ax-tree-view ax-tree-view-item .ax-tree-view-container{display:flex;align-items:center;margin-bottom:.125rem;cursor:pointer}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-checkbox-end-side{display:none!important}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-arrow{font-size:.875rem!important}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items{display:flex;align-items:center;gap:.5rem}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix{display:flex;align-items:center;gap:.5rem;padding:.375rem;padding-inline-end:.5rem!important;border-radius:.25rem}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.noselect-tree-view{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.ax-state-tree-view-active{background-color:rgba(var(--ax-color-primary-500));color:#fff}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix.ax-state-tree-view-active:hover{background-color:rgba(var(--ax-color-primary-500))}ax-tree-view ax-tree-view-item .ax-tree-view-container .ax-tree-view-items .ax-tree-view-items-prefix:hover{background-color:rgba(var(--ax-color-on-surface))}ax-tree-view ax-tree-view-item .ax-state-tree-view-rtl{padding-inline-end:.5rem}ax-tree-view ax-tree-view-item .ax-state-tree-view-ltr{padding-inline-start:.5rem}ax-tree-view ax-tree-view-item .ax-state-disabled{cursor:not-allowed!important;opacity:.5!important}ax-tree-view ax-tree-view-item .arrow-container{position:relative;display:flex;align-items:center}ax-tree-view ax-tree-view-item .vertical-line{width:.125rem;height:100%;background-color:#ccc;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}\n"] }]
|
298
|
+
}], ctorParameters: () => [] });
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-view.component.js","sourceRoot":"","sources":["../../../../../../libs/components/tree-view/src/lib/tree-view.component.ts","../../../../../../libs/components/tree-view/src/lib/tree-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXValueChangedEvent, NXComponent } from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  effect,\n  input,\n  output,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXTreeItemClickBaseEvent, AXTreeViewSchema, SelectionBehaviorType } from './tree-view.class';\n\n@Component({\n  selector: 'ax-tree-view',\n  templateUrl: 'tree-view.component.html',\n  styleUrls: ['tree-view.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXTreeViewComponent extends NXComponent {\n  constructor() {\n    super();\n  }\n\n  private itemsSignal = signal<AXTreeViewSchema[]>([]);\n\n  private itemsPromise: any;\n\n  #effect = effect(\n    () => {\n      const itemsInput = this.items();\n\n      if (typeof itemsInput === 'function') {\n        const result = itemsInput();\n        if (result instanceof Promise) {\n          this.itemsPromise = (options) => itemsInput(options);\n          this.fetchData();\n        } else {\n          this.itemsSignal.set(result);\n          this.itemsPromise = null;\n        }\n      } else {\n        this.itemsSignal.set(itemsInput);\n        this.itemsPromise = null;\n      }\n    },\n    { allowSignalWrites: true },\n  );\n\n  items = input<\n    | AXTreeViewSchema[]\n    | ((options?: { parentId: string | number }) => AXTreeViewSchema[] | Promise<AXTreeViewSchema[]>)\n  >();\n\n  protected get resolvedItems() {\n    return this.itemsSignal();\n  }\n\n  selectable = input<boolean>(true);\n\n  selectionMode = input<'single' | 'multiple'>('single');\n\n  selectionBehavior = input<SelectionBehaviorType>(null);\n\n  showActiveNode = signal<boolean>(true);\n\n  valueField = input<string>('id');\n\n  textField = input<string>('text');\n\n  visibleField = input<string>('visible');\n\n  disableField = input<string>('disabled');\n\n  hasChildField = input<string>();\n\n  iconField = input<string>('icon');\n\n  onSelectionChange = output<AXTreeItemClickBaseEvent>();\n\n  onItemClick = output<AXTreeItemClickBaseEvent>();\n\n  onNodeClick = output<AXTreeItemClickBaseEvent>();\n\n  protected handleNodeSelectionClick(event: AXValueChangedEvent, item: AXTreeViewSchema) {\n    if (item[this.disableField()] || this.isNodeLoading(item.id)) {\n      return;\n    }\n\n    if (this.selectionMode() === 'single' && event.isUserInteraction) {\n      this.handleUnSelectNode(this.itemsSignal());\n    }\n    item.selected = event.value;\n\n    if (event.value != null) {\n      switch (this.selectionBehavior()) {\n        case 'autoExpand':\n          if (event.value) {\n            if (this.itemsPromise && item[this.hasChildField()] && !item?.childrens?.length) {\n              this.fetchData(item.id);\n              this.setNodeLoading(item.id, true);\n            }\n\n            this.toggleExpand(item);\n          }\n          break;\n        case 'expandAndSelectAllOrUnSelect':\n          if (this.itemsPromise) {\n            console.error('This mode only available client Side');\n            return;\n          }\n          this.expandAndToggleSelection(item, event.value);\n          break;\n        case 'indeterminate':\n          if (item?.childrens?.length) {\n            this.applySelectionToChildren(item, event.value, item[this.valueField()]);\n          }\n          this.updateParentSelection(item, event.value);\n          break;\n        default:\n          break;\n      }\n    }\n\n    if (event.isUserInteraction) {\n      const result: AXTreeViewSchema[] = this.findSelectedNodes(this.itemsSignal());\n\n      this.onSelectionChange.emit({\n        component: this,\n        data: result,\n        nativeElement: this.nativeElement,\n      });\n\n      this.onItemClick.emit({ component: this, data: item, nativeElement: this.nativeElement });\n    }\n  }\n\n  /**\n   *\n   * auto expand\n   *\n   */\n  private toggleExpand(item: AXTreeViewSchema) {\n    if (!item.isExpanded) {\n      item.isExpanded = true;\n    }\n  }\n\n  /**\n   *\n   * expand and change value parent change\n   *\n   */\n\n  private expandAndToggleSelection(item: AXTreeViewSchema, selected: boolean) {\n    this.toggleExpand(item);\n\n    if (item.childrens?.length) {\n      this.applySelectionToChildren(item, selected, item[this.valueField()]);\n    }\n  }\n\n  private applySelectionToChildren(item: AXTreeViewSchema, isSelected: boolean, parentId?: number | string) {\n    item.childrens.forEach((child) => {\n      child.parentId = parentId;\n      child.selected = isSelected;\n      if (child.childrens?.length) {\n        this.applySelectionToChildren(child, isSelected, child.id);\n      }\n    });\n  }\n\n  /**\n   *\n   * indeterminate logic\n   *\n   */\n\n  private updateParentSelection(item: AXTreeViewSchema, selected: boolean) {\n    item.selected = selected;\n\n    let parent = this.findParent(item, this.itemsSignal());\n\n    while ((parent && parent.selected != false) || (parent && item.selected)) {\n      const allSelected = parent?.childrens?.every((child) => child.selected);\n\n      const someSelected = parent?.childrens?.some((child) => child.selected || child.indeterminate);\n\n      if (!allSelected && !someSelected) {\n        parent.selected = false;\n        parent.indeterminate = null;\n      } else if (!allSelected) {\n        parent.indeterminate = true;\n        parent.selected = null;\n      } else if (allSelected) {\n        parent.selected = true;\n        parent.indeterminate = false;\n      } else {\n        parent.indeterminate = false;\n        parent.selected = true;\n      }\n\n      parent = this.findParent(parent, this.itemsSignal());\n    }\n  }\n\n  private findParent(item: AXTreeViewSchema, nodes: AXTreeViewSchema[]): AXTreeViewSchema | null {\n    for (let node of nodes) {\n      if (node.childrens?.includes(item)) {\n        return node;\n      } else if (node.childrens) {\n        const parent = this.findParent(item, node.childrens);\n        if (parent) return parent;\n      }\n    }\n    return null;\n  }\n\n  /**\n   *\n   * find node selected true for emit Selections\n   *\n   */\n\n  private findSelectedNodes(nodes: AXTreeViewSchema[]): AXTreeViewSchema[] {\n    let selectedNodes: AXTreeViewSchema[] = [];\n\n    nodes.forEach((node) => {\n      if (node.selected) {\n        selectedNodes.push(node);\n      }\n\n      if (node.childrens) {\n        selectedNodes = selectedNodes.concat(this.findSelectedNodes(node.childrens));\n      }\n    });\n\n    return selectedNodes;\n  }\n\n  /**\n   *\n   * find for emit Selections single mode\n   *\n   */\n\n  private handleUnSelectNode(items: AXTreeViewSchema[]) {\n    items.forEach((child) => {\n      child.selected = false;\n      if (child?.childrens?.length) {\n        this.handleUnSelectNode(child.childrens);\n      }\n    });\n  }\n\n  /**\n   *\n   * lazy load logic\n   *\n   */\n\n  private fetchData(parentId?: number | string) {\n    this.itemsPromise({ parentId })\n      .then((data: AXTreeViewSchema[]) => {\n        if (Array.isArray(data)) {\n          if (parentId) {\n            this.findNode(parentId, data, this.itemsSignal());\n          } else {\n            this.itemsSignal.set(data);\n          }\n        }\n      })\n      .finally(() => {\n        this.setNodeLoading(parentId, false);\n      });\n  }\n\n  private findNode(parentId: number | string, _children: AXTreeViewSchema[], source: AXTreeViewSchema[]) {\n    if (source.length) {\n      source.forEach((element) => {\n        if (element[this.valueField()] == parentId) {\n          element.childrens = _children;\n        } else {\n          if (element?.childrens) this.findNode(parentId, _children, element.childrens);\n        }\n      });\n    }\n  }\n\n  /**\n   *\n   * emit when arrow click\n   *\n   */\n\n  protected handleNodeExpandClick(node: AXTreeItemClickBaseEvent) {\n    const parentId = node.data.id;\n    if (this.itemsPromise && node.data.isExpanded && !node?.data.childrens?.length) {\n      this.fetchData(parentId);\n      this.setNodeLoading(node.data.id, true);\n    }\n    this.onItemClick.emit({ component: this, data: node.data, nativeElement: this.nativeElement });\n  }\n\n  protected handleNodeClick(node: AXTreeItemClickBaseEvent) {\n    if (node.data[this.disableField()]) {\n      return;\n    }\n    if (this.showActiveNode()) {\n      this.handleUnActiveNode(this.itemsSignal());\n      node.data.active = true;\n    }\n    ///to do\n    // switch (this.selectionBehavior()) {\n    //   case 'activeAndSelect':\n    //     if (this.selectionMode() === 'single') {\n    //       this.handleUnselectNode(this.itemsSignal());\n    //     }\n    //     node.selected = true;\n\n    //     break;\n\n    //   default:\n    //     break;\n    // }\n    this.onNodeClick.emit({ component: this, data: node.data, nativeElement: this.nativeElement });\n  }\n\n  private handleUnActiveNode(unActiveSource: AXTreeViewSchema[]) {\n    unActiveSource.forEach((child) => {\n      child.active = false;\n      if (child?.childrens?.length) {\n        this.handleUnActiveNode(child.childrens);\n      }\n    });\n  }\n\n  protected handleNodeDbClick(node: AXTreeItemClickBaseEvent) {\n    if (this.itemsPromise) {\n      const nodeParentId = node.data.id;\n      this.fetchData(nodeParentId);\n      this.setNodeLoading(node.data.id, true);\n    }\n  }\n\n  private loadingState = signal<Record<string | number, boolean>>({});\n\n  isNodeLoading(nodeId: string | number): boolean {\n    return this.loadingState()[nodeId] || false;\n  }\n\n  setNodeLoading(nodeId: string | number, isLoading: boolean): void {\n    this.loadingState.update((state) => ({\n      ...state,\n      [nodeId]: isLoading,\n    }));\n  }\n}\n","@for (node of resolvedItems; track $index) {\n  <ng-container [ngTemplateOutlet]=\"Recursion\" [ngTemplateOutletContext]=\"{ $implicit: node }\"></ng-container>\n}\n\n<ng-template #Recursion let-item>\n  @if (item[visibleField()] !== false) {\n    <ax-tree-view-item\n      [item]=\"item\"\n      [(isExpanded)]=\"item.isExpanded\"\n      [(isActive)]=\"item.active\"\n      [isLoading]=\"isNodeLoading(item.id)\"\n      [disableField]=\"disableField()\"\n      [hasChildField]=\"hasChildField()\"\n      (onNodeExpand)=\"handleNodeExpandClick($event)\"\n      (onNodeClick)=\"handleNodeClick($event)\"\n      (onNodeDbClick)=\"handleNodeDbClick($event)\"\n    >\n      @if (this.selectable()) {\n        <ax-check-box\n          [disabled]=\"item[disableField()]\"\n          [indeterminate]=\"item.indeterminate\"\n          [(ngModel)]=\"item.selected\"\n          (onValueChanged)=\"handleNodeSelectionClick($event, item)\"\n        ></ax-check-box>\n      }\n      <ax-prefix>\n        @if (item[iconField()]) {\n          <ax-icon [icon]=\"item[iconField()]\"></ax-icon>\n        } @else {\n          <i></i>\n        }\n      </ax-prefix>\n      @if (item[textField()]) {\n        <ax-text>{{ item[textField()] }}</ax-text>\n      }\n\n      <ax-suffix></ax-suffix>\n      @for (child of item?.childrens; track $index) {\n        <ng-container\n          [ngTemplateOutlet]=\"Recursion\"\n          [ngTemplateOutletContext]=\"{ $implicit: child }\"\n        ></ng-container>\n      }\n    </ax-tree-view-item>\n  }\n</ng-template>\n"]}
|
@@ -0,0 +1,50 @@
|
|
1
|
+
import { AXCheckBoxModule } from '@acorex/components/check-box';
|
2
|
+
import { AXCommonModule } from '@acorex/components/common';
|
3
|
+
import { AXDecoratorModule } from '@acorex/components/decorators';
|
4
|
+
import { AXFormModule } from '@acorex/components/form';
|
5
|
+
import { AXLoadingModule } from '@acorex/components/loading';
|
6
|
+
import { AXTooltipModule } from '@acorex/components/tooltip';
|
7
|
+
import { CommonModule } from '@angular/common';
|
8
|
+
import { NgModule } from '@angular/core';
|
9
|
+
import { FormsModule } from '@angular/forms';
|
10
|
+
import { AXTreeViewItemComponent } from './tree-view-item.component';
|
11
|
+
import { AXTreeViewComponent } from './tree-view.component';
|
12
|
+
import * as i0 from "@angular/core";
|
13
|
+
export class AXTreeViewModule {
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
15
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewModule, declarations: [AXTreeViewComponent, AXTreeViewItemComponent], imports: [CommonModule,
|
16
|
+
AXCommonModule,
|
17
|
+
AXDecoratorModule,
|
18
|
+
AXCheckBoxModule,
|
19
|
+
AXFormModule,
|
20
|
+
FormsModule,
|
21
|
+
AXTooltipModule,
|
22
|
+
AXLoadingModule], exports: [AXTreeViewComponent, AXTreeViewItemComponent] }); }
|
23
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewModule, imports: [CommonModule,
|
24
|
+
AXCommonModule,
|
25
|
+
AXDecoratorModule,
|
26
|
+
AXCheckBoxModule,
|
27
|
+
AXFormModule,
|
28
|
+
FormsModule,
|
29
|
+
AXTooltipModule,
|
30
|
+
AXLoadingModule] }); }
|
31
|
+
}
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTreeViewModule, decorators: [{
|
33
|
+
type: NgModule,
|
34
|
+
args: [{
|
35
|
+
imports: [
|
36
|
+
CommonModule,
|
37
|
+
AXCommonModule,
|
38
|
+
AXDecoratorModule,
|
39
|
+
AXCheckBoxModule,
|
40
|
+
AXFormModule,
|
41
|
+
FormsModule,
|
42
|
+
AXTooltipModule,
|
43
|
+
AXLoadingModule,
|
44
|
+
],
|
45
|
+
exports: [AXTreeViewComponent, AXTreeViewItemComponent],
|
46
|
+
declarations: [AXTreeViewComponent, AXTreeViewItemComponent],
|
47
|
+
providers: [],
|
48
|
+
}]
|
49
|
+
}] });
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS12aWV3LmNvbXBvbmVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvdHJlZS12aWV3L3NyYy9saWIvdHJlZS12aWV3LmNvbXBvbmVudC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNyRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFnQjVELE1BQU0sT0FBTyxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQUhaLG1CQUFtQixFQUFFLHVCQUF1QixhQVZ6RCxZQUFZO1lBQ1osY0FBYztZQUNkLGlCQUFpQjtZQUNqQixnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsZUFBZSxhQUVQLG1CQUFtQixFQUFFLHVCQUF1QjsrR0FJM0MsZ0JBQWdCLFlBYnpCLFlBQVk7WUFDWixjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixlQUFlOzsyRkFNTixnQkFBZ0I7a0JBZjVCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxpQkFBaUI7d0JBQ2pCLGdCQUFnQjt3QkFDaEIsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsZUFBZTtxQkFDaEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsbUJBQW1CLEVBQUUsdUJBQXVCLENBQUM7b0JBQ3ZELFlBQVksRUFBRSxDQUFDLG1CQUFtQixFQUFFLHVCQUF1QixDQUFDO29CQUM1RCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYQ2hlY2tCb3hNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY2hlY2stYm94JztcbmltcG9ydCB7IEFYQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcbmltcG9ydCB7IEFYRm9ybU1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9mb3JtJztcbmltcG9ydCB7IEFYTG9hZGluZ01vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9sb2FkaW5nJztcbmltcG9ydCB7IEFYVG9vbHRpcE1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy90b29sdGlwJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBBWFRyZWVWaWV3SXRlbUNvbXBvbmVudCB9IGZyb20gJy4vdHJlZS12aWV3LWl0ZW0uY29tcG9uZW50JztcbmltcG9ydCB7IEFYVHJlZVZpZXdDb21wb25lbnQgfSBmcm9tICcuL3RyZWUtdmlldy5jb21wb25lbnQnO1xuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBBWENvbW1vbk1vZHVsZSxcbiAgICBBWERlY29yYXRvck1vZHVsZSxcbiAgICBBWENoZWNrQm94TW9kdWxlLFxuICAgIEFYRm9ybU1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBBWFRvb2x0aXBNb2R1bGUsXG4gICAgQVhMb2FkaW5nTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbQVhUcmVlVmlld0NvbXBvbmVudCwgQVhUcmVlVmlld0l0ZW1Db21wb25lbnRdLFxuICBkZWNsYXJhdGlvbnM6IFtBWFRyZWVWaWV3Q29tcG9uZW50LCBBWFRyZWVWaWV3SXRlbUNvbXBvbmVudF0sXG4gIHByb3ZpZGVyczogW10sXG59KVxuZXhwb3J0IGNsYXNzIEFYVHJlZVZpZXdNb2R1bGUge31cbiJdfQ==
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { AXTranslationService } from '@acorex/core/translation';
|
2
2
|
import { AXUnsubscriber } from '@acorex/core/utils';
|
3
|
-
import { DOCUMENT } from '@angular/common';
|
4
|
-
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostBinding, Input, Output, inject, } from '@angular/core';
|
3
|
+
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
4
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostBinding, Input, Output, PLATFORM_ID, inject, } from '@angular/core';
|
5
5
|
import { AXUploaderService } from './uploader.service';
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
export class AXUploaderZoneDirective {
|
@@ -11,6 +11,7 @@ export class AXUploaderZoneDirective {
|
|
11
11
|
this.accept = null;
|
12
12
|
this.cdr = inject(ChangeDetectorRef);
|
13
13
|
this.document = inject(DOCUMENT);
|
14
|
+
this.platformID = inject(PLATFORM_ID);
|
14
15
|
this.uploadService = inject(AXUploaderService);
|
15
16
|
this.unsubscriber = inject(AXUnsubscriber);
|
16
17
|
this.translateService = inject(AXTranslationService);
|
@@ -63,21 +64,25 @@ export class AXUploaderZoneDirective {
|
|
63
64
|
event.stopImmediatePropagation();
|
64
65
|
}
|
65
66
|
createZone() {
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
67
|
+
if (isPlatformBrowser(this.platformID)) {
|
68
|
+
this.overlayElement = this.document.createElement('div');
|
69
|
+
this.overlayElement.classList.add('ax-uploader-overlay-state', '-ax-z-1');
|
70
|
+
this.overlayElement.id = 'ax-uploader-overlay-state';
|
71
|
+
const icon = this.document.createElement('span');
|
72
|
+
icon.classList.add('ax-icon', 'ax-icon-upload');
|
73
|
+
const text = this.document.createElement('span');
|
74
|
+
text.innerText = this.translateService.translateSync('uploader.zone.text');
|
75
|
+
this.overlayElement.appendChild(icon);
|
76
|
+
this.overlayElement.appendChild(text);
|
77
|
+
this.element.appendChild(this.overlayElement);
|
78
|
+
}
|
76
79
|
}
|
77
80
|
removeZone() {
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
+
if (isPlatformBrowser(this.platformID)) {
|
82
|
+
this.element.removeChild(this.document.getElementById('ax-uploader-overlay-state'));
|
83
|
+
this.overlayElement.remove();
|
84
|
+
//console.log(this.overlayElement);
|
85
|
+
}
|
81
86
|
}
|
82
87
|
async browser() {
|
83
88
|
const requests = await this.uploadService.browse({ accept: this.accept, multiple: this.multiple });
|
@@ -113,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
113
118
|
type: HostBinding,
|
114
119
|
args: ['class']
|
115
120
|
}] } });
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader-zone.directive.js","sourceRoot":"","sources":["../../../../../../libs/components/uploader/src/lib/uploader-zone.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EAEL,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;AAMvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;;AAKvD,MAAM,OAAO,uBAAuB;IA6BlC,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QA3B1C,aAAQ,GAAG,IAAI,CAAC;QAGhB,WAAM,GAAW,IAAI,CAAC;QAEd,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAChC,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE5B,kBAAa,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC1C,iBAAY,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACtC,qBAAgB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAIxD,cAAS,GAAyC,IAAI,YAAY,EAA0B,CAAC;QAG7F,yBAAoB,GAClB,IAAI,YAAY,EAA+B,CAAC;QAGlD,0BAAqB,GACnB,IAAI,YAAY,EAAgC,CAAC;QAEnD,eAAU,GAAG,2BAA2B,CAAC;QAIvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAA4B,CAAC;QAC5D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;QAEzC,EAAE;QACF,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC/F,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAChG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QACH,EAAE;QACF,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAEtE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAClF,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAChF,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAC1E,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;IAC/E,CAAC;IAED,WAAW;QACT,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAEtE,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5E,CAAC;IAEO,eAAe,CAAC,KAAY;QAClC,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;IACnC,CAAC;IACO,KAAK,CAAC,YAAY,CAAC,KAAgB;QACzC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;QACjC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QACzE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAClB,SAAS,EAAE,IAAI;YACf,QAAQ;YACR,iBAAiB,EAAE,IAAI;SACxB,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAEO,cAAc,CAAC,KAAY;QACjC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;IACnC,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,2BAA2B,EAAE,SAAS,CAAC,CAAC;QAC1E,IAAI,CAAC,cAAc,CAAC,EAAE,GAAG,2BAA2B,CAAC;QAErD,MAAM,IAAI,GAAoB,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAClE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;QAEhD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;QAE3E,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEtC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAChD,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,2BAA2B,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;QAC7B,mCAAmC;IACrC,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACnG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAClB,SAAS,EAAE,IAAI;YACf,QAAQ;YACR,iBAAiB,EAAE,IAAI;SACxB,CAAC,CAAC;IACL,CAAC;IAED,IACI,WAAW;QACb,OAAO,cAAc,CAAC;IACxB,CAAC;8GArHU,uBAAuB;kGAAvB,uBAAuB,yRAFvB,CAAC,cAAc,CAAC;;2FAEhB,uBAAuB;kBAJnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,SAAS,EAAE,CAAC,cAAc,CAAC;iBAC5B;+EAGC,QAAQ;sBADP,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAYN,SAAS;sBADR,MAAM;gBAIP,oBAAoB;sBADnB,MAAM;gBAKP,qBAAqB;sBADpB,MAAM;gBA6FH,WAAW;sBADd,WAAW;uBAAC,OAAO","sourcesContent":["import { AXTranslationService } from '@acorex/core/translation';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Output,\n  inject,\n} from '@angular/core';\nimport {\n  AXUploaderChangedEvent,\n  AXUploaderFileCompleteEvent,\n  AXUploaderFilesCompleteEvent,\n} from './uploader.models';\nimport { AXUploaderService } from './uploader.service';\n@Directive({\n  selector: '[axUploaderZone]',\n  providers: [AXUnsubscriber],\n})\nexport class AXUploaderZoneDirective implements OnDestroy {\n  @Input()\n  multiple = true;\n\n  @Input()\n  accept: string = null;\n\n  private cdr = inject(ChangeDetectorRef);\n  private document = inject(DOCUMENT);\n\n  private uploadService = inject(AXUploaderService);\n  private unsubscriber = inject(AXUnsubscriber);\n  private translateService = inject(AXTranslationService);\n  private element: HTMLElement;\n\n  @Output()\n  onChanged: EventEmitter<AXUploaderChangedEvent> = new EventEmitter<AXUploaderChangedEvent>();\n\n  @Output()\n  onFileUploadComplete: EventEmitter<AXUploaderFileCompleteEvent> =\n    new EventEmitter<AXUploaderFileCompleteEvent>();\n\n  @Output()\n  onFilesUploadComplete: EventEmitter<AXUploaderFilesCompleteEvent> =\n    new EventEmitter<AXUploaderFilesCompleteEvent>();\n\n  stateClass = 'ax-uploader-overlay-state';\n  overlayElement: HTMLDivElement;\n\n  constructor(private elementRef: ElementRef) {\n    this.element = this.elementRef.nativeElement as HTMLElement;\n    this.element.style.position = 'relative';\n\n    //\n    this.uploadService.onFileUploadComplete.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {\n      this.onFileUploadComplete.next(c);\n    });\n\n    this.uploadService.onFilesUploadComplete.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {\n      this.onFilesUploadComplete.next(c);\n    });\n    //\n    this.element.addEventListener('click', this.browser.bind(this), true);\n\n    this.element.addEventListener('dragenter', this.handleDragEnter.bind(this), true);\n    this.element.addEventListener('dragover', this.handleDragOver.bind(this), true);\n    this.element.addEventListener('drop', this.handleOnDrop.bind(this), true);\n    this.element.addEventListener('dragleave', this.removeZone.bind(this), true);\n  }\n\n  ngOnDestroy(): void {\n    this.element.addEventListener('click', this.browser.bind(this), true);\n\n    this.element.removeEventListener('dragenter', this.handleDragEnter.bind(this));\n    this.element.removeEventListener('drop', this.handleOnDrop.bind(this));\n    this.element.removeEventListener('dragover', this.handleDragOver.bind(this));\n    this.element.removeEventListener('dragleave', this.removeZone.bind(this));\n  }\n\n  private handleDragEnter(event: Event) {\n    this.createZone();\n    event.preventDefault();\n    event.stopImmediatePropagation();\n  }\n  private async handleOnDrop(event: DragEvent) {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n    const requests = await this.uploadService.add(event.dataTransfer?.files);\n    this.onChanged.emit({\n      component: this,\n      requests,\n      isUserInteraction: true,\n    });\n    this.removeZone();\n    this.cdr.detectChanges();\n  }\n\n  private handleDragOver(event: Event) {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n  }\n\n  private createZone() {\n    this.overlayElement = this.document.createElement('div');\n    this.overlayElement.classList.add('ax-uploader-overlay-state', '-ax-z-1');\n    this.overlayElement.id = 'ax-uploader-overlay-state';\n\n    const icon: HTMLSpanElement = this.document.createElement('span');\n    icon.classList.add('ax-icon', 'ax-icon-upload');\n\n    const text = this.document.createElement('span');\n    text.innerText = this.translateService.translateSync('uploader.zone.text');\n\n    this.overlayElement.appendChild(icon);\n    this.overlayElement.appendChild(text);\n\n    this.element.appendChild(this.overlayElement);\n  }\n\n  private removeZone() {\n    this.element.removeChild(this.document.getElementById('ax-uploader-overlay-state'));\n    this.overlayElement.remove();\n    //console.log(this.overlayElement);\n  }\n\n  public async browser(): Promise<void> {\n    const requests = await this.uploadService.browse({ accept: this.accept, multiple: this.multiple });\n    this.onChanged.emit({\n      component: this,\n      requests,\n      isUserInteraction: true,\n    });\n  }\n\n  @HostBinding('class')\n  get __hostClass(): string {\n    return `ax-drop-zone`;\n  }\n}\n"]}
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader-zone.directive.js","sourceRoot":"","sources":["../../../../../../libs/components/uploader/src/lib/uploader-zone.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXTranslationService } from '@acorex/core/translation';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Output,\n  PLATFORM_ID,\n  inject,\n} from '@angular/core';\nimport {\n  AXUploaderChangedEvent,\n  AXUploaderFileCompleteEvent,\n  AXUploaderFilesCompleteEvent,\n} from './uploader.models';\nimport { AXUploaderService } from './uploader.service';\n@Directive({\n  selector: '[axUploaderZone]',\n  providers: [AXUnsubscriber],\n})\nexport class AXUploaderZoneDirective implements OnDestroy {\n  @Input()\n  multiple = true;\n\n  @Input()\n  accept: string = null;\n\n  private cdr = inject(ChangeDetectorRef);\n  private document = inject(DOCUMENT);\n  private platformID = inject(PLATFORM_ID);\n\n  private uploadService = inject(AXUploaderService);\n  private unsubscriber = inject(AXUnsubscriber);\n  private translateService = inject(AXTranslationService);\n  private element: HTMLElement;\n\n  @Output()\n  onChanged: EventEmitter<AXUploaderChangedEvent> = new EventEmitter<AXUploaderChangedEvent>();\n\n  @Output()\n  onFileUploadComplete: EventEmitter<AXUploaderFileCompleteEvent> =\n    new EventEmitter<AXUploaderFileCompleteEvent>();\n\n  @Output()\n  onFilesUploadComplete: EventEmitter<AXUploaderFilesCompleteEvent> =\n    new EventEmitter<AXUploaderFilesCompleteEvent>();\n\n  stateClass = 'ax-uploader-overlay-state';\n  overlayElement: HTMLDivElement;\n\n  constructor(private elementRef: ElementRef) {\n    this.element = this.elementRef.nativeElement as HTMLElement;\n    this.element.style.position = 'relative';\n\n    //\n    this.uploadService.onFileUploadComplete.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {\n      this.onFileUploadComplete.next(c);\n    });\n\n    this.uploadService.onFilesUploadComplete.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {\n      this.onFilesUploadComplete.next(c);\n    });\n    //\n    this.element.addEventListener('click', this.browser.bind(this), true);\n\n    this.element.addEventListener('dragenter', this.handleDragEnter.bind(this), true);\n    this.element.addEventListener('dragover', this.handleDragOver.bind(this), true);\n    this.element.addEventListener('drop', this.handleOnDrop.bind(this), true);\n    this.element.addEventListener('dragleave', this.removeZone.bind(this), true);\n  }\n\n  ngOnDestroy(): void {\n    this.element.addEventListener('click', this.browser.bind(this), true);\n\n    this.element.removeEventListener('dragenter', this.handleDragEnter.bind(this));\n    this.element.removeEventListener('drop', this.handleOnDrop.bind(this));\n    this.element.removeEventListener('dragover', this.handleDragOver.bind(this));\n    this.element.removeEventListener('dragleave', this.removeZone.bind(this));\n  }\n\n  private handleDragEnter(event: Event) {\n    this.createZone();\n    event.preventDefault();\n    event.stopImmediatePropagation();\n  }\n  private async handleOnDrop(event: DragEvent) {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n    const requests = await this.uploadService.add(event.dataTransfer?.files);\n    this.onChanged.emit({\n      component: this,\n      requests,\n      isUserInteraction: true,\n    });\n    this.removeZone();\n    this.cdr.detectChanges();\n  }\n\n  private handleDragOver(event: Event) {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n  }\n\n  private createZone() {\n    if (isPlatformBrowser(this.platformID)) {\n      this.overlayElement = this.document.createElement('div');\n      this.overlayElement.classList.add('ax-uploader-overlay-state', '-ax-z-1');\n      this.overlayElement.id = 'ax-uploader-overlay-state';\n\n      const icon: HTMLSpanElement = this.document.createElement('span');\n      icon.classList.add('ax-icon', 'ax-icon-upload');\n\n      const text = this.document.createElement('span');\n      text.innerText = this.translateService.translateSync('uploader.zone.text');\n\n      this.overlayElement.appendChild(icon);\n      this.overlayElement.appendChild(text);\n\n      this.element.appendChild(this.overlayElement);\n    }\n  }\n\n  private removeZone() {\n    if (isPlatformBrowser(this.platformID)) {\n      this.element.removeChild(this.document.getElementById('ax-uploader-overlay-state'));\n      this.overlayElement.remove();\n      //console.log(this.overlayElement);\n    }\n  }\n\n  public async browser(): Promise<void> {\n    const requests = await this.uploadService.browse({ accept: this.accept, multiple: this.multiple });\n    this.onChanged.emit({\n      component: this,\n      requests,\n      isUserInteraction: true,\n    });\n  }\n\n  @HostBinding('class')\n  get __hostClass(): string {\n    return `ax-drop-zone`;\n  }\n}\n"]}
|
@@ -1,8 +1,8 @@
|
|
1
|
+
import * as i1 from '@angular/common';
|
2
|
+
import { isPlatformBrowser, CommonModule } from '@angular/common';
|
1
3
|
import * as i0 from '@angular/core';
|
2
|
-
import { input, output, signal, inject, NgZone, afterNextRender, Component, ViewEncapsulation, ViewChild, NgModule } from '@angular/core';
|
4
|
+
import { input, output, signal, inject, NgZone, PLATFORM_ID, afterNextRender, Component, ViewEncapsulation, ViewChild, NgModule } from '@angular/core';
|
3
5
|
import WaveSurfer from 'wavesurfer.js';
|
4
|
-
import * as i1 from '@angular/common';
|
5
|
-
import { CommonModule } from '@angular/common';
|
6
6
|
import * as i2 from '@acorex/core/translation';
|
7
7
|
import { AXTranslationModule } from '@acorex/core/translation';
|
8
8
|
import { AXButtonModule } from '@acorex/components/button';
|
@@ -35,19 +35,22 @@ class AXAudioWaveComponent {
|
|
35
35
|
* @ignore
|
36
36
|
*/
|
37
37
|
this.ngZone = inject(NgZone);
|
38
|
+
this.platformID = inject(PLATFORM_ID);
|
38
39
|
afterNextRender(() => {
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
40
|
+
if (isPlatformBrowser(this.platformID)) {
|
41
|
+
const primary200 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-200');
|
42
|
+
const primary700 = getComputedStyle(document.body).getPropertyValue('--ax-color-primary-700');
|
43
|
+
this.audio = WaveSurfer.create({
|
44
|
+
container: this.div.nativeElement,
|
45
|
+
waveColor: this.config()?.waveColor || `rgba(${primary200})`,
|
46
|
+
progressColor: this.config()?.progressColor || `rgba(${primary700})`,
|
47
|
+
url: this.config()?.url || '',
|
48
|
+
barWidth: this.config()?.barWidth || 2,
|
49
|
+
barRadius: this.config()?.barRadius || 2,
|
50
|
+
barGap: this.config()?.barGap || 2,
|
51
|
+
height: this.config()?.height || 36,
|
52
|
+
});
|
53
|
+
}
|
51
54
|
this.load();
|
52
55
|
this.audio?.on('loading', () => {
|
53
56
|
this.audioState.set('loading');
|