@wemake4u/form-player-se 1.0.46 → 1.0.47
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/directives/treelist.directive.mjs +98 -0
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +85 -32
- package/esm2022/lib/services/function.service.mjs +14 -7
- package/esm2022/lib/services/programmability.service.mjs +2 -1
- package/esm2022/lib/utils/flatten.mjs +44 -0
- package/fesm2022/wemake4u-form-player-se.mjs +241 -45
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/directives/treelist.directive.d.ts +23 -0
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +15 -2
- package/lib/services/function.service.d.ts +2 -1
- package/lib/services/programmability.service.d.ts +1 -0
- package/lib/utils/flatten.d.ts +13 -0
- package/package.json +1 -1
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { ListenerService } from '../services/listener.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../services/listener.service";
|
|
5
|
+
export class TreeListDirective {
|
|
6
|
+
el;
|
|
7
|
+
listenerService;
|
|
8
|
+
nodes = [];
|
|
9
|
+
constructor(el, listenerService) {
|
|
10
|
+
this.el = el;
|
|
11
|
+
this.listenerService = listenerService;
|
|
12
|
+
}
|
|
13
|
+
ngOnChanges(changes) {
|
|
14
|
+
if (changes['nodes'] && this.initialized) {
|
|
15
|
+
this.rebuild();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
ngAfterViewInit() {
|
|
19
|
+
this.initialized = true;
|
|
20
|
+
this.rebuild();
|
|
21
|
+
}
|
|
22
|
+
initialized = false;
|
|
23
|
+
rows = [];
|
|
24
|
+
rebuild() {
|
|
25
|
+
queueMicrotask(() => {
|
|
26
|
+
this.rows = Array.from(this.el.nativeElement.querySelectorAll('tbody tr'));
|
|
27
|
+
this.initToggles();
|
|
28
|
+
this.refreshTree();
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
getChildren(id) {
|
|
32
|
+
return this.rows.filter(r => r.dataset['parent'] === id);
|
|
33
|
+
}
|
|
34
|
+
setVisible(row, visible) {
|
|
35
|
+
row.classList.toggle('hidden', !visible);
|
|
36
|
+
}
|
|
37
|
+
updateVisibility(parentId, parentVisible, parentExpanded) {
|
|
38
|
+
const children = this.getChildren(parentId);
|
|
39
|
+
for (const child of children) {
|
|
40
|
+
const childVisible = parentVisible && parentExpanded;
|
|
41
|
+
this.setVisible(child, childVisible);
|
|
42
|
+
const childExpanded = child.dataset['expanded'] === 'true';
|
|
43
|
+
this.updateVisibility(child.dataset['id'], childVisible, childExpanded);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
isExpanded(row) {
|
|
47
|
+
return row.dataset['expanded'] === 'true';
|
|
48
|
+
}
|
|
49
|
+
refreshTree() {
|
|
50
|
+
this.rows
|
|
51
|
+
.filter(r => !r.dataset['parent'])
|
|
52
|
+
.forEach(root => {
|
|
53
|
+
this.setVisible(root, true);
|
|
54
|
+
this.updateVisibility(root.dataset['id'], true, root.dataset['expanded'] === 'true');
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
initToggles() {
|
|
58
|
+
const toggles = this.el.nativeElement.querySelectorAll('.toggle');
|
|
59
|
+
toggles.forEach((toggle) => {
|
|
60
|
+
if (toggle.dataset['bound'] === 'true') {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
toggle.dataset['bound'] = 'true';
|
|
64
|
+
const row = toggle.closest('tr');
|
|
65
|
+
this.refreshToggleIcon(toggle, this.isExpanded(row));
|
|
66
|
+
this.listenerService.listen(toggle, 'click', (e) => {
|
|
67
|
+
e.stopPropagation();
|
|
68
|
+
const expanded = this.isExpanded(row);
|
|
69
|
+
row.dataset['expanded'] = (!expanded).toString();
|
|
70
|
+
this.refreshToggleIcon(toggle, this.isExpanded(row));
|
|
71
|
+
this.refreshTree();
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
refreshToggleIcon(target, expanded) {
|
|
76
|
+
target.classList.remove('fas', 'fa-angle-down', 'fa-angle-right');
|
|
77
|
+
target.classList.add('fas');
|
|
78
|
+
target.classList.add(expanded ? 'fa-angle-down' : 'fa-angle-right');
|
|
79
|
+
}
|
|
80
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TreeListDirective, deps: [{ token: i0.ElementRef }, { token: i1.ListenerService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
81
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: TreeListDirective, isStandalone: true, selector: "[treelist]", inputs: { nodes: ["treelist", "nodes"] }, providers: [
|
|
82
|
+
ListenerService
|
|
83
|
+
], usesOnChanges: true, ngImport: i0 });
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TreeListDirective, decorators: [{
|
|
86
|
+
type: Directive,
|
|
87
|
+
args: [{
|
|
88
|
+
selector: '[treelist]',
|
|
89
|
+
standalone: true,
|
|
90
|
+
providers: [
|
|
91
|
+
ListenerService
|
|
92
|
+
]
|
|
93
|
+
}]
|
|
94
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.ListenerService }], propDecorators: { nodes: [{
|
|
95
|
+
type: Input,
|
|
96
|
+
args: ['treelist']
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treelist.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/treelist.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, AfterViewInit, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { ListenerService } from '../services/listener.service';\r\n\r\n@Directive({\r\n    selector: '[treelist]',\r\n    standalone: true,\r\n    providers: [\r\n        ListenerService\r\n    ]\r\n})\r\nexport class TreeListDirective implements OnChanges, AfterViewInit {\r\n\r\n    @Input('treelist') nodes: any[] = [];\r\n\r\n    constructor(private el: ElementRef\r\n        , private listenerService: ListenerService) {\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes['nodes'] && this.initialized) {\r\n            this.rebuild();\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.initialized = true;\r\n        this.rebuild();        \r\n    }\r\n\r\n    private initialized = false;\r\n    private rows: HTMLTableRowElement[] = [];\r\n\r\n    private rebuild() {\r\n        queueMicrotask(() => {\r\n            this.rows = Array.from(this.el.nativeElement.querySelectorAll('tbody tr'));\r\n            this.initToggles();\r\n            this.refreshTree();      \r\n        });\r\n    }\r\n\r\n    private getChildren(id: string): HTMLTableRowElement[] {\r\n        return this.rows.filter(r => r.dataset['parent'] === id);\r\n    }\r\n\r\n    private setVisible(row: HTMLTableRowElement, visible: boolean) {\r\n        row.classList.toggle('hidden', !visible);\r\n    }\r\n\r\n    private updateVisibility(parentId: string, parentVisible: boolean, parentExpanded: boolean) {\r\n        const children = this.getChildren(parentId);\r\n\r\n        for (const child of children) {\r\n            const childVisible = parentVisible && parentExpanded;\r\n            this.setVisible(child, childVisible);\r\n\r\n            const childExpanded = child.dataset['expanded'] === 'true';\r\n            this.updateVisibility(child.dataset['id']!, childVisible, childExpanded);\r\n        }\r\n    }\r\n\r\n    private isExpanded(row: HTMLTableRowElement): boolean {\r\n        return row.dataset['expanded'] === 'true';\r\n    }\r\n\r\n    private refreshTree() {\r\n        this.rows\r\n            .filter(r => !r.dataset['parent'])\r\n            .forEach(root => {\r\n                this.setVisible(root, true);\r\n                this.updateVisibility(\r\n                    root.dataset['id']!,\r\n                    true,\r\n                    root.dataset['expanded'] === 'true'\r\n                );\r\n            });\r\n    }\r\n\r\n    private initToggles() {\r\n        const toggles = this.el.nativeElement.querySelectorAll('.toggle');\r\n        toggles.forEach((toggle: any) => {\r\n            if (toggle.dataset['bound'] === 'true') {\r\n                return;\r\n            }\r\n            toggle.dataset['bound'] = 'true';\r\n            const row = toggle.closest('tr') as HTMLTableRowElement;\r\n            this.refreshToggleIcon(toggle, this.isExpanded(row));\r\n            this.listenerService.listen(toggle, 'click', (e: Event) => {\r\n                e.stopPropagation();\r\n                const expanded = this.isExpanded(row);\r\n                row.dataset['expanded'] = (!expanded).toString();\r\n                this.refreshToggleIcon(toggle, this.isExpanded(row));\r\n                this.refreshTree();\r\n            });\r\n        });\r\n    }\r\n\r\n    private refreshToggleIcon(target: HTMLElement, expanded: boolean)\r\n    {        \r\n        target.classList.remove('fas', 'fa-angle-down', 'fa-angle-right');\r\n        target.classList.add('fas');\r\n        target.classList.add(expanded ? 'fa-angle-down' : 'fa-angle-right');\r\n    }\r\n}\r\n"]}
|