@datarailsshared/datarailsshared 1.5.389 → 1.5.397
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/datarailsshared-datarailsshared-1.5.397.tgz +0 -0
- package/esm2022/lib/date-tags/any-tag.component.mjs +18 -18
- package/esm2022/lib/date-tags/date-tag.component.mjs +99 -23
- package/esm2022/lib/date-tags/date-tag.module.mjs +27 -26
- package/esm2022/lib/date-tags/day-tag/day-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/forecast-tag/forecast-tag.component.mjs +43 -25
- package/esm2022/lib/date-tags/month-tag/month-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/quarter-tag/quarter-tag.component.mjs +26 -12
- package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/year-tag/year-tag.component.mjs +40 -26
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +16 -16
- package/esm2022/lib/directives/click-outside/click-outside.module.mjs +13 -12
- package/esm2022/lib/dr-accordion/accordion-item-body.component.mjs +18 -15
- package/esm2022/lib/dr-accordion/accordion-item-header.component.mjs +71 -54
- package/esm2022/lib/dr-accordion/accordion-item.component.mjs +37 -32
- package/esm2022/lib/dr-accordion/accordion.component.mjs +15 -10
- package/esm2022/lib/dr-accordion/accordion.module.mjs +20 -19
- package/esm2022/lib/dr-alert/dr-alert.component.mjs +44 -16
- package/esm2022/lib/dr-alert/dr-alert.module.mjs +14 -13
- package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +98 -23
- package/esm2022/lib/dr-avatar/dr-avatar.module.mjs +13 -12
- package/esm2022/lib/dr-avatar/dr-avatar.pipe.mjs +9 -9
- package/esm2022/lib/dr-badge-status/dr-badge-status.component.mjs +43 -17
- package/esm2022/lib/dr-badge-status/dr-badge-status.module.mjs +14 -13
- package/esm2022/lib/dr-chat/chat.component.mjs +115 -38
- package/esm2022/lib/dr-chat/chat.module.mjs +27 -26
- package/esm2022/lib/dr-chat/dr-chat-alert/dr-chat-alert.component.mjs +21 -11
- package/esm2022/lib/dr-chat/dr-chat-form/chat-form.component.mjs +128 -37
- package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +126 -41
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.directive.mjs +11 -11
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.service.mjs +6 -6
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +40 -11
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-text/chat-message-text.component.mjs +22 -9
- package/esm2022/lib/dr-chat/dr-chat-suggestions/chat-suggestions.component.mjs +86 -20
- package/esm2022/lib/dr-chat/dr-dot-flashing/dr-dot-flashing.component.mjs +9 -7
- package/esm2022/lib/dr-chip/dr-chip.component.mjs +49 -15
- package/esm2022/lib/dr-code-editor/components/code-editor-hint-wrapper.component.mjs +14 -10
- package/esm2022/lib/dr-code-editor/components/dr-codemirror.component.mjs +62 -57
- package/esm2022/lib/dr-code-editor/dr-code-editor.component.mjs +48 -20
- package/esm2022/lib/dr-code-editor/dr-code-editor.module.mjs +14 -13
- package/esm2022/lib/dr-details-list/dr-details-list.component.mjs +69 -41
- package/esm2022/lib/dr-details-list/dr-details-list.module.mjs +14 -13
- package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +265 -13
- package/esm2022/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.mjs +154 -16
- package/esm2022/lib/dr-dialog/dialog.module.mjs +14 -13
- package/esm2022/lib/dr-dialog/services/dialog.service.mjs +9 -9
- package/esm2022/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.mjs +29 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown-item-show.pipe.mjs +9 -9
- package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +175 -56
- package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +98 -87
- package/esm2022/lib/dr-dropdown/dr-dropdown.module.mjs +32 -15
- package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +55 -18
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.component.mjs +92 -25
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.module.mjs +13 -12
- package/esm2022/lib/dr-error/dr-error.component.mjs +48 -24
- package/esm2022/lib/dr-error/dr-error.module.mjs +14 -13
- package/esm2022/lib/dr-inputs/button/button.component.mjs +88 -45
- package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +53 -28
- package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +32 -32
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +67 -42
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.mjs +72 -32
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +111 -42
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +99 -10
- package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +9 -9
- package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +6 -6
- package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +168 -84
- package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +64 -63
- package/esm2022/lib/dr-inputs/dr-link/dr-link.component.mjs +26 -16
- package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +13 -13
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +243 -104
- package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +77 -20
- package/esm2022/lib/dr-inputs/dr-slider/dr-slider.component.mjs +23 -17
- package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +64 -22
- package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +53 -21
- package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +40 -28
- package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +51 -41
- package/esm2022/lib/dr-layout/dr-layout-body.component.mjs +14 -10
- package/esm2022/lib/dr-layout/dr-layout-header.component.mjs +16 -14
- package/esm2022/lib/dr-layout/dr-layout.component.mjs +16 -7
- package/esm2022/lib/dr-layout/dr-layout.module.mjs +13 -12
- package/esm2022/lib/dr-popover/dr-popover-ref.mjs +4 -1
- package/esm2022/lib/dr-popover/dr-popover.component.mjs +71 -40
- package/esm2022/lib/dr-popover/dr-popover.directive.mjs +51 -49
- package/esm2022/lib/dr-popover/dr-popover.module.mjs +13 -12
- package/esm2022/lib/dr-popover/dr-popover.service.mjs +25 -13
- package/esm2022/lib/dr-scenario/components/dr-scenario-configuration/dr-scenario-configuration.component.mjs +41 -17
- package/esm2022/lib/dr-scenario/components/dr-scenario-tag-configuration/dr-scenario-tag-configuration.component.mjs +42 -27
- package/esm2022/lib/dr-scenario/dr-scenario.module.mjs +14 -13
- package/esm2022/lib/dr-scenario/services/scenario.service.mjs +6 -6
- package/esm2022/lib/dr-spinner/dr-spinner.component.mjs +17 -7
- package/esm2022/lib/dr-spinner/dr-spinner.directive.mjs +25 -20
- package/esm2022/lib/dr-spinner/dr-spinner.module.mjs +13 -12
- package/esm2022/lib/dr-tabs/dr-tab.component.mjs +33 -25
- package/esm2022/lib/dr-tabs/dr-tabs.component.mjs +118 -30
- package/esm2022/lib/dr-tabs/dr-tabs.module.mjs +14 -13
- package/esm2022/lib/dr-tags/dr-tag.component.mjs +75 -33
- package/esm2022/lib/dr-tags/dr-tag.module.mjs +14 -13
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.component.mjs +72 -19
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.module.mjs +14 -13
- package/esm2022/lib/dr-tags-constructor/tags-constructor.service.mjs +6 -6
- package/esm2022/lib/dr-toastr/default-toastr/default-toastr.component.mjs +48 -10
- package/esm2022/lib/dr-toastr/dr-toastr.module.mjs +19 -18
- package/esm2022/lib/dr-toastr/dr-toastr.service.mjs +9 -9
- package/esm2022/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.mjs +23 -14
- package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +76 -9
- package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +63 -25
- package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +41 -39
- package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +14 -13
- package/esm2022/lib/dr-treeview/components/treeview/treeview.component.mjs +211 -19
- package/esm2022/lib/dr-treeview/components/treeview-item/treeview-item.component.mjs +52 -15
- package/esm2022/lib/dr-treeview/dr-tree-view.module.mjs +14 -13
- package/esm2022/lib/dr-treeview/helpers/treeview-event-parser.mjs +21 -21
- package/esm2022/lib/dr-treeview/models/treeview-config.mjs +6 -6
- package/esm2022/lib/dr-treeview/models/treeview-i18n.mjs +11 -11
- package/esm2022/lib/dr-treeview/pipes/treeview.pipe.mjs +9 -9
- package/esm2022/lib/image-cropper/dr-image-cropper-canvas.service.mjs +6 -6
- package/esm2022/lib/image-cropper/dr-image-cropper.component.mjs +67 -28
- package/esm2022/lib/list-tags/list-tag.component.mjs +57 -17
- package/esm2022/lib/list-tags/list-tag.module.mjs +14 -13
- package/esm2022/lib/models/dropdown.mjs +1 -1
- package/esm2022/lib/models/popover.mjs +1 -1
- package/esm2022/lib/models/serverTags.mjs +1 -1
- package/esm2022/lib/stepper/stepper.component.mjs +225 -28
- package/esm2022/lib/stepper/stepper.module.mjs +13 -12
- package/esm2022/lib/utils/decorators.mjs +12 -0
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +5787 -2724
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.d.ts +8 -0
- package/lib/dr-dropdown/dr-dropdown.component.d.ts +24 -22
- package/lib/dr-dropdown/dr-dropdown.directive.d.ts +16 -15
- package/lib/dr-dropdown/dr-dropdown.module.d.ts +5 -4
- package/lib/dr-dropdown/dr-dropdown.service.d.ts +23 -8
- package/lib/dr-popover/dr-popover-ref.d.ts +1 -0
- package/lib/dr-popover/dr-popover.service.d.ts +2 -1
- package/lib/models/dropdown.d.ts +13 -21
- package/lib/models/popover.d.ts +6 -3
- package/lib/models/serverTags.d.ts +1 -0
- package/lib/utils/decorators.d.ts +1 -0
- package/package.json +5 -2
- package/public-api.d.ts +2 -2
- package/datarailsshared-datarailsshared-1.5.389.tgz +0 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown-position.directive.mjs +0 -113
- package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +0 -15
|
@@ -12,6 +12,178 @@ import * as i3 from "../../helpers/treeview-event-parser";
|
|
|
12
12
|
import * as i4 from "@angular/forms";
|
|
13
13
|
import * as i5 from "@angular/common";
|
|
14
14
|
import * as i6 from "../treeview-item/treeview-item.component";
|
|
15
|
+
function TreeviewComponent_ng_template_0_i_1__svg_svg_1_Template(rf, ctx) { if (rf & 1) {
|
|
16
|
+
i0.ɵɵnamespaceSVG();
|
|
17
|
+
i0.ɵɵelementStart(0, "svg", 15);
|
|
18
|
+
i0.ɵɵelement(1, "path", 16);
|
|
19
|
+
i0.ɵɵelementEnd();
|
|
20
|
+
} }
|
|
21
|
+
function TreeviewComponent_ng_template_0_i_1__svg_svg_2_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
+
i0.ɵɵnamespaceSVG();
|
|
23
|
+
i0.ɵɵelementStart(0, "svg", 17);
|
|
24
|
+
i0.ɵɵelement(1, "path", 18);
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
} }
|
|
27
|
+
function TreeviewComponent_ng_template_0_i_1_Template(rf, ctx) { if (rf & 1) {
|
|
28
|
+
const _r15 = i0.ɵɵgetCurrentView();
|
|
29
|
+
i0.ɵɵelementStart(0, "i", 12);
|
|
30
|
+
i0.ɵɵlistener("click", function TreeviewComponent_ng_template_0_i_1_Template_i_click_0_listener() { i0.ɵɵrestoreView(_r15); const onCollapseExpand_r8 = i0.ɵɵnextContext().onCollapseExpand; return i0.ɵɵresetView(onCollapseExpand_r8()); });
|
|
31
|
+
i0.ɵɵtemplate(1, TreeviewComponent_ng_template_0_i_1__svg_svg_1_Template, 2, 0, "svg", 13);
|
|
32
|
+
i0.ɵɵtemplate(2, TreeviewComponent_ng_template_0_i_1__svg_svg_2_Template, 2, 0, "svg", 14);
|
|
33
|
+
i0.ɵɵelementEnd();
|
|
34
|
+
} if (rf & 2) {
|
|
35
|
+
const item_r7 = i0.ɵɵnextContext().item;
|
|
36
|
+
i0.ɵɵproperty("ngSwitch", item_r7.collapsed);
|
|
37
|
+
i0.ɵɵadvance(1);
|
|
38
|
+
i0.ɵɵproperty("ngSwitchCase", true);
|
|
39
|
+
i0.ɵɵadvance(1);
|
|
40
|
+
i0.ɵɵproperty("ngSwitchCase", false);
|
|
41
|
+
} }
|
|
42
|
+
function TreeviewComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
43
|
+
const _r18 = i0.ɵɵgetCurrentView();
|
|
44
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
45
|
+
i0.ɵɵtemplate(1, TreeviewComponent_ng_template_0_i_1_Template, 3, 3, "i", 8);
|
|
46
|
+
i0.ɵɵelementStart(2, "div", 9)(3, "input", 10);
|
|
47
|
+
i0.ɵɵlistener("ngModelChange", function TreeviewComponent_ng_template_0_Template_input_ngModelChange_3_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r18); const item_r7 = restoredCtx.item; return i0.ɵɵresetView(item_r7.checked = $event); })("ngModelChange", function TreeviewComponent_ng_template_0_Template_input_ngModelChange_3_listener() { const restoredCtx = i0.ɵɵrestoreView(_r18); const onCheckedChange_r9 = restoredCtx.onCheckedChange; return i0.ɵɵresetView(onCheckedChange_r9()); });
|
|
48
|
+
i0.ɵɵelementEnd();
|
|
49
|
+
i0.ɵɵelementStart(4, "label", 11);
|
|
50
|
+
i0.ɵɵlistener("click", function TreeviewComponent_ng_template_0_Template_label_click_4_listener() { const restoredCtx = i0.ɵɵrestoreView(_r18); const item_r7 = restoredCtx.item; const onCheckedChange_r9 = restoredCtx.onCheckedChange; item_r7.checked = !item_r7.checked; return i0.ɵɵresetView(onCheckedChange_r9()); });
|
|
51
|
+
i0.ɵɵtext(5);
|
|
52
|
+
i0.ɵɵelementEnd()()();
|
|
53
|
+
} if (rf & 2) {
|
|
54
|
+
const item_r7 = ctx.item;
|
|
55
|
+
i0.ɵɵadvance(1);
|
|
56
|
+
i0.ɵɵproperty("ngIf", item_r7.children);
|
|
57
|
+
i0.ɵɵadvance(2);
|
|
58
|
+
i0.ɵɵproperty("ngModel", item_r7.checked)("disabled", item_r7.disabled)("indeterminate", item_r7.indeterminate);
|
|
59
|
+
i0.ɵɵadvance(2);
|
|
60
|
+
i0.ɵɵtextInterpolate1(" ", item_r7.text, " ");
|
|
61
|
+
} }
|
|
62
|
+
function TreeviewComponent_ng_template_2_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
63
|
+
const _r29 = i0.ɵɵgetCurrentView();
|
|
64
|
+
i0.ɵɵelementStart(0, "div", 21)(1, "div", 22)(2, "input", 23);
|
|
65
|
+
i0.ɵɵlistener("ngModelChange", function TreeviewComponent_ng_template_2_div_0_Template_input_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r29); const ctx_r28 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r28.filterText = $event); })("ngModelChange", function TreeviewComponent_ng_template_2_div_0_Template_input_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r29); const onFilterTextChange_r25 = i0.ɵɵnextContext().onFilterTextChange; return i0.ɵɵresetView(onFilterTextChange_r25($event)); });
|
|
66
|
+
i0.ɵɵelementEnd()()();
|
|
67
|
+
} if (rf & 2) {
|
|
68
|
+
const ctx_r26 = i0.ɵɵnextContext(2);
|
|
69
|
+
i0.ɵɵadvance(2);
|
|
70
|
+
i0.ɵɵproperty("placeholder", ctx_r26.i18n.getFilterPlaceholder())("ngModel", ctx_r26.filterText);
|
|
71
|
+
} }
|
|
72
|
+
function TreeviewComponent_ng_template_2_div_1_div_1_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
73
|
+
const _r38 = i0.ɵɵgetCurrentView();
|
|
74
|
+
i0.ɵɵelementStart(0, "div", 29)(1, "input", 30);
|
|
75
|
+
i0.ɵɵlistener("ngModelChange", function TreeviewComponent_ng_template_2_div_1_div_1_div_2_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r38); const item_r22 = i0.ɵɵnextContext(3).item; return i0.ɵɵresetView(item_r22.checked = $event); })("ngModelChange", function TreeviewComponent_ng_template_2_div_1_div_1_div_2_Template_input_ngModelChange_1_listener() { i0.ɵɵrestoreView(_r38); const onCheckedChange_r24 = i0.ɵɵnextContext(3).onCheckedChange; return i0.ɵɵresetView(onCheckedChange_r24()); });
|
|
76
|
+
i0.ɵɵelementEnd();
|
|
77
|
+
i0.ɵɵelementStart(2, "label", 11);
|
|
78
|
+
i0.ɵɵlistener("click", function TreeviewComponent_ng_template_2_div_1_div_1_div_2_Template_label_click_2_listener() { i0.ɵɵrestoreView(_r38); const ctx_r42 = i0.ɵɵnextContext(3); const item_r22 = ctx_r42.item; const onCheckedChange_r24 = ctx_r42.onCheckedChange; item_r22.checked = !item_r22.checked; return i0.ɵɵresetView(onCheckedChange_r24()); });
|
|
79
|
+
i0.ɵɵtext(3);
|
|
80
|
+
i0.ɵɵelementEnd()();
|
|
81
|
+
} if (rf & 2) {
|
|
82
|
+
const item_r22 = i0.ɵɵnextContext(3).item;
|
|
83
|
+
const ctx_r34 = i0.ɵɵnextContext();
|
|
84
|
+
i0.ɵɵadvance(1);
|
|
85
|
+
i0.ɵɵproperty("ngModel", item_r22.checked)("indeterminate", item_r22.indeterminate);
|
|
86
|
+
i0.ɵɵadvance(2);
|
|
87
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r34.i18n.getAllCheckboxText(), " ");
|
|
88
|
+
} }
|
|
89
|
+
function TreeviewComponent_ng_template_2_div_1_div_1_label_3__svg_svg_2_Template(rf, ctx) { if (rf & 1) {
|
|
90
|
+
i0.ɵɵnamespaceSVG();
|
|
91
|
+
i0.ɵɵelementStart(0, "svg", 35);
|
|
92
|
+
i0.ɵɵelement(1, "path", 36)(2, "path", 37)(3, "path", 38);
|
|
93
|
+
i0.ɵɵelementEnd();
|
|
94
|
+
} }
|
|
95
|
+
function TreeviewComponent_ng_template_2_div_1_div_1_label_3__svg_svg_3_Template(rf, ctx) { if (rf & 1) {
|
|
96
|
+
i0.ɵɵnamespaceSVG();
|
|
97
|
+
i0.ɵɵelementStart(0, "svg", 39);
|
|
98
|
+
i0.ɵɵelement(1, "path", 40)(2, "path", 41)(3, "path", 42);
|
|
99
|
+
i0.ɵɵelementEnd();
|
|
100
|
+
} }
|
|
101
|
+
function TreeviewComponent_ng_template_2_div_1_div_1_label_3_Template(rf, ctx) { if (rf & 1) {
|
|
102
|
+
const _r48 = i0.ɵɵgetCurrentView();
|
|
103
|
+
i0.ɵɵelementStart(0, "label", 31);
|
|
104
|
+
i0.ɵɵlistener("click", function TreeviewComponent_ng_template_2_div_1_div_1_label_3_Template_label_click_0_listener() { i0.ɵɵrestoreView(_r48); const onCollapseExpand_r23 = i0.ɵɵnextContext(3).onCollapseExpand; return i0.ɵɵresetView(onCollapseExpand_r23()); });
|
|
105
|
+
i0.ɵɵelementStart(1, "i", 32);
|
|
106
|
+
i0.ɵɵtemplate(2, TreeviewComponent_ng_template_2_div_1_div_1_label_3__svg_svg_2_Template, 4, 0, "svg", 33);
|
|
107
|
+
i0.ɵɵtemplate(3, TreeviewComponent_ng_template_2_div_1_div_1_label_3__svg_svg_3_Template, 4, 0, "svg", 34);
|
|
108
|
+
i0.ɵɵelementEnd()();
|
|
109
|
+
} if (rf & 2) {
|
|
110
|
+
const item_r22 = i0.ɵɵnextContext(3).item;
|
|
111
|
+
const ctx_r35 = i0.ɵɵnextContext();
|
|
112
|
+
i0.ɵɵadvance(1);
|
|
113
|
+
i0.ɵɵproperty("title", ctx_r35.i18n.getTooltipCollapseExpandText(item_r22.collapsed))("ngSwitch", item_r22.collapsed);
|
|
114
|
+
i0.ɵɵadvance(1);
|
|
115
|
+
i0.ɵɵproperty("ngSwitchCase", true);
|
|
116
|
+
i0.ɵɵadvance(1);
|
|
117
|
+
i0.ɵɵproperty("ngSwitchCase", false);
|
|
118
|
+
} }
|
|
119
|
+
function TreeviewComponent_ng_template_2_div_1_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
120
|
+
i0.ɵɵelementStart(0, "div", 26)(1, "div", 22);
|
|
121
|
+
i0.ɵɵtemplate(2, TreeviewComponent_ng_template_2_div_1_div_1_div_2_Template, 4, 3, "div", 27);
|
|
122
|
+
i0.ɵɵtemplate(3, TreeviewComponent_ng_template_2_div_1_div_1_label_3_Template, 4, 4, "label", 28);
|
|
123
|
+
i0.ɵɵelementEnd()();
|
|
124
|
+
} if (rf & 2) {
|
|
125
|
+
const config_r21 = i0.ɵɵnextContext(2).config;
|
|
126
|
+
i0.ɵɵadvance(2);
|
|
127
|
+
i0.ɵɵproperty("ngIf", config_r21.hasAllCheckBox);
|
|
128
|
+
i0.ɵɵadvance(1);
|
|
129
|
+
i0.ɵɵproperty("ngIf", config_r21.hasCollapseExpand);
|
|
130
|
+
} }
|
|
131
|
+
function TreeviewComponent_ng_template_2_div_1_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
132
|
+
i0.ɵɵelement(0, "div", 43);
|
|
133
|
+
} }
|
|
134
|
+
function TreeviewComponent_ng_template_2_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
135
|
+
i0.ɵɵelementStart(0, "div");
|
|
136
|
+
i0.ɵɵtemplate(1, TreeviewComponent_ng_template_2_div_1_div_1_Template, 4, 2, "div", 24);
|
|
137
|
+
i0.ɵɵtemplate(2, TreeviewComponent_ng_template_2_div_1_div_2_Template, 1, 0, "div", 25);
|
|
138
|
+
i0.ɵɵelementEnd();
|
|
139
|
+
} if (rf & 2) {
|
|
140
|
+
const config_r21 = i0.ɵɵnextContext().config;
|
|
141
|
+
i0.ɵɵadvance(1);
|
|
142
|
+
i0.ɵɵproperty("ngIf", config_r21.hasAllCheckBox || config_r21.hasCollapseExpand);
|
|
143
|
+
i0.ɵɵadvance(1);
|
|
144
|
+
i0.ɵɵproperty("ngIf", config_r21.hasDivider);
|
|
145
|
+
} }
|
|
146
|
+
function TreeviewComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
147
|
+
i0.ɵɵtemplate(0, TreeviewComponent_ng_template_2_div_0_Template, 3, 2, "div", 19);
|
|
148
|
+
i0.ɵɵtemplate(1, TreeviewComponent_ng_template_2_div_1_Template, 3, 2, "div", 20);
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
const config_r21 = ctx.config;
|
|
151
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
152
|
+
i0.ɵɵproperty("ngIf", config_r21.hasFilter);
|
|
153
|
+
i0.ɵɵadvance(1);
|
|
154
|
+
i0.ɵɵproperty("ngIf", ctx_r3.hasFilterItems);
|
|
155
|
+
} }
|
|
156
|
+
function TreeviewComponent_ng_template_5_Template(rf, ctx) { }
|
|
157
|
+
function TreeviewComponent_div_7_ngx_treeview_item_1_Template(rf, ctx) { if (rf & 1) {
|
|
158
|
+
const _r55 = i0.ɵɵgetCurrentView();
|
|
159
|
+
i0.ɵɵelementStart(0, "ngx-treeview-item", 46);
|
|
160
|
+
i0.ɵɵlistener("checkedChange", function TreeviewComponent_div_7_ngx_treeview_item_1_Template_ngx_treeview_item_checkedChange_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r55); const item_r53 = restoredCtx.$implicit; const ctx_r54 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r54.onItemCheckedChange(item_r53, $event)); });
|
|
161
|
+
i0.ɵɵelementEnd();
|
|
162
|
+
} if (rf & 2) {
|
|
163
|
+
const item_r53 = ctx.$implicit;
|
|
164
|
+
const ctx_r52 = i0.ɵɵnextContext(2);
|
|
165
|
+
const _r0 = i0.ɵɵreference(1);
|
|
166
|
+
i0.ɵɵproperty("config", ctx_r52.config)("item", item_r53)("template", ctx_r52.itemTemplate || _r0);
|
|
167
|
+
} }
|
|
168
|
+
function TreeviewComponent_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
169
|
+
i0.ɵɵelementStart(0, "div", 44);
|
|
170
|
+
i0.ɵɵtemplate(1, TreeviewComponent_div_7_ngx_treeview_item_1_Template, 1, 3, "ngx-treeview-item", 45);
|
|
171
|
+
i0.ɵɵelementEnd();
|
|
172
|
+
} if (rf & 2) {
|
|
173
|
+
const ctx_r5 = i0.ɵɵnextContext();
|
|
174
|
+
i0.ɵɵstyleProp("max-height", ctx_r5.maxHeight, "px");
|
|
175
|
+
i0.ɵɵadvance(1);
|
|
176
|
+
i0.ɵɵproperty("ngForOf", ctx_r5.filterItems);
|
|
177
|
+
} }
|
|
178
|
+
function TreeviewComponent_div_8_Template(rf, ctx) { if (rf & 1) {
|
|
179
|
+
i0.ɵɵelementStart(0, "div", 47);
|
|
180
|
+
i0.ɵɵtext(1);
|
|
181
|
+
i0.ɵɵelementEnd();
|
|
182
|
+
} if (rf & 2) {
|
|
183
|
+
const ctx_r6 = i0.ɵɵnextContext();
|
|
184
|
+
i0.ɵɵadvance(1);
|
|
185
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r6.i18n.getFilterNoItemsFoundText(), " ");
|
|
186
|
+
} }
|
|
15
187
|
class FilterTreeviewItem extends TreeviewItem {
|
|
16
188
|
constructor(item) {
|
|
17
189
|
super({
|
|
@@ -193,23 +365,43 @@ export class TreeviewComponent {
|
|
|
193
365
|
}
|
|
194
366
|
this.allItem.collapsed = !hasItemExpanded;
|
|
195
367
|
}
|
|
196
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
197
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵ
|
|
368
|
+
/** @nocollapse */ static { this.ɵfac = function TreeviewComponent_Factory(t) { return new (t || TreeviewComponent)(i0.ɵɵdirectiveInject(i1.TreeviewI18n), i0.ɵɵdirectiveInject(i2.TreeviewConfig), i0.ɵɵdirectiveInject(i3.TreeviewEventParser)); }; }
|
|
369
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TreeviewComponent, selectors: [["ngx-treeview"]], inputs: { headerTemplate: "headerTemplate", itemTemplate: "itemTemplate", items: "items", config: "config" }, outputs: { selectedChange: "selectedChange", filterChange: "filterChange" }, features: [i0.ɵɵNgOnChangesFeature], decls: 9, vars: 5, consts: [["defaultItemTemplate", ""], ["defaultHeaderTemplate", ""], [1, "treeview-header"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [3, "ngSwitch"], ["class", "treeview-container", 3, "max-height", 4, "ngSwitchCase"], ["class", "treeview-text", 4, "ngSwitchCase"], [1, "form-inline", "row-item"], ["aria-hidden", "true", 3, "ngSwitch", "click", 4, "ngIf"], [1, "form-check"], ["type", "checkbox", 1, "form-check-input", 3, "ngModel", "disabled", "indeterminate", "ngModelChange"], [1, "form-check-label", 3, "click"], ["aria-hidden", "true", 3, "ngSwitch", "click"], ["width", "0.8rem", "height", "0.8rem", "viewBox", "0 0 16 16", "class", "bi bi-caret-right-fill", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 4, "ngSwitchCase"], ["width", "0.8rem", "height", "0.8rem", "viewBox", "0 0 16 16", "class", "bi bi-caret-down-fill", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 4, "ngSwitchCase"], ["width", "0.8rem", "height", "0.8rem", "viewBox", "0 0 16 16", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 1, "bi", "bi-caret-right-fill"], ["d", "M12.14 8.753l-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z"], ["width", "0.8rem", "height", "0.8rem", "viewBox", "0 0 16 16", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 1, "bi", "bi-caret-down-fill"], ["d", "M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z"], ["class", "row row-filter", 4, "ngIf"], [4, "ngIf"], [1, "row", "row-filter"], [1, "col-12"], ["type", "text", 1, "form-control", 3, "placeholder", "ngModel", "ngModelChange"], ["class", "row row-all", 4, "ngIf"], ["class", "dropdown-divider", 4, "ngIf"], [1, "row", "row-all"], ["class", "form-check form-check-inline", 4, "ngIf"], ["class", "float-right form-check-label", 3, "click", 4, "ngIf"], [1, "form-check", "form-check-inline"], ["type", "checkbox", 1, "form-check-input", 3, "ngModel", "indeterminate", "ngModelChange"], [1, "float-right", "form-check-label", 3, "click"], ["aria-hidden", "true", 3, "title", "ngSwitch"], ["width", "1em", "height", "1em", "viewBox", "0 0 16 16", "class", "bi bi-arrows-angle-expand", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 4, "ngSwitchCase"], ["width", "1em", "height", "1em", "viewBox", "0 0 16 16", "class", "bi bi-arrows-angle-contract", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 4, "ngSwitchCase"], ["width", "1em", "height", "1em", "viewBox", "0 0 16 16", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 1, "bi", "bi-arrows-angle-expand"], ["fill-rule", "evenodd", "d", "M1.5 10.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z"], ["fill-rule", "evenodd", "d", "M6.354 9.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm8.5-8.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z"], ["fill-rule", "evenodd", "d", "M10.036 1.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 1 1-1 0V2h-3.5a.5.5 0 0 1-.5-.5z"], ["width", "1em", "height", "1em", "viewBox", "0 0 16 16", "fill", "currentColor", "xmlns", "http://www.w3.org/2000/svg", 1, "bi", "bi-arrows-angle-contract"], ["fill-rule", "evenodd", "d", "M9.5 2.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z"], ["fill-rule", "evenodd", "d", "M14.354 1.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 1 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm-7.5 7.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z"], ["fill-rule", "evenodd", "d", "M2.036 9.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V10h-3.5a.5.5 0 0 1-.5-.5z"], [1, "dropdown-divider"], [1, "treeview-container"], [3, "config", "item", "template", "checkedChange", 4, "ngFor", "ngForOf"], [3, "config", "item", "template", "checkedChange"], [1, "treeview-text"]], template: function TreeviewComponent_Template(rf, ctx) { if (rf & 1) {
|
|
370
|
+
i0.ɵɵtemplate(0, TreeviewComponent_ng_template_0_Template, 6, 5, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
371
|
+
i0.ɵɵtemplate(2, TreeviewComponent_ng_template_2_Template, 2, 2, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
|
|
372
|
+
i0.ɵɵelementStart(4, "div", 2);
|
|
373
|
+
i0.ɵɵtemplate(5, TreeviewComponent_ng_template_5_Template, 0, 0, "ng-template", 3);
|
|
374
|
+
i0.ɵɵelementEnd();
|
|
375
|
+
i0.ɵɵelementStart(6, "div", 4);
|
|
376
|
+
i0.ɵɵtemplate(7, TreeviewComponent_div_7_Template, 2, 3, "div", 5);
|
|
377
|
+
i0.ɵɵtemplate(8, TreeviewComponent_div_8_Template, 2, 1, "div", 6);
|
|
378
|
+
i0.ɵɵelementEnd();
|
|
379
|
+
} if (rf & 2) {
|
|
380
|
+
const _r2 = i0.ɵɵreference(3);
|
|
381
|
+
i0.ɵɵadvance(5);
|
|
382
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx.headerTemplate || _r2)("ngTemplateOutletContext", ctx.headerTemplateContext);
|
|
383
|
+
i0.ɵɵadvance(1);
|
|
384
|
+
i0.ɵɵproperty("ngSwitch", ctx.hasFilterItems);
|
|
385
|
+
i0.ɵɵadvance(1);
|
|
386
|
+
i0.ɵɵproperty("ngSwitchCase", true);
|
|
387
|
+
i0.ɵɵadvance(1);
|
|
388
|
+
i0.ɵɵproperty("ngSwitchCase", false);
|
|
389
|
+
} }, dependencies: [i4.DefaultValueAccessor, i4.CheckboxControlValueAccessor, i4.NgControlStatus, i4.NgModel, i5.NgForOf, i5.NgIf, i5.NgTemplateOutlet, i5.NgSwitch, i5.NgSwitchCase, i6.TreeviewItemComponent], styles: ["[_nghost-%COMP%] .treeview-header[_ngcontent-%COMP%] .row-filter[_ngcontent-%COMP%]{margin-bottom:.5rem}[_nghost-%COMP%] .treeview-header[_ngcontent-%COMP%] .row-all[_ngcontent-%COMP%] .bi[_ngcontent-%COMP%]{cursor:pointer}[_nghost-%COMP%] .treeview-container[_ngcontent-%COMP%] .row-item[_ngcontent-%COMP%]{margin-bottom:.3rem;flex-wrap:nowrap}[_nghost-%COMP%] .treeview-container[_ngcontent-%COMP%] .row-item[_ngcontent-%COMP%] .bi[_ngcontent-%COMP%]{cursor:pointer;margin-right:.3rem}.treeview-container[_ngcontent-%COMP%]{overflow-y:auto;padding-right:.3rem}.treeview-text[_ngcontent-%COMP%]{padding:.3rem 0;white-space:nowrap}"] }); }
|
|
198
390
|
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treeview.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-treeview/components/treeview/treeview.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-treeview/components/treeview/treeview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, TemplateRef, OnInit } from '@angular/core';\nimport { isNil, includes } from 'lodash';\nimport { TreeviewI18n } from '../../models/treeview-i18n';\nimport { TreeviewItem, TreeviewSelection } from '../../models/treeview-item';\nimport { TreeviewConfig } from '../../models/treeview-config';\nimport { TreeviewHeaderTemplateContext } from '../../models/treeview-header-template-context';\nimport { TreeviewItemTemplateContext } from '../../models/treeview-item-template-context';\nimport { TreeviewHelper } from '../../helpers/treeview-helper';\nimport { TreeviewEventParser } from '../../helpers/treeview-event-parser';\n\nclass FilterTreeviewItem extends TreeviewItem {\n    private readonly refItem: TreeviewItem;\n    constructor(item: TreeviewItem) {\n        super({\n            text: item.text,\n            value: item.value,\n            disabled: item.disabled,\n            checked: item.checked,\n            collapsed: item.collapsed,\n            children: item.children,\n        });\n        this.refItem = item;\n    }\n\n    updateRefChecked(): void {\n        this.children.forEach((child) => {\n            if (child instanceof FilterTreeviewItem) {\n                child.updateRefChecked();\n            }\n        });\n\n        let refChecked = this.checked;\n        if (refChecked) {\n            for (const refChild of this.refItem.children) {\n                if (!refChild.checked) {\n                    refChecked = false;\n                    break;\n                }\n            }\n        }\n        this.refItem.checked = refChecked;\n    }\n}\n\n@Component({\n    selector: 'ngx-treeview',\n    templateUrl: './treeview.component.html',\n    styleUrls: ['./treeview.component.scss'],\n})\nexport class TreeviewComponent implements OnChanges, OnInit {\n    @Input() headerTemplate: TemplateRef<TreeviewHeaderTemplateContext>;\n    @Input() itemTemplate: TemplateRef<TreeviewItemTemplateContext>;\n    @Input() items: TreeviewItem[];\n    @Input() config: TreeviewConfig;\n    @Output() selectedChange = new EventEmitter<any[]>();\n    @Output() filterChange = new EventEmitter<string>();\n    headerTemplateContext: TreeviewHeaderTemplateContext;\n    allItem: TreeviewItem;\n    filterText = '';\n    filterItems: TreeviewItem[];\n    selection: TreeviewSelection;\n\n    constructor(\n        public i18n: TreeviewI18n,\n        private defaultConfig: TreeviewConfig,\n        private eventParser: TreeviewEventParser,\n    ) {\n        this.config = this.defaultConfig;\n        this.allItem = new TreeviewItem({ text: 'All', value: undefined });\n    }\n\n    get hasFilterItems(): boolean {\n        return !isNil(this.filterItems) && this.filterItems.length > 0;\n    }\n\n    get maxHeight(): string {\n        return `${this.config.maxHeight}`;\n    }\n\n    ngOnInit(): void {\n        this.createHeaderTemplateContext();\n        this.generateSelection();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const itemsSimpleChange = changes.items;\n        if (!isNil(itemsSimpleChange) && !isNil(this.items)) {\n            this.updateFilterItems();\n            this.updateCollapsedOfAll();\n            this.raiseSelectedChange();\n        }\n    }\n\n    onAllCollapseExpand(): void {\n        this.allItem.collapsed = !this.allItem.collapsed;\n        this.filterItems.forEach((item) => item.setCollapsedRecursive(this.allItem.collapsed));\n    }\n\n    onFilterTextChange(text: string): void {\n        this.filterText = text;\n        this.filterChange.emit(text);\n        this.updateFilterItems();\n    }\n\n    onAllCheckedChange(): void {\n        const checked = this.allItem.checked;\n        this.filterItems.forEach((item) => {\n            item.setCheckedRecursive(checked);\n            if (item instanceof FilterTreeviewItem) {\n                item.updateRefChecked();\n            }\n        });\n\n        this.raiseSelectedChange();\n    }\n\n    onItemCheckedChange(item: TreeviewItem, checked: boolean): void {\n        if (item instanceof FilterTreeviewItem) {\n            item.updateRefChecked();\n        }\n\n        this.updateCheckedOfAll();\n        this.raiseSelectedChange();\n    }\n\n    raiseSelectedChange(): void {\n        this.generateSelection();\n        const values = this.eventParser.getSelectedChange(this);\n        setTimeout(() => {\n            this.selectedChange.emit(values);\n        });\n    }\n\n    private createHeaderTemplateContext(): void {\n        this.headerTemplateContext = {\n            config: this.config,\n            item: this.allItem,\n            onCheckedChange: () => this.onAllCheckedChange(),\n            onCollapseExpand: () => this.onAllCollapseExpand(),\n            onFilterTextChange: (text) => this.onFilterTextChange(text),\n        };\n    }\n\n    private generateSelection(): void {\n        let checkedItems: TreeviewItem[] = [];\n        let uncheckedItems: TreeviewItem[] = [];\n        if (!isNil(this.items)) {\n            const selection = TreeviewHelper.concatSelection(this.items, checkedItems, uncheckedItems);\n            checkedItems = selection.checked;\n            uncheckedItems = selection.unchecked;\n        }\n\n        this.selection = {\n            checkedItems,\n            uncheckedItems,\n        };\n    }\n\n    private updateFilterItems(): void {\n        if (this.filterText !== '') {\n            const filterItems: TreeviewItem[] = [];\n            const filterText = this.filterText.toLowerCase();\n            this.items.forEach((item) => {\n                const newItem = this.filterItem(item, filterText);\n                if (!isNil(newItem)) {\n                    filterItems.push(newItem);\n                }\n            });\n            this.filterItems = filterItems;\n        } else {\n            this.filterItems = this.items;\n        }\n\n        this.updateCheckedOfAll();\n    }\n\n    private filterItem(item: TreeviewItem, filterText: string): TreeviewItem {\n        const isMatch = includes(item.text.toLowerCase(), filterText);\n        if (isMatch) {\n            return item;\n        } else {\n            if (!isNil(item.children)) {\n                const children: TreeviewItem[] = [];\n                item.children.forEach((child) => {\n                    const newChild = this.filterItem(child, filterText);\n                    if (!isNil(newChild)) {\n                        children.push(newChild);\n                    }\n                });\n                if (children.length > 0) {\n                    const newItem = new FilterTreeviewItem(item);\n                    newItem.collapsed = false;\n                    newItem.children = children;\n                    return newItem;\n                }\n            }\n        }\n\n        return undefined;\n    }\n\n    private updateCheckedOfAll(): void {\n        let itemChecked: boolean = null;\n        for (const filterItem of this.filterItems) {\n            if (itemChecked === null) {\n                itemChecked = filterItem.checked;\n            } else if (itemChecked !== filterItem.checked) {\n                itemChecked = undefined;\n                break;\n            }\n        }\n\n        if (itemChecked === null) {\n            itemChecked = false;\n        }\n\n        this.allItem.checked = itemChecked;\n    }\n\n    private updateCollapsedOfAll(): void {\n        let hasItemExpanded = false;\n        for (const filterItem of this.filterItems) {\n            if (!filterItem.collapsed) {\n                hasItemExpanded = true;\n                break;\n            }\n        }\n\n        this.allItem.collapsed = !hasItemExpanded;\n    }\n}\n","<ng-template #defaultItemTemplate let-item=\"item\" let-onCollapseExpand=\"onCollapseExpand\" let-onCheckedChange=\"onCheckedChange\">\n    <div class=\"form-inline row-item\">\n        <i *ngIf=\"item.children\" (click)=\"onCollapseExpand()\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n            <svg\n                *ngSwitchCase=\"true\"\n                width=\"0.8rem\"\n                height=\"0.8rem\"\n                viewBox=\"0 0 16 16\"\n                class=\"bi bi-caret-right-fill\"\n                fill=\"currentColor\"\n                xmlns=\"http://www.w3.org/2000/svg\">\n                <path\n                    d=\"M12.14 8.753l-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z\" />\n            </svg>\n            <svg\n                *ngSwitchCase=\"false\"\n                width=\"0.8rem\"\n                height=\"0.8rem\"\n                viewBox=\"0 0 16 16\"\n                class=\"bi bi-caret-down-fill\"\n                fill=\"currentColor\"\n                xmlns=\"http://www.w3.org/2000/svg\">\n                <path\n                    d=\"M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\" />\n            </svg>\n        </i>\n        <div class=\"form-check\">\n            <input\n                type=\"checkbox\"\n                class=\"form-check-input\"\n                [(ngModel)]=\"item.checked\"\n                (ngModelChange)=\"onCheckedChange()\"\n                [disabled]=\"item.disabled\"\n                [indeterminate]=\"item.indeterminate\" />\n            <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n                {{ item.text }}\n            </label>\n        </div>\n    </div>\n</ng-template>\n<ng-template\n    #defaultHeaderTemplate\n    let-config=\"config\"\n    let-item=\"item\"\n    let-onCollapseExpand=\"onCollapseExpand\"\n    let-onCheckedChange=\"onCheckedChange\"\n    let-onFilterTextChange=\"onFilterTextChange\">\n    <div *ngIf=\"config.hasFilter\" class=\"row row-filter\">\n        <div class=\"col-12\">\n            <input\n                class=\"form-control\"\n                type=\"text\"\n                [placeholder]=\"i18n.getFilterPlaceholder()\"\n                [(ngModel)]=\"filterText\"\n                (ngModelChange)=\"onFilterTextChange($event)\" />\n        </div>\n    </div>\n    <div *ngIf=\"hasFilterItems\">\n        <div *ngIf=\"config.hasAllCheckBox || config.hasCollapseExpand\" class=\"row row-all\">\n            <div class=\"col-12\">\n                <div class=\"form-check form-check-inline\" *ngIf=\"config.hasAllCheckBox\">\n                    <input\n                        type=\"checkbox\"\n                        class=\"form-check-input\"\n                        [(ngModel)]=\"item.checked\"\n                        (ngModelChange)=\"onCheckedChange()\"\n                        [indeterminate]=\"item.indeterminate\" />\n                    <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n                        {{ i18n.getAllCheckboxText() }}\n                    </label>\n                </div>\n                <label *ngIf=\"config.hasCollapseExpand\" class=\"float-right form-check-label\" (click)=\"onCollapseExpand()\">\n                    <i [title]=\"i18n.getTooltipCollapseExpandText(item.collapsed)\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n                        <svg\n                            *ngSwitchCase=\"true\"\n                            width=\"1em\"\n                            height=\"1em\"\n                            viewBox=\"0 0 16 16\"\n                            class=\"bi bi-arrows-angle-expand\"\n                            fill=\"currentColor\"\n                            xmlns=\"http://www.w3.org/2000/svg\">\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M1.5 10.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M6.354 9.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm8.5-8.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M10.036 1.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 1 1-1 0V2h-3.5a.5.5 0 0 1-.5-.5z\" />\n                        </svg>\n                        <svg\n                            *ngSwitchCase=\"false\"\n                            width=\"1em\"\n                            height=\"1em\"\n                            viewBox=\"0 0 16 16\"\n                            class=\"bi bi-arrows-angle-contract\"\n                            fill=\"currentColor\"\n                            xmlns=\"http://www.w3.org/2000/svg\">\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M9.5 2.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M14.354 1.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 1 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm-7.5 7.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M2.036 9.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V10h-3.5a.5.5 0 0 1-.5-.5z\" />\n                        </svg>\n                    </i>\n                </label>\n            </div>\n        </div>\n        <div *ngIf=\"config.hasDivider\" class=\"dropdown-divider\"></div>\n    </div>\n</ng-template>\n<div class=\"treeview-header\">\n    <ng-template [ngTemplateOutlet]=\"headerTemplate || defaultHeaderTemplate\" [ngTemplateOutletContext]=\"headerTemplateContext\">\n    </ng-template>\n</div>\n<div [ngSwitch]=\"hasFilterItems\">\n    <div *ngSwitchCase=\"true\" class=\"treeview-container\" [style.max-height.px]=\"maxHeight\">\n        <ngx-treeview-item\n            *ngFor=\"let item of filterItems\"\n            [config]=\"config\"\n            [item]=\"item\"\n            [template]=\"itemTemplate || defaultItemTemplate\"\n            (checkedChange)=\"onItemCheckedChange(item, $event)\">\n        </ngx-treeview-item>\n    </div>\n    <div *ngSwitchCase=\"false\" class=\"treeview-text\">\n        {{ i18n.getFilterNoItemsFoundText() }}\n    </div>\n</div>\n"]}
|
|
391
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeviewComponent, [{
|
|
392
|
+
type: Component,
|
|
393
|
+
args: [{ selector: 'ngx-treeview', template: "<ng-template #defaultItemTemplate let-item=\"item\" let-onCollapseExpand=\"onCollapseExpand\" let-onCheckedChange=\"onCheckedChange\">\n <div class=\"form-inline row-item\">\n <i *ngIf=\"item.children\" (click)=\"onCollapseExpand()\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n <svg\n *ngSwitchCase=\"true\"\n width=\"0.8rem\"\n height=\"0.8rem\"\n viewBox=\"0 0 16 16\"\n class=\"bi bi-caret-right-fill\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M12.14 8.753l-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z\" />\n </svg>\n <svg\n *ngSwitchCase=\"false\"\n width=\"0.8rem\"\n height=\"0.8rem\"\n viewBox=\"0 0 16 16\"\n class=\"bi bi-caret-down-fill\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\" />\n </svg>\n </i>\n <div class=\"form-check\">\n <input\n type=\"checkbox\"\n class=\"form-check-input\"\n [(ngModel)]=\"item.checked\"\n (ngModelChange)=\"onCheckedChange()\"\n [disabled]=\"item.disabled\"\n [indeterminate]=\"item.indeterminate\" />\n <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n {{ item.text }}\n </label>\n </div>\n </div>\n</ng-template>\n<ng-template\n #defaultHeaderTemplate\n let-config=\"config\"\n let-item=\"item\"\n let-onCollapseExpand=\"onCollapseExpand\"\n let-onCheckedChange=\"onCheckedChange\"\n let-onFilterTextChange=\"onFilterTextChange\">\n <div *ngIf=\"config.hasFilter\" class=\"row row-filter\">\n <div class=\"col-12\">\n <input\n class=\"form-control\"\n type=\"text\"\n [placeholder]=\"i18n.getFilterPlaceholder()\"\n [(ngModel)]=\"filterText\"\n (ngModelChange)=\"onFilterTextChange($event)\" />\n </div>\n </div>\n <div *ngIf=\"hasFilterItems\">\n <div *ngIf=\"config.hasAllCheckBox || config.hasCollapseExpand\" class=\"row row-all\">\n <div class=\"col-12\">\n <div class=\"form-check form-check-inline\" *ngIf=\"config.hasAllCheckBox\">\n <input\n type=\"checkbox\"\n class=\"form-check-input\"\n [(ngModel)]=\"item.checked\"\n (ngModelChange)=\"onCheckedChange()\"\n [indeterminate]=\"item.indeterminate\" />\n <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n {{ i18n.getAllCheckboxText() }}\n </label>\n </div>\n <label *ngIf=\"config.hasCollapseExpand\" class=\"float-right form-check-label\" (click)=\"onCollapseExpand()\">\n <i [title]=\"i18n.getTooltipCollapseExpandText(item.collapsed)\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n <svg\n *ngSwitchCase=\"true\"\n width=\"1em\"\n height=\"1em\"\n viewBox=\"0 0 16 16\"\n class=\"bi bi-arrows-angle-expand\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fill-rule=\"evenodd\"\n d=\"M1.5 10.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n <path\n fill-rule=\"evenodd\"\n d=\"M6.354 9.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm8.5-8.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n <path\n fill-rule=\"evenodd\"\n d=\"M10.036 1.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 1 1-1 0V2h-3.5a.5.5 0 0 1-.5-.5z\" />\n </svg>\n <svg\n *ngSwitchCase=\"false\"\n width=\"1em\"\n height=\"1em\"\n viewBox=\"0 0 16 16\"\n class=\"bi bi-arrows-angle-contract\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path\n fill-rule=\"evenodd\"\n d=\"M9.5 2.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n <path\n fill-rule=\"evenodd\"\n d=\"M14.354 1.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 1 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm-7.5 7.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n <path\n fill-rule=\"evenodd\"\n d=\"M2.036 9.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V10h-3.5a.5.5 0 0 1-.5-.5z\" />\n </svg>\n </i>\n </label>\n </div>\n </div>\n <div *ngIf=\"config.hasDivider\" class=\"dropdown-divider\"></div>\n </div>\n</ng-template>\n<div class=\"treeview-header\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate || defaultHeaderTemplate\" [ngTemplateOutletContext]=\"headerTemplateContext\">\n </ng-template>\n</div>\n<div [ngSwitch]=\"hasFilterItems\">\n <div *ngSwitchCase=\"true\" class=\"treeview-container\" [style.max-height.px]=\"maxHeight\">\n <ngx-treeview-item\n *ngFor=\"let item of filterItems\"\n [config]=\"config\"\n [item]=\"item\"\n [template]=\"itemTemplate || defaultItemTemplate\"\n (checkedChange)=\"onItemCheckedChange(item, $event)\">\n </ngx-treeview-item>\n </div>\n <div *ngSwitchCase=\"false\" class=\"treeview-text\">\n {{ i18n.getFilterNoItemsFoundText() }}\n </div>\n</div>\n", styles: [":host .treeview-header .row-filter{margin-bottom:.5rem}:host .treeview-header .row-all .bi{cursor:pointer}:host .treeview-container .row-item{margin-bottom:.3rem;flex-wrap:nowrap}:host .treeview-container .row-item .bi{cursor:pointer;margin-right:.3rem}.treeview-container{overflow-y:auto;padding-right:.3rem}.treeview-text{padding:.3rem 0;white-space:nowrap}\n"] }]
|
|
394
|
+
}], function () { return [{ type: i1.TreeviewI18n }, { type: i2.TreeviewConfig }, { type: i3.TreeviewEventParser }]; }, { headerTemplate: [{
|
|
395
|
+
type: Input
|
|
396
|
+
}], itemTemplate: [{
|
|
397
|
+
type: Input
|
|
398
|
+
}], items: [{
|
|
399
|
+
type: Input
|
|
400
|
+
}], config: [{
|
|
401
|
+
type: Input
|
|
402
|
+
}], selectedChange: [{
|
|
403
|
+
type: Output
|
|
404
|
+
}], filterChange: [{
|
|
405
|
+
type: Output
|
|
406
|
+
}] }); })();
|
|
407
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treeview.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-treeview/components/treeview/treeview.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-treeview/components/treeview/treeview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, SimpleChanges, OnChanges, TemplateRef, OnInit } from '@angular/core';\nimport { isNil, includes } from 'lodash';\nimport { TreeviewI18n } from '../../models/treeview-i18n';\nimport { TreeviewItem, TreeviewSelection } from '../../models/treeview-item';\nimport { TreeviewConfig } from '../../models/treeview-config';\nimport { TreeviewHeaderTemplateContext } from '../../models/treeview-header-template-context';\nimport { TreeviewItemTemplateContext } from '../../models/treeview-item-template-context';\nimport { TreeviewHelper } from '../../helpers/treeview-helper';\nimport { TreeviewEventParser } from '../../helpers/treeview-event-parser';\n\nclass FilterTreeviewItem extends TreeviewItem {\n    private readonly refItem: TreeviewItem;\n    constructor(item: TreeviewItem) {\n        super({\n            text: item.text,\n            value: item.value,\n            disabled: item.disabled,\n            checked: item.checked,\n            collapsed: item.collapsed,\n            children: item.children,\n        });\n        this.refItem = item;\n    }\n\n    updateRefChecked(): void {\n        this.children.forEach((child) => {\n            if (child instanceof FilterTreeviewItem) {\n                child.updateRefChecked();\n            }\n        });\n\n        let refChecked = this.checked;\n        if (refChecked) {\n            for (const refChild of this.refItem.children) {\n                if (!refChild.checked) {\n                    refChecked = false;\n                    break;\n                }\n            }\n        }\n        this.refItem.checked = refChecked;\n    }\n}\n\n@Component({\n    selector: 'ngx-treeview',\n    templateUrl: './treeview.component.html',\n    styleUrls: ['./treeview.component.scss'],\n})\nexport class TreeviewComponent implements OnChanges, OnInit {\n    @Input() headerTemplate: TemplateRef<TreeviewHeaderTemplateContext>;\n    @Input() itemTemplate: TemplateRef<TreeviewItemTemplateContext>;\n    @Input() items: TreeviewItem[];\n    @Input() config: TreeviewConfig;\n    @Output() selectedChange = new EventEmitter<any[]>();\n    @Output() filterChange = new EventEmitter<string>();\n    headerTemplateContext: TreeviewHeaderTemplateContext;\n    allItem: TreeviewItem;\n    filterText = '';\n    filterItems: TreeviewItem[];\n    selection: TreeviewSelection;\n\n    constructor(\n        public i18n: TreeviewI18n,\n        private defaultConfig: TreeviewConfig,\n        private eventParser: TreeviewEventParser,\n    ) {\n        this.config = this.defaultConfig;\n        this.allItem = new TreeviewItem({ text: 'All', value: undefined });\n    }\n\n    get hasFilterItems(): boolean {\n        return !isNil(this.filterItems) && this.filterItems.length > 0;\n    }\n\n    get maxHeight(): string {\n        return `${this.config.maxHeight}`;\n    }\n\n    ngOnInit(): void {\n        this.createHeaderTemplateContext();\n        this.generateSelection();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const itemsSimpleChange = changes.items;\n        if (!isNil(itemsSimpleChange) && !isNil(this.items)) {\n            this.updateFilterItems();\n            this.updateCollapsedOfAll();\n            this.raiseSelectedChange();\n        }\n    }\n\n    onAllCollapseExpand(): void {\n        this.allItem.collapsed = !this.allItem.collapsed;\n        this.filterItems.forEach((item) => item.setCollapsedRecursive(this.allItem.collapsed));\n    }\n\n    onFilterTextChange(text: string): void {\n        this.filterText = text;\n        this.filterChange.emit(text);\n        this.updateFilterItems();\n    }\n\n    onAllCheckedChange(): void {\n        const checked = this.allItem.checked;\n        this.filterItems.forEach((item) => {\n            item.setCheckedRecursive(checked);\n            if (item instanceof FilterTreeviewItem) {\n                item.updateRefChecked();\n            }\n        });\n\n        this.raiseSelectedChange();\n    }\n\n    onItemCheckedChange(item: TreeviewItem, checked: boolean): void {\n        if (item instanceof FilterTreeviewItem) {\n            item.updateRefChecked();\n        }\n\n        this.updateCheckedOfAll();\n        this.raiseSelectedChange();\n    }\n\n    raiseSelectedChange(): void {\n        this.generateSelection();\n        const values = this.eventParser.getSelectedChange(this);\n        setTimeout(() => {\n            this.selectedChange.emit(values);\n        });\n    }\n\n    private createHeaderTemplateContext(): void {\n        this.headerTemplateContext = {\n            config: this.config,\n            item: this.allItem,\n            onCheckedChange: () => this.onAllCheckedChange(),\n            onCollapseExpand: () => this.onAllCollapseExpand(),\n            onFilterTextChange: (text) => this.onFilterTextChange(text),\n        };\n    }\n\n    private generateSelection(): void {\n        let checkedItems: TreeviewItem[] = [];\n        let uncheckedItems: TreeviewItem[] = [];\n        if (!isNil(this.items)) {\n            const selection = TreeviewHelper.concatSelection(this.items, checkedItems, uncheckedItems);\n            checkedItems = selection.checked;\n            uncheckedItems = selection.unchecked;\n        }\n\n        this.selection = {\n            checkedItems,\n            uncheckedItems,\n        };\n    }\n\n    private updateFilterItems(): void {\n        if (this.filterText !== '') {\n            const filterItems: TreeviewItem[] = [];\n            const filterText = this.filterText.toLowerCase();\n            this.items.forEach((item) => {\n                const newItem = this.filterItem(item, filterText);\n                if (!isNil(newItem)) {\n                    filterItems.push(newItem);\n                }\n            });\n            this.filterItems = filterItems;\n        } else {\n            this.filterItems = this.items;\n        }\n\n        this.updateCheckedOfAll();\n    }\n\n    private filterItem(item: TreeviewItem, filterText: string): TreeviewItem {\n        const isMatch = includes(item.text.toLowerCase(), filterText);\n        if (isMatch) {\n            return item;\n        } else {\n            if (!isNil(item.children)) {\n                const children: TreeviewItem[] = [];\n                item.children.forEach((child) => {\n                    const newChild = this.filterItem(child, filterText);\n                    if (!isNil(newChild)) {\n                        children.push(newChild);\n                    }\n                });\n                if (children.length > 0) {\n                    const newItem = new FilterTreeviewItem(item);\n                    newItem.collapsed = false;\n                    newItem.children = children;\n                    return newItem;\n                }\n            }\n        }\n\n        return undefined;\n    }\n\n    private updateCheckedOfAll(): void {\n        let itemChecked: boolean = null;\n        for (const filterItem of this.filterItems) {\n            if (itemChecked === null) {\n                itemChecked = filterItem.checked;\n            } else if (itemChecked !== filterItem.checked) {\n                itemChecked = undefined;\n                break;\n            }\n        }\n\n        if (itemChecked === null) {\n            itemChecked = false;\n        }\n\n        this.allItem.checked = itemChecked;\n    }\n\n    private updateCollapsedOfAll(): void {\n        let hasItemExpanded = false;\n        for (const filterItem of this.filterItems) {\n            if (!filterItem.collapsed) {\n                hasItemExpanded = true;\n                break;\n            }\n        }\n\n        this.allItem.collapsed = !hasItemExpanded;\n    }\n}\n","<ng-template #defaultItemTemplate let-item=\"item\" let-onCollapseExpand=\"onCollapseExpand\" let-onCheckedChange=\"onCheckedChange\">\n    <div class=\"form-inline row-item\">\n        <i *ngIf=\"item.children\" (click)=\"onCollapseExpand()\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n            <svg\n                *ngSwitchCase=\"true\"\n                width=\"0.8rem\"\n                height=\"0.8rem\"\n                viewBox=\"0 0 16 16\"\n                class=\"bi bi-caret-right-fill\"\n                fill=\"currentColor\"\n                xmlns=\"http://www.w3.org/2000/svg\">\n                <path\n                    d=\"M12.14 8.753l-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 0 1 1.659-.753l5.48 4.796a1 1 0 0 1 0 1.506z\" />\n            </svg>\n            <svg\n                *ngSwitchCase=\"false\"\n                width=\"0.8rem\"\n                height=\"0.8rem\"\n                viewBox=\"0 0 16 16\"\n                class=\"bi bi-caret-down-fill\"\n                fill=\"currentColor\"\n                xmlns=\"http://www.w3.org/2000/svg\">\n                <path\n                    d=\"M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\" />\n            </svg>\n        </i>\n        <div class=\"form-check\">\n            <input\n                type=\"checkbox\"\n                class=\"form-check-input\"\n                [(ngModel)]=\"item.checked\"\n                (ngModelChange)=\"onCheckedChange()\"\n                [disabled]=\"item.disabled\"\n                [indeterminate]=\"item.indeterminate\" />\n            <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n                {{ item.text }}\n            </label>\n        </div>\n    </div>\n</ng-template>\n<ng-template\n    #defaultHeaderTemplate\n    let-config=\"config\"\n    let-item=\"item\"\n    let-onCollapseExpand=\"onCollapseExpand\"\n    let-onCheckedChange=\"onCheckedChange\"\n    let-onFilterTextChange=\"onFilterTextChange\">\n    <div *ngIf=\"config.hasFilter\" class=\"row row-filter\">\n        <div class=\"col-12\">\n            <input\n                class=\"form-control\"\n                type=\"text\"\n                [placeholder]=\"i18n.getFilterPlaceholder()\"\n                [(ngModel)]=\"filterText\"\n                (ngModelChange)=\"onFilterTextChange($event)\" />\n        </div>\n    </div>\n    <div *ngIf=\"hasFilterItems\">\n        <div *ngIf=\"config.hasAllCheckBox || config.hasCollapseExpand\" class=\"row row-all\">\n            <div class=\"col-12\">\n                <div class=\"form-check form-check-inline\" *ngIf=\"config.hasAllCheckBox\">\n                    <input\n                        type=\"checkbox\"\n                        class=\"form-check-input\"\n                        [(ngModel)]=\"item.checked\"\n                        (ngModelChange)=\"onCheckedChange()\"\n                        [indeterminate]=\"item.indeterminate\" />\n                    <label class=\"form-check-label\" (click)=\"item.checked = !item.checked; onCheckedChange()\">\n                        {{ i18n.getAllCheckboxText() }}\n                    </label>\n                </div>\n                <label *ngIf=\"config.hasCollapseExpand\" class=\"float-right form-check-label\" (click)=\"onCollapseExpand()\">\n                    <i [title]=\"i18n.getTooltipCollapseExpandText(item.collapsed)\" aria-hidden=\"true\" [ngSwitch]=\"item.collapsed\">\n                        <svg\n                            *ngSwitchCase=\"true\"\n                            width=\"1em\"\n                            height=\"1em\"\n                            viewBox=\"0 0 16 16\"\n                            class=\"bi bi-arrows-angle-expand\"\n                            fill=\"currentColor\"\n                            xmlns=\"http://www.w3.org/2000/svg\">\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M1.5 10.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M6.354 9.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm8.5-8.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M10.036 1.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 1 1-1 0V2h-3.5a.5.5 0 0 1-.5-.5z\" />\n                        </svg>\n                        <svg\n                            *ngSwitchCase=\"false\"\n                            width=\"1em\"\n                            height=\"1em\"\n                            viewBox=\"0 0 16 16\"\n                            class=\"bi bi-arrows-angle-contract\"\n                            fill=\"currentColor\"\n                            xmlns=\"http://www.w3.org/2000/svg\">\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M9.5 2.036a.5.5 0 0 1 .5.5v3.5h3.5a.5.5 0 0 1 0 1h-4a.5.5 0 0 1-.5-.5v-4a.5.5 0 0 1 .5-.5z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M14.354 1.646a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 1 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0zm-7.5 7.5a.5.5 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708l4.5-4.5a.5.5 0 0 1 .708 0z\" />\n                            <path\n                                fill-rule=\"evenodd\"\n                                d=\"M2.036 9.5a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-1 0V10h-3.5a.5.5 0 0 1-.5-.5z\" />\n                        </svg>\n                    </i>\n                </label>\n            </div>\n        </div>\n        <div *ngIf=\"config.hasDivider\" class=\"dropdown-divider\"></div>\n    </div>\n</ng-template>\n<div class=\"treeview-header\">\n    <ng-template [ngTemplateOutlet]=\"headerTemplate || defaultHeaderTemplate\" [ngTemplateOutletContext]=\"headerTemplateContext\">\n    </ng-template>\n</div>\n<div [ngSwitch]=\"hasFilterItems\">\n    <div *ngSwitchCase=\"true\" class=\"treeview-container\" [style.max-height.px]=\"maxHeight\">\n        <ngx-treeview-item\n            *ngFor=\"let item of filterItems\"\n            [config]=\"config\"\n            [item]=\"item\"\n            [template]=\"itemTemplate || defaultItemTemplate\"\n            (checkedChange)=\"onItemCheckedChange(item, $event)\">\n        </ngx-treeview-item>\n    </div>\n    <div *ngSwitchCase=\"false\" class=\"treeview-text\">\n        {{ i18n.getFilterNoItemsFoundText() }}\n    </div>\n</div>\n"]}
|
|
@@ -5,6 +5,39 @@ import { TreeviewConfig } from '../../models/treeview-config';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../../models/treeview-config";
|
|
7
7
|
import * as i2 from "@angular/common";
|
|
8
|
+
function TreeviewItemComponent_div_0_ng_template_1_Template(rf, ctx) { }
|
|
9
|
+
function TreeviewItemComponent_div_0_div_2_ngx_treeview_item_1_Template(rf, ctx) { if (rf & 1) {
|
|
10
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
11
|
+
i0.ɵɵelementStart(0, "ngx-treeview-item", 5);
|
|
12
|
+
i0.ɵɵlistener("checkedChange", function TreeviewItemComponent_div_0_div_2_ngx_treeview_item_1_Template_ngx_treeview_item_checkedChange_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r6); const child_r4 = restoredCtx.$implicit; const ctx_r5 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r5.onChildCheckedChange(child_r4, $event)); });
|
|
13
|
+
i0.ɵɵelementEnd();
|
|
14
|
+
} if (rf & 2) {
|
|
15
|
+
const child_r4 = ctx.$implicit;
|
|
16
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
17
|
+
i0.ɵɵproperty("config", ctx_r3.config)("item", child_r4)("template", ctx_r3.template);
|
|
18
|
+
} }
|
|
19
|
+
function TreeviewItemComponent_div_0_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
20
|
+
i0.ɵɵelementStart(0, "div");
|
|
21
|
+
i0.ɵɵtemplate(1, TreeviewItemComponent_div_0_div_2_ngx_treeview_item_1_Template, 1, 3, "ngx-treeview-item", 4);
|
|
22
|
+
i0.ɵɵelementEnd();
|
|
23
|
+
} if (rf & 2) {
|
|
24
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
25
|
+
i0.ɵɵadvance(1);
|
|
26
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.item.children);
|
|
27
|
+
} }
|
|
28
|
+
const _c0 = function (a0, a1, a2) { return { item: a0, onCollapseExpand: a1, onCheckedChange: a2 }; };
|
|
29
|
+
function TreeviewItemComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
30
|
+
i0.ɵɵelementStart(0, "div", 1);
|
|
31
|
+
i0.ɵɵtemplate(1, TreeviewItemComponent_div_0_ng_template_1_Template, 0, 0, "ng-template", 2);
|
|
32
|
+
i0.ɵɵtemplate(2, TreeviewItemComponent_div_0_div_2_Template, 2, 1, "div", 3);
|
|
33
|
+
i0.ɵɵelementEnd();
|
|
34
|
+
} if (rf & 2) {
|
|
35
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
36
|
+
i0.ɵɵadvance(1);
|
|
37
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.template)("ngTemplateOutletContext", i0.ɵɵpureFunction3(3, _c0, ctx_r0.item, ctx_r0.onCollapseExpand, ctx_r0.onCheckedChange));
|
|
38
|
+
i0.ɵɵadvance(1);
|
|
39
|
+
i0.ɵɵproperty("ngIf", !ctx_r0.item.collapsed);
|
|
40
|
+
} }
|
|
8
41
|
export class TreeviewItemComponent {
|
|
9
42
|
constructor(defaultConfig) {
|
|
10
43
|
this.defaultConfig = defaultConfig;
|
|
@@ -42,19 +75,23 @@ export class TreeviewItemComponent {
|
|
|
42
75
|
}
|
|
43
76
|
this.checkedChange.emit(checked);
|
|
44
77
|
}
|
|
45
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
46
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵ
|
|
78
|
+
/** @nocollapse */ static { this.ɵfac = function TreeviewItemComponent_Factory(t) { return new (t || TreeviewItemComponent)(i0.ɵɵdirectiveInject(i1.TreeviewConfig)); }; }
|
|
79
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TreeviewItemComponent, selectors: [["ngx-treeview-item"]], inputs: { config: "config", template: "template", item: "item" }, outputs: { checkedChange: "checkedChange" }, decls: 1, vars: 1, consts: [["class", "treeview-item", 4, "ngIf"], [1, "treeview-item"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [4, "ngIf"], [3, "config", "item", "template", "checkedChange", 4, "ngFor", "ngForOf"], [3, "config", "item", "template", "checkedChange"]], template: function TreeviewItemComponent_Template(rf, ctx) { if (rf & 1) {
|
|
80
|
+
i0.ɵɵtemplate(0, TreeviewItemComponent_div_0_Template, 3, 7, "div", 0);
|
|
81
|
+
} if (rf & 2) {
|
|
82
|
+
i0.ɵɵproperty("ngIf", ctx.item);
|
|
83
|
+
} }, dependencies: [i2.NgForOf, i2.NgIf, i2.NgTemplateOutlet, TreeviewItemComponent], styles: ["[_nghost-%COMP%]{display:block}[_nghost-%COMP%] .treeview-item[_ngcontent-%COMP%]{white-space:nowrap}[_nghost-%COMP%] .treeview-item[_ngcontent-%COMP%] .treeview-item[_ngcontent-%COMP%]{margin-left:2rem}"] }); }
|
|
47
84
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TreeviewItemComponent, [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{ selector: 'ngx-treeview-item', template: "<div *ngIf=\"item\" class=\"treeview-item\">\n <ng-template\n [ngTemplateOutlet]=\"template\"\n [ngTemplateOutletContext]=\"{ item: item, onCollapseExpand: onCollapseExpand, onCheckedChange: onCheckedChange }\">\n </ng-template>\n <div *ngIf=\"!item.collapsed\">\n <ngx-treeview-item\n [config]=\"config\"\n *ngFor=\"let child of item.children\"\n [item]=\"child\"\n [template]=\"template\"\n (checkedChange)=\"onChildCheckedChange(child, $event)\">\n </ngx-treeview-item>\n </div>\n</div>\n", styles: [":host{display:block}:host .treeview-item{white-space:nowrap}:host .treeview-item .treeview-item{margin-left:2rem}\n"] }]
|
|
88
|
+
}], function () { return [{ type: i1.TreeviewConfig }]; }, { config: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], template: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], item: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], checkedChange: [{
|
|
95
|
+
type: Output
|
|
96
|
+
}] }); })();
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZXZpZXctaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10cmVldmlldy9jb21wb25lbnRzL3RyZWV2aWV3LWl0ZW0vdHJlZXZpZXctaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10cmVldmlldy9jb21wb25lbnRzL3RyZWV2aWV3LWl0ZW0vdHJlZXZpZXctaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7SUNHdEQsNENBSzBEO0lBQXRELDBSQUFpQixlQUFBLDZDQUFtQyxDQUFBLElBQUM7SUFDekQsaUJBQW9COzs7O0lBTGhCLHNDQUFpQixrQkFBQSw2QkFBQTs7O0lBRnpCLDJCQUE2QjtJQUN6Qiw4R0FNb0I7SUFDeEIsaUJBQU07OztJQUxvQixlQUFnQjtJQUFoQiw4Q0FBZ0I7Ozs7SUFSOUMsOEJBQXdDO0lBQ3BDLDRGQUdjO0lBQ2QsNEVBUU07SUFDVixpQkFBTTs7O0lBWkUsZUFBNkI7SUFBN0Isa0RBQTZCLHFIQUFBO0lBRzNCLGVBQXFCO0lBQXJCLDZDQUFxQjs7QURNL0IsTUFBTSxPQUFPLHFCQUFxQjtJQU05QixZQUFvQixhQUE2QjtRQUE3QixrQkFBYSxHQUFiLGFBQWEsQ0FBZ0I7UUFGdkMsa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBTXRELHFCQUFnQixHQUFHLEdBQUcsRUFBRTtZQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQy9DLENBQUMsQ0FBQztRQUVGLG9CQUFlLEdBQUcsR0FBRyxFQUFFO1lBQ25CLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsdUJBQXVCLEVBQUU7Z0JBQ3BFLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7YUFDN0U7WUFDRCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNyQyxDQUFDLENBQUM7UUFiRSxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDckMsQ0FBQztJQWNELG9CQUFvQixDQUFDLEtBQW1CLEVBQUUsT0FBZ0I7UUFDdEQsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsdUJBQXVCLEVBQUU7WUFDdEMsSUFBSSxXQUFXLEdBQVksSUFBSSxDQUFDO1lBQ2hDLEtBQUssTUFBTSxTQUFTLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3hDLElBQUksV0FBVyxLQUFLLElBQUksRUFBRTtvQkFDdEIsV0FBVyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUM7aUJBQ25DO3FCQUFNLElBQUksV0FBVyxLQUFLLFNBQVMsQ0FBQyxPQUFPLEVBQUU7b0JBQzFDLFdBQVcsR0FBRyxTQUFTLENBQUM7b0JBQ3hCLE1BQU07aUJBQ1Q7YUFDSjtZQUVELElBQUksV0FBVyxLQUFLLElBQUksRUFBRTtnQkFDdEIsV0FBVyxHQUFHLEtBQUssQ0FBQzthQUN2QjtZQUVELElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEtBQUssV0FBVyxFQUFFO2dCQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxXQUFXLENBQUM7YUFDbkM7U0FDSjtRQUVELElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3JDLENBQUM7eUdBNUNRLHFCQUFxQjttR0FBckIscUJBQXFCO1lDWGxDLHNFQWNNOztZQWRBLCtCQUFVO3NFRFdILHFCQUFxQjs7dUZBQXJCLHFCQUFxQjtjQUxqQyxTQUFTOzJCQUNJLG1CQUFtQjtpRUFLcEIsTUFBTTtrQkFBZCxLQUFLO1lBQ0csUUFBUTtrQkFBaEIsS0FBSztZQUNHLElBQUk7a0JBQVosS0FBSztZQUNJLGFBQWE7a0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzTmlsIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IFRyZWV2aWV3SXRlbSB9IGZyb20gJy4uLy4uL21vZGVscy90cmVldmlldy1pdGVtJztcbmltcG9ydCB7IFRyZWV2aWV3Q29uZmlnIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3RyZWV2aWV3LWNvbmZpZyc7XG5pbXBvcnQgeyBUcmVldmlld0l0ZW1UZW1wbGF0ZUNvbnRleHQgfSBmcm9tICcuLi8uLi9tb2RlbHMvdHJlZXZpZXctaXRlbS10ZW1wbGF0ZS1jb250ZXh0JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduZ3gtdHJlZXZpZXctaXRlbScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RyZWV2aWV3LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3RyZWV2aWV3LWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgVHJlZXZpZXdJdGVtQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBjb25maWc6IFRyZWV2aWV3Q29uZmlnO1xuICAgIEBJbnB1dCgpIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxUcmVldmlld0l0ZW1UZW1wbGF0ZUNvbnRleHQ+O1xuICAgIEBJbnB1dCgpIGl0ZW06IFRyZWV2aWV3SXRlbTtcbiAgICBAT3V0cHV0KCkgY2hlY2tlZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZGVmYXVsdENvbmZpZzogVHJlZXZpZXdDb25maWcpIHtcbiAgICAgICAgdGhpcy5jb25maWcgPSB0aGlzLmRlZmF1bHRDb25maWc7XG4gICAgfVxuXG4gICAgb25Db2xsYXBzZUV4cGFuZCA9ICgpID0+IHtcbiAgICAgICAgdGhpcy5pdGVtLmNvbGxhcHNlZCA9ICF0aGlzLml0ZW0uY29sbGFwc2VkO1xuICAgIH07XG5cbiAgICBvbkNoZWNrZWRDaGFuZ2UgPSAoKSA9PiB7XG4gICAgICAgIGNvbnN0IGNoZWNrZWQgPSB0aGlzLml0ZW0uY2hlY2tlZDtcbiAgICAgICAgaWYgKCFpc05pbCh0aGlzLml0ZW0uY2hpbGRyZW4pICYmICF0aGlzLmNvbmZpZy5kZWNvdXBsZUNoaWxkRnJvbVBhcmVudCkge1xuICAgICAgICAgICAgdGhpcy5pdGVtLmNoaWxkcmVuLmZvckVhY2goKGNoaWxkKSA9PiBjaGlsZC5zZXRDaGVja2VkUmVjdXJzaXZlKGNoZWNrZWQpKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmNoZWNrZWRDaGFuZ2UuZW1pdChjaGVja2VkKTtcbiAgICB9O1xuXG4gICAgb25DaGlsZENoZWNrZWRDaGFuZ2UoY2hpbGQ6IFRyZWV2aWV3SXRlbSwgY2hlY2tlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuY29uZmlnLmRlY291cGxlQ2hpbGRGcm9tUGFyZW50KSB7XG4gICAgICAgICAgICBsZXQgaXRlbUNoZWNrZWQ6IGJvb2xlYW4gPSBudWxsO1xuICAgICAgICAgICAgZm9yIChjb25zdCBjaGlsZEl0ZW0gb2YgdGhpcy5pdGVtLmNoaWxkcmVuKSB7XG4gICAgICAgICAgICAgICAgaWYgKGl0ZW1DaGVja2VkID09PSBudWxsKSB7XG4gICAgICAgICAgICAgICAgICAgIGl0ZW1DaGVja2VkID0gY2hpbGRJdGVtLmNoZWNrZWQ7XG4gICAgICAgICAgICAgICAgfSBlbHNlIGlmIChpdGVtQ2hlY2tlZCAhPT0gY2hpbGRJdGVtLmNoZWNrZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgaXRlbUNoZWNrZWQgPSB1bmRlZmluZWQ7XG4gICAgICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKGl0ZW1DaGVja2VkID09PSBudWxsKSB7XG4gICAgICAgICAgICAgICAgaXRlbUNoZWNrZWQgPSBmYWxzZTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKHRoaXMuaXRlbS5jaGVja2VkICE9PSBpdGVtQ2hlY2tlZCkge1xuICAgICAgICAgICAgICAgIHRoaXMuaXRlbS5jaGVja2VkID0gaXRlbUNoZWNrZWQ7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNoZWNrZWRDaGFuZ2UuZW1pdChjaGVja2VkKTtcbiAgICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiaXRlbVwiIGNsYXNzPVwidHJlZXZpZXctaXRlbVwiPlxuICAgIDxuZy10ZW1wbGF0ZVxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldF09XCJ0ZW1wbGF0ZVwiXG4gICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7IGl0ZW06IGl0ZW0sIG9uQ29sbGFwc2VFeHBhbmQ6IG9uQ29sbGFwc2VFeHBhbmQsIG9uQ2hlY2tlZENoYW5nZTogb25DaGVja2VkQ2hhbmdlIH1cIj5cbiAgICA8L25nLXRlbXBsYXRlPlxuICAgIDxkaXYgKm5nSWY9XCIhaXRlbS5jb2xsYXBzZWRcIj5cbiAgICAgICAgPG5neC10cmVldmlldy1pdGVtXG4gICAgICAgICAgICBbY29uZmlnXT1cImNvbmZpZ1wiXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgY2hpbGQgb2YgaXRlbS5jaGlsZHJlblwiXG4gICAgICAgICAgICBbaXRlbV09XCJjaGlsZFwiXG4gICAgICAgICAgICBbdGVtcGxhdGVdPVwidGVtcGxhdGVcIlxuICAgICAgICAgICAgKGNoZWNrZWRDaGFuZ2UpPVwib25DaGlsZENoZWNrZWRDaGFuZ2UoY2hpbGQsICRldmVudClcIj5cbiAgICAgICAgPC9uZ3gtdHJlZXZpZXctaXRlbT5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
|