@datarailsshared/datarailsshared 1.5.393 → 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.
Files changed (142) hide show
  1. package/datarailsshared-datarailsshared-1.5.397.tgz +0 -0
  2. package/esm2022/lib/date-tags/any-tag.component.mjs +18 -18
  3. package/esm2022/lib/date-tags/date-tag.component.mjs +99 -23
  4. package/esm2022/lib/date-tags/date-tag.module.mjs +27 -26
  5. package/esm2022/lib/date-tags/day-tag/day-tag.component.mjs +40 -26
  6. package/esm2022/lib/date-tags/forecast-tag/forecast-tag.component.mjs +43 -25
  7. package/esm2022/lib/date-tags/month-tag/month-tag.component.mjs +40 -26
  8. package/esm2022/lib/date-tags/quarter-tag/quarter-tag.component.mjs +26 -12
  9. package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +40 -26
  10. package/esm2022/lib/date-tags/year-tag/year-tag.component.mjs +40 -26
  11. package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +16 -16
  12. package/esm2022/lib/directives/click-outside/click-outside.module.mjs +13 -12
  13. package/esm2022/lib/dr-accordion/accordion-item-body.component.mjs +18 -15
  14. package/esm2022/lib/dr-accordion/accordion-item-header.component.mjs +71 -54
  15. package/esm2022/lib/dr-accordion/accordion-item.component.mjs +37 -32
  16. package/esm2022/lib/dr-accordion/accordion.component.mjs +15 -10
  17. package/esm2022/lib/dr-accordion/accordion.module.mjs +20 -19
  18. package/esm2022/lib/dr-alert/dr-alert.component.mjs +44 -16
  19. package/esm2022/lib/dr-alert/dr-alert.module.mjs +14 -13
  20. package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +98 -23
  21. package/esm2022/lib/dr-avatar/dr-avatar.module.mjs +13 -12
  22. package/esm2022/lib/dr-avatar/dr-avatar.pipe.mjs +9 -9
  23. package/esm2022/lib/dr-badge-status/dr-badge-status.component.mjs +43 -17
  24. package/esm2022/lib/dr-badge-status/dr-badge-status.module.mjs +14 -13
  25. package/esm2022/lib/dr-chat/chat.component.mjs +115 -38
  26. package/esm2022/lib/dr-chat/chat.module.mjs +27 -26
  27. package/esm2022/lib/dr-chat/dr-chat-alert/dr-chat-alert.component.mjs +21 -11
  28. package/esm2022/lib/dr-chat/dr-chat-form/chat-form.component.mjs +128 -37
  29. package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +126 -41
  30. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.directive.mjs +11 -11
  31. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.service.mjs +6 -6
  32. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +40 -11
  33. package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-text/chat-message-text.component.mjs +22 -9
  34. package/esm2022/lib/dr-chat/dr-chat-suggestions/chat-suggestions.component.mjs +86 -20
  35. package/esm2022/lib/dr-chat/dr-dot-flashing/dr-dot-flashing.component.mjs +9 -7
  36. package/esm2022/lib/dr-chip/dr-chip.component.mjs +49 -15
  37. package/esm2022/lib/dr-code-editor/components/code-editor-hint-wrapper.component.mjs +14 -10
  38. package/esm2022/lib/dr-code-editor/components/dr-codemirror.component.mjs +62 -57
  39. package/esm2022/lib/dr-code-editor/dr-code-editor.component.mjs +48 -20
  40. package/esm2022/lib/dr-code-editor/dr-code-editor.module.mjs +14 -13
  41. package/esm2022/lib/dr-details-list/dr-details-list.component.mjs +69 -41
  42. package/esm2022/lib/dr-details-list/dr-details-list.module.mjs +14 -13
  43. package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +265 -13
  44. package/esm2022/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.mjs +154 -16
  45. package/esm2022/lib/dr-dialog/dialog.module.mjs +14 -13
  46. package/esm2022/lib/dr-dialog/services/dialog.service.mjs +9 -9
  47. package/esm2022/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.mjs +29 -0
  48. package/esm2022/lib/dr-dropdown/dr-dropdown-item-show.pipe.mjs +9 -9
  49. package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +175 -56
  50. package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +98 -87
  51. package/esm2022/lib/dr-dropdown/dr-dropdown.module.mjs +32 -15
  52. package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +55 -18
  53. package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.component.mjs +92 -25
  54. package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.module.mjs +13 -12
  55. package/esm2022/lib/dr-error/dr-error.component.mjs +48 -24
  56. package/esm2022/lib/dr-error/dr-error.module.mjs +14 -13
  57. package/esm2022/lib/dr-inputs/button/button.component.mjs +88 -45
  58. package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +53 -28
  59. package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +32 -32
  60. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +67 -42
  61. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.mjs +72 -32
  62. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +111 -42
  63. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +99 -10
  64. package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +9 -9
  65. package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +6 -6
  66. package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +168 -84
  67. package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +64 -63
  68. package/esm2022/lib/dr-inputs/dr-link/dr-link.component.mjs +26 -16
  69. package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +13 -13
  70. package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +243 -104
  71. package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +77 -20
  72. package/esm2022/lib/dr-inputs/dr-slider/dr-slider.component.mjs +23 -17
  73. package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +64 -22
  74. package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +53 -21
  75. package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +40 -28
  76. package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +51 -41
  77. package/esm2022/lib/dr-layout/dr-layout-body.component.mjs +14 -10
  78. package/esm2022/lib/dr-layout/dr-layout-header.component.mjs +16 -14
  79. package/esm2022/lib/dr-layout/dr-layout.component.mjs +16 -7
  80. package/esm2022/lib/dr-layout/dr-layout.module.mjs +13 -12
  81. package/esm2022/lib/dr-popover/dr-popover-ref.mjs +4 -1
  82. package/esm2022/lib/dr-popover/dr-popover.component.mjs +71 -40
  83. package/esm2022/lib/dr-popover/dr-popover.directive.mjs +51 -49
  84. package/esm2022/lib/dr-popover/dr-popover.module.mjs +13 -12
  85. package/esm2022/lib/dr-popover/dr-popover.service.mjs +25 -13
  86. package/esm2022/lib/dr-scenario/components/dr-scenario-configuration/dr-scenario-configuration.component.mjs +41 -17
  87. package/esm2022/lib/dr-scenario/components/dr-scenario-tag-configuration/dr-scenario-tag-configuration.component.mjs +42 -27
  88. package/esm2022/lib/dr-scenario/dr-scenario.module.mjs +14 -13
  89. package/esm2022/lib/dr-scenario/services/scenario.service.mjs +6 -6
  90. package/esm2022/lib/dr-spinner/dr-spinner.component.mjs +17 -7
  91. package/esm2022/lib/dr-spinner/dr-spinner.directive.mjs +25 -20
  92. package/esm2022/lib/dr-spinner/dr-spinner.module.mjs +13 -12
  93. package/esm2022/lib/dr-tabs/dr-tab.component.mjs +33 -25
  94. package/esm2022/lib/dr-tabs/dr-tabs.component.mjs +118 -30
  95. package/esm2022/lib/dr-tabs/dr-tabs.module.mjs +14 -13
  96. package/esm2022/lib/dr-tags/dr-tag.component.mjs +74 -33
  97. package/esm2022/lib/dr-tags/dr-tag.module.mjs +14 -13
  98. package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.component.mjs +72 -19
  99. package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.module.mjs +14 -13
  100. package/esm2022/lib/dr-tags-constructor/tags-constructor.service.mjs +6 -6
  101. package/esm2022/lib/dr-toastr/default-toastr/default-toastr.component.mjs +48 -10
  102. package/esm2022/lib/dr-toastr/dr-toastr.module.mjs +19 -18
  103. package/esm2022/lib/dr-toastr/dr-toastr.service.mjs +9 -9
  104. package/esm2022/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.mjs +23 -14
  105. package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +76 -9
  106. package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +63 -25
  107. package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +41 -39
  108. package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +14 -13
  109. package/esm2022/lib/dr-treeview/components/treeview/treeview.component.mjs +211 -19
  110. package/esm2022/lib/dr-treeview/components/treeview-item/treeview-item.component.mjs +52 -15
  111. package/esm2022/lib/dr-treeview/dr-tree-view.module.mjs +14 -13
  112. package/esm2022/lib/dr-treeview/helpers/treeview-event-parser.mjs +21 -21
  113. package/esm2022/lib/dr-treeview/models/treeview-config.mjs +6 -6
  114. package/esm2022/lib/dr-treeview/models/treeview-i18n.mjs +11 -11
  115. package/esm2022/lib/dr-treeview/pipes/treeview.pipe.mjs +9 -9
  116. package/esm2022/lib/image-cropper/dr-image-cropper-canvas.service.mjs +6 -6
  117. package/esm2022/lib/image-cropper/dr-image-cropper.component.mjs +67 -28
  118. package/esm2022/lib/list-tags/list-tag.component.mjs +57 -17
  119. package/esm2022/lib/list-tags/list-tag.module.mjs +14 -13
  120. package/esm2022/lib/models/dropdown.mjs +1 -1
  121. package/esm2022/lib/models/popover.mjs +1 -1
  122. package/esm2022/lib/stepper/stepper.component.mjs +225 -28
  123. package/esm2022/lib/stepper/stepper.module.mjs +13 -12
  124. package/esm2022/lib/utils/decorators.mjs +12 -0
  125. package/esm2022/public-api.mjs +2 -2
  126. package/fesm2022/datarailsshared-datarailsshared.mjs +5786 -2724
  127. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  128. package/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.d.ts +8 -0
  129. package/lib/dr-dropdown/dr-dropdown.component.d.ts +24 -22
  130. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +16 -15
  131. package/lib/dr-dropdown/dr-dropdown.module.d.ts +5 -4
  132. package/lib/dr-dropdown/dr-dropdown.service.d.ts +23 -8
  133. package/lib/dr-popover/dr-popover-ref.d.ts +1 -0
  134. package/lib/dr-popover/dr-popover.service.d.ts +2 -1
  135. package/lib/models/dropdown.d.ts +13 -21
  136. package/lib/models/popover.d.ts +6 -3
  137. package/lib/utils/decorators.d.ts +1 -0
  138. package/package.json +5 -2
  139. package/public-api.d.ts +2 -2
  140. package/datarailsshared-datarailsshared-1.5.393.tgz +0 -0
  141. package/esm2022/lib/dr-dropdown/dr-dropdown-position.directive.mjs +0 -113
  142. package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +0 -15
@@ -1,55 +1,144 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
2
- import { DrDropdownService } from './dr-dropdown.service';
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, ElementRef, EventEmitter, inject, Input, Output, ViewChild, } from '@angular/core';
11
+ import { DrPopoverRef } from '../models/popover';
12
+ import { first, merge, Subject, takeUntil } from 'rxjs';
13
+ import { DropdownInstanceService } from './dr-dropdown.service';
14
+ import { Debounce } from '../utils/decorators';
3
15
  import * as i0 from "@angular/core";
4
- import * as i1 from "./dr-dropdown.service";
5
- import * as i2 from "@angular/common";
6
- import * as i3 from "../dr-tooltip/dr-tooltip.directive";
7
- import * as i4 from "./dr-dropdown-position.directive";
8
- import * as i5 from "./dr-dropdown-item-show.pipe";
16
+ const _c0 = ["menuContainer"];
17
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_1_i_1_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵelement(0, "i");
19
+ } if (rf & 2) {
20
+ const act_r2 = i0.ɵɵnextContext(2).$implicit;
21
+ i0.ɵɵclassMap(act_r2.icon);
22
+ } }
23
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_1_Template(rf, ctx) { if (rf & 1) {
24
+ i0.ɵɵelementContainerStart(0, 8);
25
+ i0.ɵɵtemplate(1, DrDropdownComponent_dr_dropdown_item_4_ng_container_1_i_1_Template, 1, 2, "i", 9);
26
+ i0.ɵɵelementStart(2, "span", 10);
27
+ i0.ɵɵtext(3);
28
+ i0.ɵɵelementEnd();
29
+ i0.ɵɵelementContainerEnd();
30
+ } if (rf & 2) {
31
+ const act_r2 = i0.ɵɵnextContext().$implicit;
32
+ i0.ɵɵadvance(1);
33
+ i0.ɵɵproperty("ngIf", act_r2.icon);
34
+ i0.ɵɵadvance(2);
35
+ i0.ɵɵtextInterpolate(act_r2.title);
36
+ } }
37
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_2_i_1_Template(rf, ctx) { if (rf & 1) {
38
+ const _r13 = i0.ɵɵgetCurrentView();
39
+ i0.ɵɵelementStart(0, "i", 14);
40
+ i0.ɵɵlistener("mousedown", function DrDropdownComponent_dr_dropdown_item_4_ng_container_2_i_1_Template_i_mousedown_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r13); const actionIcon_r11 = restoredCtx.$implicit; const act_r2 = i0.ɵɵnextContext(2).$implicit; const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r12.onActionIconClick($event, actionIcon_r11, act_r2.data)); });
41
+ i0.ɵɵelementEnd();
42
+ } if (rf & 2) {
43
+ const actionIcon_r11 = ctx.$implicit;
44
+ i0.ɵɵclassMap(actionIcon_r11.icon);
45
+ i0.ɵɵclassProp("showOnHover", actionIcon_r11.showOnHover);
46
+ } }
47
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_2_i_2_Template(rf, ctx) { if (rf & 1) {
48
+ i0.ɵɵelement(0, "i", 15);
49
+ } }
50
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_2_Template(rf, ctx) { if (rf & 1) {
51
+ i0.ɵɵelementContainerStart(0, 11);
52
+ i0.ɵɵtemplate(1, DrDropdownComponent_dr_dropdown_item_4_ng_container_2_i_1_Template, 1, 4, "i", 12);
53
+ i0.ɵɵtemplate(2, DrDropdownComponent_dr_dropdown_item_4_ng_container_2_i_2_Template, 1, 0, "i", 13);
54
+ i0.ɵɵelementContainerEnd();
55
+ } if (rf & 2) {
56
+ const act_r2 = i0.ɵɵnextContext().$implicit;
57
+ const ctx_r4 = i0.ɵɵnextContext();
58
+ i0.ɵɵadvance(1);
59
+ i0.ɵɵproperty("ngForOf", act_r2.actionIcons);
60
+ i0.ɵɵadvance(1);
61
+ i0.ɵɵproperty("ngIf", ctx_r4.hasChildren(act_r2));
62
+ } }
63
+ const _c1 = function (a0) { return { $implicit: a0 }; };
64
+ function DrDropdownComponent_dr_dropdown_item_4_ng_container_3_Template(rf, ctx) { if (rf & 1) {
65
+ i0.ɵɵelementContainer(0, 16);
66
+ } if (rf & 2) {
67
+ const act_r2 = i0.ɵɵnextContext().$implicit;
68
+ i0.ɵɵproperty("ngTemplateOutlet", act_r2.templateRef)("ngTemplateOutletContext", i0.ɵɵpureFunction1(2, _c1, act_r2));
69
+ } }
70
+ const _c2 = function () { return { withoutArrow: true }; };
71
+ function DrDropdownComponent_dr_dropdown_item_4_Template(rf, ctx) { if (rf & 1) {
72
+ const _r18 = i0.ɵɵgetCurrentView();
73
+ i0.ɵɵelementStart(0, "dr-dropdown-item", 4);
74
+ i0.ɵɵlistener("mousedown", function DrDropdownComponent_dr_dropdown_item_4_Template_dr_dropdown_item_mousedown_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r18); const act_r2 = restoredCtx.$implicit; const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.action(act_r2)); });
75
+ i0.ɵɵtemplate(1, DrDropdownComponent_dr_dropdown_item_4_ng_container_1_Template, 4, 2, "ng-container", 5);
76
+ i0.ɵɵtemplate(2, DrDropdownComponent_dr_dropdown_item_4_ng_container_2_Template, 3, 2, "ng-container", 6);
77
+ i0.ɵɵtemplate(3, DrDropdownComponent_dr_dropdown_item_4_ng_container_3_Template, 1, 4, "ng-container", 7);
78
+ i0.ɵɵelementEnd();
79
+ } if (rf & 2) {
80
+ const act_r2 = ctx.$implicit;
81
+ const ctx_r1 = i0.ɵɵnextContext();
82
+ i0.ɵɵproperty("drTooltip", ctx_r1.tooltipToShow(act_r2))("drTooltipPosition", "left")("drTooltipOptions", i0.ɵɵpureFunction0(14, _c2))("drTooltipClass", "dr-dropdown__tooltip")("drDropdown", ctx_r1.hasChildren(act_r2) && act_r2.children)("drDropdownClass", act_r2.childOptions == null ? null : act_r2.childOptions.class)("drDropdownInHover", true)("drDropdownPosition", act_r2.childOptions == null ? null : act_r2.childOptions.position)("disabled", ctx_r1.disabled(act_r2))("selected", ctx_r1.selected(act_r2))("divider", act_r2.separateLine);
83
+ i0.ɵɵadvance(1);
84
+ i0.ɵɵproperty("ngIf", !act_r2.templateRef);
85
+ i0.ɵɵadvance(1);
86
+ i0.ɵɵproperty("ngIf", !act_r2.templateRef);
87
+ i0.ɵɵadvance(1);
88
+ i0.ɵɵproperty("ngIf", act_r2.templateRef);
89
+ } }
90
+ const _c3 = [[["dr-dropdown-item"]]];
91
+ const _c4 = ["dr-dropdown-item"];
9
92
  export class DrDropdownComponent {
10
- constructor(menuService, cdr) {
11
- this.menuService = menuService;
12
- this.cdr = cdr;
13
- this.position = 'left';
14
- this.wasHovered = false;
15
- }
16
93
  set options(data) {
17
94
  if (data) {
18
- this.option = data.option;
19
- this.position = data.position;
20
95
  this.drDropdownInHover = data.drDropdownInHover;
21
96
  this.containerClass = data.class;
22
97
  this.list = data.list || [];
23
98
  this.list.forEach((item) => {
24
99
  if (item.children?.length) {
25
100
  item.childOptions = {
26
- list: item.children,
27
101
  class: item?.childOptions?.class || '',
28
- position: 'child',
102
+ position: item?.childOptions?.position || 'left-top',
29
103
  };
30
104
  }
31
105
  });
32
106
  this.cdr.markForCheck();
107
+ if (this.drDropdownInHover) {
108
+ this.dropdownInstanceService
109
+ .inactive(this)
110
+ .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))
111
+ .subscribe(() => {
112
+ this.popoverRef.close();
113
+ });
114
+ }
33
115
  }
34
116
  }
35
- onMouseEnter() {
36
- this.wasHovered = true;
37
- }
38
- onMouseLeave() {
39
- if (this.drDropdownInHover)
40
- this.menuService.destroy();
117
+ constructor() {
118
+ this.cdr = inject(ChangeDetectorRef);
119
+ this.popoverRef = inject(DrPopoverRef, { optional: true });
120
+ this.dropdownInstanceService = inject(DropdownInstanceService, { optional: true });
121
+ this.destroy$ = new Subject();
122
+ this._active = true;
123
+ this.drDropdownInHoverChange$ = new Subject();
124
+ this.list = [];
125
+ this.wasHovered = false;
126
+ this.asChild = false;
127
+ this.onAction = new EventEmitter();
128
+ if (!this.dropdownInstanceService)
129
+ return;
130
+ this.dropdownInstanceService.register(this);
131
+ inject(DestroyRef).onDestroy(() => {
132
+ this.dropdownInstanceService.unregister(this);
133
+ this.destroy$.next();
134
+ this.destroy$.next();
135
+ });
41
136
  }
42
- onClickedOutside() {
43
- if (this.firstInit) {
44
- this.menuService.destroy();
45
- }
46
- else {
47
- this.firstInit = true;
137
+ ngOnChanges(changes) {
138
+ if (!changes?.drDropdownInHover?.isFirstChange()) {
139
+ this.drDropdownInHoverChange$.next();
48
140
  }
49
141
  }
50
- hide() {
51
- this.menuService.destroy();
52
- }
53
142
  disabled(act) {
54
143
  if (!act.disabled) {
55
144
  return false;
@@ -77,40 +166,70 @@ export class DrDropdownComponent {
77
166
  return '';
78
167
  return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;
79
168
  }
80
- tooltipPosition(widthMoreRight) {
81
- return widthMoreRight ? 'right' : 'left';
82
- }
83
169
  action(act) {
84
170
  if (!this.disabled(act)) {
85
171
  if (act.action) {
86
172
  act.action(act.data);
87
173
  }
88
174
  else {
89
- this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });
175
+ const event = { event: act.event || act.title || 'default', data: act.data };
176
+ this.onAction.emit(event);
90
177
  }
91
- this.hide();
92
178
  }
93
179
  }
94
180
  onActionIconClick($event, actionIcon, data) {
95
181
  $event.stopPropagation();
96
- if (!this.disabled(actionIcon)) {
97
- actionIcon.action(data);
98
- this.hide();
99
- }
182
+ actionIcon.action(data);
183
+ }
184
+ hasChildren(item) {
185
+ return !!item.children?.length;
186
+ }
187
+ onMouseenter() {
188
+ this.wasHovered = true;
189
+ this._active = true;
190
+ }
191
+ onMouseleave() {
192
+ this._active = false;
193
+ }
194
+ active() {
195
+ return this._active;
100
196
  }
101
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrDropdownComponent, deps: [{ token: i1.DrDropdownService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
102
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DrDropdownComponent, selector: "dr-dropdown", inputs: { options: "options" }, viewQueries: [{ propertyName: "viewMenu", first: true, predicate: ["listMenu"], descendants: true }, { propertyName: "menuContainer", first: true, predicate: ["menuContainer"], descendants: true }], ngImport: i0, template: "<div\n #menuContainer\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n (clickOutside)=\"onClickedOutside()\"\n [drDropdownPosition]=\"option\"\n #dropdownPosition=\"dropdownPosition\"\n [position]=\"position\"\n [class]=\"containerClass\"\n class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\">\n <div\n *ngFor=\"let act of list | drDropdownItemShowPipe\"\n (click)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n [drTooltipOptions]=\"{ withoutArrow: true }\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n class=\"dr-dropdown__container__item\"\n [class.item-disabled]=\"disabled(act)\"\n [class.item-selected]=\"selected(act)\"\n [class.separate-line]=\"act.separateLine\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n <span class=\"dr-dropdown__container__item__text\">{{ act.title }}</span>\n <i\n *ngFor=\"let actionIcon of act.actionIcons\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{position:absolute;z-index:-1;top:0;left:0;width:auto}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;border-radius:4px;box-shadow:0 4px 8px 1px #00000040;padding:8px 0;overflow-y:auto;max-height:60vh}.dr-dropdown__container__item{display:flex;align-items:center;justify-content:flex-start;cursor:pointer;min-width:15rem;font-style:normal;font-weight:400;font-size:14px;line-height:24px;clear:both;width:100%;white-space:nowrap;padding:0 12px;height:36px;flex-shrink:0;background:#fff}.dr-dropdown__container__item.separate-line{border-top:1px solid #dfe0e3}.dr-dropdown__container__item:hover{background-color:#f5f5f5}.dr-dropdown__container__item:hover .showOnHover{visibility:visible}.dr-dropdown__container__item.item-selected{background:#eaeaff}.dr-dropdown__container__item.item-disabled,.dr-dropdown__container__item.item-disabled i,.dr-dropdown__container__item.item-disabled .dr-dropdown__container__item__text{background:#fff!important;color:#aeabac}.dr-dropdown__container__item i:first-child{margin-right:8px}.dr-dropdown__container__item__text{margin-right:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dr-dropdown__container__item i,.dr-dropdown__container__item__text{color:#333}.dr-dropdown__container__item__text+i:hover{color:#4646ce}.dr-dropdown__container__item .showOnHover{visibility:hidden}.dr-dropdown.content-top{transform:translate(-50%,-100%)}.dr-dropdown.content-top-left{transform:translate(-100%,-100%)}.dr-dropdown.content-bottom{transform:translate(-50%,50%)}.dr-dropdown.content-bottom-left{transform:translate(-90%,35%)}.dr-dropdown.content-bottom-right{transform:translateY(15%)}.dr-dropdown.content-left{transform:translate(-100%)}.dr-dropdown.content-left-center{transform:translate(-100%,-50%)}.dr-dropdown.content-right{transform:translate(5%)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DrTooltipDirective, selector: "[drTooltip]", inputs: ["drTooltip", "drTooltipContext", "drTooltipPosition", "drTooltipClass", "drTooltipTheme", "drTooltipMousleaveTimeout", "drTooltipMouseEnterTimeout", "drTooltipOptions", "drTooltipShow"] }, { kind: "directive", type: i4.DrDropdownPositionDirective, selector: "[drDropdownPosition]", inputs: ["drDropdownPosition", "position"], exportAs: ["dropdownPosition"] }, { kind: "component", type: DrDropdownComponent, selector: "dr-dropdown", inputs: ["options"] }, { kind: "pipe", type: i5.DrDropdownItemShowPipe, name: "drDropdownItemShowPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
197
+ /** @nocollapse */ static { this.ɵfac = function DrDropdownComponent_Factory(t) { return new (t || DrDropdownComponent)(); }; }
198
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDropdownComponent, selectors: [["dr-dropdown"]], viewQuery: function DrDropdownComponent_Query(rf, ctx) { if (rf & 1) {
199
+ i0.ɵɵviewQuery(_c0, 7);
200
+ } if (rf & 2) {
201
+ let _t;
202
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.menuContainer = _t.first);
203
+ } }, inputs: { options: "options" }, outputs: { onAction: "action" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c4, decls: 6, vars: 5, consts: [[1, "dr-dropdown"], ["menuContainer", ""], ["tabindex", "-1", "role", "listbox", 1, "dr-dropdown__container", 3, "mouseenter", "mouseleave"], ["drDropdownChild", "", "role", "option", "tabindex", "0", 3, "drTooltip", "drTooltipPosition", "drTooltipOptions", "drTooltipClass", "drDropdown", "drDropdownClass", "drDropdownInHover", "drDropdownPosition", "disabled", "selected", "divider", "mousedown", 4, "ngFor", "ngForOf"], ["drDropdownChild", "", "role", "option", "tabindex", "0", 3, "drTooltip", "drTooltipPosition", "drTooltipOptions", "drTooltipClass", "drDropdown", "drDropdownClass", "drDropdownInHover", "drDropdownPosition", "disabled", "selected", "divider", "mousedown"], ["dropdownItemContent", "", 4, "ngIf"], ["dropdownItemActions", "", 4, "ngIf"], ["dropdownItemContent", "", 3, "ngTemplateOutlet", "ngTemplateOutletContext", 4, "ngIf"], ["dropdownItemContent", ""], [3, "class", 4, "ngIf"], [1, "dr-dropdown__text"], ["dropdownItemActions", ""], [3, "class", "showOnHover", "mousedown", 4, "ngFor", "ngForOf"], ["class", "dr-icon-arrow-right", 4, "ngIf"], [3, "mousedown"], [1, "dr-icon-arrow-right"], ["dropdownItemContent", "", 3, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrDropdownComponent_Template(rf, ctx) { if (rf & 1) {
204
+ i0.ɵɵprojectionDef(_c3);
205
+ i0.ɵɵelementStart(0, "div", 0, 1)(2, "div", 2);
206
+ i0.ɵɵlistener("mouseenter", function DrDropdownComponent_Template_div_mouseenter_2_listener() { return ctx.onMouseenter(); })("mouseleave", function DrDropdownComponent_Template_div_mouseleave_2_listener() { return ctx.onMouseleave(); });
207
+ i0.ɵɵprojection(3);
208
+ i0.ɵɵtemplate(4, DrDropdownComponent_dr_dropdown_item_4_Template, 4, 15, "dr-dropdown-item", 3);
209
+ i0.ɵɵpipe(5, "drDropdownItemShowPipe");
210
+ i0.ɵɵelementEnd()();
211
+ } if (rf & 2) {
212
+ i0.ɵɵclassMap(ctx.containerClass);
213
+ i0.ɵɵadvance(4);
214
+ i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(5, 3, ctx.list));
215
+ } }, styles: [".dr-dropdown__item .dr-dropdown{visibility:hidden;transition-delay:.2s} .dr-dropdown__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s} .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown[_ngcontent-%COMP%]{width:auto}.dr-dropdown__text[_ngcontent-%COMP%]{overflow:hidden;text-overflow:ellipsis;flex:1}.dr-dropdown__container[_ngcontent-%COMP%]{display:flex;flex-direction:column;background:#fff;padding:8px 0;overflow-y:auto;max-height:60vh;max-width:300px}.dr-dropdown[_ngcontent-%COMP%] i[_ngcontent-%COMP%]:first-child{margin-right:8px}.dr-dropdown[_ngcontent-%COMP%] i[_ngcontent-%COMP%]:not(:first-child):hover{color:#4646ce}.dr-dropdown[_ngcontent-%COMP%] dr-dropdown-item[_ngcontent-%COMP%]:hover .showOnHover[_ngcontent-%COMP%]{visibility:visible}.dr-dropdown[_ngcontent-%COMP%] .showOnHover[_ngcontent-%COMP%]{visibility:hidden}"], changeDetection: 0 }); }
103
216
  }
104
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrDropdownComponent, decorators: [{
105
- type: Component,
106
- args: [{ selector: 'dr-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #menuContainer\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n (clickOutside)=\"onClickedOutside()\"\n [drDropdownPosition]=\"option\"\n #dropdownPosition=\"dropdownPosition\"\n [position]=\"position\"\n [class]=\"containerClass\"\n class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\">\n <div\n *ngFor=\"let act of list | drDropdownItemShowPipe\"\n (click)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n [drTooltipOptions]=\"{ withoutArrow: true }\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n class=\"dr-dropdown__container__item\"\n [class.item-disabled]=\"disabled(act)\"\n [class.item-selected]=\"selected(act)\"\n [class.separate-line]=\"act.separateLine\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n <span class=\"dr-dropdown__container__item__text\">{{ act.title }}</span>\n <i\n *ngFor=\"let actionIcon of act.actionIcons\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n </div>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__container__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__container__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{position:absolute;z-index:-1;top:0;left:0;width:auto}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;border-radius:4px;box-shadow:0 4px 8px 1px #00000040;padding:8px 0;overflow-y:auto;max-height:60vh}.dr-dropdown__container__item{display:flex;align-items:center;justify-content:flex-start;cursor:pointer;min-width:15rem;font-style:normal;font-weight:400;font-size:14px;line-height:24px;clear:both;width:100%;white-space:nowrap;padding:0 12px;height:36px;flex-shrink:0;background:#fff}.dr-dropdown__container__item.separate-line{border-top:1px solid #dfe0e3}.dr-dropdown__container__item:hover{background-color:#f5f5f5}.dr-dropdown__container__item:hover .showOnHover{visibility:visible}.dr-dropdown__container__item.item-selected{background:#eaeaff}.dr-dropdown__container__item.item-disabled,.dr-dropdown__container__item.item-disabled i,.dr-dropdown__container__item.item-disabled .dr-dropdown__container__item__text{background:#fff!important;color:#aeabac}.dr-dropdown__container__item i:first-child{margin-right:8px}.dr-dropdown__container__item__text{margin-right:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dr-dropdown__container__item i,.dr-dropdown__container__item__text{color:#333}.dr-dropdown__container__item__text+i:hover{color:#4646ce}.dr-dropdown__container__item .showOnHover{visibility:hidden}.dr-dropdown.content-top{transform:translate(-50%,-100%)}.dr-dropdown.content-top-left{transform:translate(-100%,-100%)}.dr-dropdown.content-bottom{transform:translate(-50%,50%)}.dr-dropdown.content-bottom-left{transform:translate(-90%,35%)}.dr-dropdown.content-bottom-right{transform:translateY(15%)}.dr-dropdown.content-left{transform:translate(-100%)}.dr-dropdown.content-left-center{transform:translate(-100%,-50%)}.dr-dropdown.content-right{transform:translate(5%)}\n"] }]
107
- }], ctorParameters: function () { return [{ type: i1.DrDropdownService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { viewMenu: [{
108
- type: ViewChild,
109
- args: ['listMenu']
110
- }], menuContainer: [{
111
- type: ViewChild,
112
- args: ['menuContainer']
113
- }], options: [{
114
- type: Input
115
- }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';\nimport { ElPosition, IDropdown, IDropdownActionIcon, IDropdownCoordinate, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent {\n    @ViewChild('listMenu') viewMenu: HTMLElement;\n    @ViewChild('menuContainer') menuContainer: HTMLElement;\n    option: any;\n    position: ElPosition | IDropdownCoordinate = 'left';\n    drDropdownInHover: boolean;\n    list: IDropdownItem<unknown>[];\n    containerClass: string;\n    public wasHovered = false;\n    private firstInit: boolean;\n\n    constructor(\n        protected menuService: DrDropdownService,\n        private cdr: ChangeDetectorRef,\n    ) {}\n\n    @Input() set options(data: IDropdown<IDropdownItem<any>>) {\n        if (data) {\n            this.option = data.option;\n            this.position = data.position;\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        list: item.children,\n                        class: item?.childOptions?.class || '',\n                        position: 'child',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n        }\n    }\n\n    onMouseEnter(): void {\n        this.wasHovered = true;\n    }\n\n    onMouseLeave(): void {\n        if (this.drDropdownInHover) this.menuService.destroy();\n    }\n\n    onClickedOutside(): void {\n        if (this.firstInit) {\n            this.menuService.destroy();\n        } else {\n            this.firstInit = true;\n        }\n    }\n\n    hide(): void {\n        this.menuService.destroy();\n    }\n\n    disabled(act: IDropdownItem<unknown> | IDropdownActionIcon<any>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    tooltipPosition(widthMoreRight: boolean) {\n        return widthMoreRight ? 'right' : 'left';\n    }\n\n    action(act: IDropdownItem<any>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                this.menuService.actionItem.next({ event: act.event || act.title || 'default', data: act.data });\n            }\n            this.hide();\n        }\n    }\n\n    onActionIconClick($event, actionIcon: IDropdownActionIcon<any>, data: any) {\n        $event.stopPropagation();\n        if (!this.disabled(actionIcon)) {\n            actionIcon.action(data);\n            this.hide();\n        }\n    }\n}\n","<div\n    #menuContainer\n    (mouseleave)=\"onMouseLeave()\"\n    (mouseenter)=\"onMouseEnter()\"\n    (clickOutside)=\"onClickedOutside()\"\n    [drDropdownPosition]=\"option\"\n    #dropdownPosition=\"dropdownPosition\"\n    [position]=\"position\"\n    [class]=\"containerClass\"\n    class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\">\n        <div\n            *ngFor=\"let act of list | drDropdownItemShowPipe\"\n            (click)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"tooltipPosition(dropdownPosition.widthMoreRight)\"\n            [drTooltipOptions]=\"{ withoutArrow: true }\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            class=\"dr-dropdown__container__item\"\n            [class.item-disabled]=\"disabled(act)\"\n            [class.item-selected]=\"selected(act)\"\n            [class.separate-line]=\"act.separateLine\">\n            <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n            <span class=\"dr-dropdown__container__item__text\">{{ act.title }}</span>\n            <i\n                *ngFor=\"let actionIcon of act.actionIcons\"\n                [class]=\"actionIcon.icon\"\n                [class.showOnHover]=\"actionIcon.showOnHover\"\n                (click)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n            <i *ngIf=\"act.children?.length\" class=\"dr-icon-arrow-right\"></i>\n            <dr-dropdown *ngIf=\"act.children?.length\" [options]=\"act.childOptions\"></dr-dropdown>\n        </div>\n    </div>\n</div>\n"]}
217
+ __decorate([
218
+ Debounce(200),
219
+ __metadata("design:type", Function),
220
+ __metadata("design:paramtypes", []),
221
+ __metadata("design:returntype", void 0)
222
+ ], DrDropdownComponent.prototype, "onMouseleave", null);
223
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDropdownComponent, [{
224
+ type: Component,
225
+ args: [{ selector: 'dr-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n <dr-dropdown-item\n *ngFor=\"let act of list | drDropdownItemShowPipe\"\n (mousedown)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"'left'\"\n [drTooltipOptions]=\"{ withoutArrow: true }\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n [drDropdown]=\"hasChildren(act) && act.children\"\n [drDropdownClass]=\"act.childOptions?.class\"\n [drDropdownInHover]=\"true\"\n [drDropdownPosition]=\"act.childOptions?.position\"\n drDropdownChild\n [disabled]=\"disabled(act)\"\n [selected]=\"selected(act)\"\n [divider]=\"act.separateLine\"\n role=\"option\"\n tabindex=\"0\">\n <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n </ng-container>\n\n <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n <i\n *ngFor=\"let actionIcon of act.actionIcons\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n </ng-container>\n\n <ng-container\n *ngIf=\"act.templateRef\"\n dropdownItemContent\n [ngTemplateOutlet]=\"act.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: act }\">\n </ng-container>\n </dr-dropdown-item>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{width:auto}.dr-dropdown__text{overflow:hidden;text-overflow:ellipsis;flex:1}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;padding:8px 0;overflow-y:auto;max-height:60vh;max-width:300px}.dr-dropdown i:first-child{margin-right:8px}.dr-dropdown i:not(:first-child):hover{color:#4646ce}.dr-dropdown dr-dropdown-item:hover .showOnHover{visibility:visible}.dr-dropdown .showOnHover{visibility:hidden}\n"] }]
226
+ }], function () { return []; }, { menuContainer: [{
227
+ type: ViewChild,
228
+ args: ['menuContainer', { static: true }]
229
+ }], options: [{
230
+ type: Input
231
+ }], onAction: [{
232
+ type: Output,
233
+ args: ['action']
234
+ }], onMouseleave: [] }); })();
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { IDropdown, IDropdownAction, IDropdownActionIcon, IDropdownItem } from '../models/dropdown';\nimport { DrPopoverRef } from '../models/popover';\nimport { first, merge, Subject, takeUntil } from 'rxjs';\nimport { DropdownInstanceRef, DropdownInstanceService } from './dr-dropdown.service';\nimport { Debounce } from '../utils/decorators';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent implements DropdownInstanceRef {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly popoverRef = inject(DrPopoverRef, { optional: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService, { optional: true });\n\n    private readonly destroy$ = new Subject<void>();\n\n    private _active = true;\n\n    @ViewChild('menuContainer', { static: true })\n    menuContainer: ElementRef<HTMLDivElement>;\n\n    drDropdownInHover: boolean;\n    private readonly drDropdownInHoverChange$ = new Subject<void>();\n    list: IDropdownItem<unknown>[] = [];\n    containerClass: string;\n    wasHovered = false;\n    asChild = false;\n\n    @Input()\n    set options(data: IDropdown<IDropdownItem<unknown>>) {\n        if (data) {\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        class: item?.childOptions?.class || '',\n                        position: item?.childOptions?.position || 'left-top',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n\n            if (this.drDropdownInHover) {\n                this.dropdownInstanceService\n                    .inactive(this)\n                    .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))\n                    .subscribe(() => {\n                        this.popoverRef.close();\n                    });\n            }\n        }\n    }\n\n    @Output('action')\n    onAction = new EventEmitter<IDropdownAction<unknown>>();\n\n    constructor() {\n        if (!this.dropdownInstanceService) return;\n\n        this.dropdownInstanceService.register(this);\n        inject(DestroyRef).onDestroy(() => {\n            this.dropdownInstanceService.unregister(this);\n            this.destroy$.next();\n            this.destroy$.next();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes?.drDropdownInHover?.isFirstChange()) {\n            this.drDropdownInHoverChange$.next();\n        }\n    }\n\n    disabled(act: IDropdownItem<unknown>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    action(act: IDropdownItem<unknown>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                const event = { event: act.event || act.title || 'default', data: act.data };\n                this.onAction.emit(event);\n            }\n        }\n    }\n\n    onActionIconClick($event: MouseEvent, actionIcon: IDropdownActionIcon<unknown>, data: unknown) {\n        $event.stopPropagation();\n        actionIcon.action(data);\n    }\n\n    hasChildren(item: IDropdownItem<unknown>): boolean {\n        return !!item.children?.length;\n    }\n\n    onMouseenter(): void {\n        this.wasHovered = true;\n        this._active = true;\n    }\n\n    @Debounce(200)\n    onMouseleave(): void {\n        this._active = false;\n    }\n\n    active(): boolean {\n        return this._active;\n    }\n}\n","<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n        <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n        <dr-dropdown-item\n            *ngFor=\"let act of list | drDropdownItemShowPipe\"\n            (mousedown)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"'left'\"\n            [drTooltipOptions]=\"{ withoutArrow: true }\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            [drDropdown]=\"hasChildren(act) && act.children\"\n            [drDropdownClass]=\"act.childOptions?.class\"\n            [drDropdownInHover]=\"true\"\n            [drDropdownPosition]=\"act.childOptions?.position\"\n            drDropdownChild\n            [disabled]=\"disabled(act)\"\n            [selected]=\"selected(act)\"\n            [divider]=\"act.separateLine\"\n            role=\"option\"\n            tabindex=\"0\">\n            <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n                <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n                <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n            </ng-container>\n\n            <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n                <i\n                    *ngFor=\"let actionIcon of act.actionIcons\"\n                    [class]=\"actionIcon.icon\"\n                    [class.showOnHover]=\"actionIcon.showOnHover\"\n                    (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n                <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n            </ng-container>\n\n            <ng-container\n                *ngIf=\"act.templateRef\"\n                dropdownItemContent\n                [ngTemplateOutlet]=\"act.templateRef\"\n                [ngTemplateOutletContext]=\"{ $implicit: act }\">\n            </ng-container>\n        </dr-dropdown-item>\n    </div>\n</div>\n"]}
@@ -1,17 +1,14 @@
1
- import { ComponentFactoryResolver, Directive, ElementRef, HostListener, Inject, Input, ViewChild, ViewContainerRef, } from '@angular/core';
2
- import { DOCUMENT } from '@angular/common';
3
- import { DrDropdownComponent } from './dr-dropdown.component';
4
- import { DrDropdownService } from './dr-dropdown.service';
1
+ import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, Output } from '@angular/core';
2
+ import { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';
5
3
  import * as i0 from "@angular/core";
6
- import * as i1 from "./dr-dropdown.service";
7
4
  export class DrDropdownDirective {
8
- constructor(componentFactoryResolver, viewContainerRef, service, el, _document) {
9
- this.componentFactoryResolver = componentFactoryResolver;
10
- this.viewContainerRef = viewContainerRef;
11
- this.service = service;
12
- this.el = el;
13
- this._document = _document;
14
- this.position = 'left';
5
+ constructor() {
6
+ this.elementRef = inject((ElementRef));
7
+ this.service = inject(DrDropdownService);
8
+ this.child = inject(DrDropdownChildDirective, { optional: true, self: true });
9
+ this.dropdownInstanceService = inject(DropdownInstanceService);
10
+ this.drDropdownPosition = 'left-top';
11
+ this.drDropdownAction = new EventEmitter();
15
12
  this.mouseleaveTimeout = 200;
16
13
  }
17
14
  elementHover() {
@@ -24,94 +21,108 @@ export class DrDropdownDirective {
24
21
  }
25
22
  leaveDropdownTriggerElement() {
26
23
  if (this.drDropdownInHover) {
27
- setTimeout((_) => {
28
- if (this.contentCmpRef && !this.contentCmpRef.instance.wasHovered) {
29
- this.contentCmpRef.destroy();
30
- this.contentCmpRef = null;
24
+ setTimeout(() => {
25
+ if (this.ref && !this.ref.instance.wasHovered) {
26
+ this.close();
31
27
  }
32
28
  }, this.mouseleaveTimeout);
33
29
  }
34
30
  }
35
- documentClick(e) {
36
- this.closeDropdown(e);
31
+ documentClick() {
32
+ this.close();
37
33
  }
38
34
  openDropdown() {
39
- const option = this.el.nativeElement.getBoundingClientRect();
40
- this._document.querySelectorAll('dr-dropdown').forEach((item) => item.remove());
41
- if (this.contentCmpRef && this.contentCmpRef.destroyCbs) {
42
- this.contentCmpRef.destroy();
43
- this.contentCmpRef = null;
35
+ if (!this.drDropdown?.length) {
36
+ return;
37
+ }
38
+ if (this.ref) {
39
+ this.close();
40
+ return;
44
41
  }
45
- else {
46
- this.service.destroy();
47
- this.showMenu({
48
- option,
42
+ this.ref = this.service.open({
43
+ hostRef: this.elementRef,
44
+ position: this.drDropdownPosition,
45
+ asChild: !!this.child,
46
+ providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],
47
+ action$: this.drDropdownAction,
48
+ options: {
49
49
  drDropdownInHover: this.drDropdownInHover,
50
- position: this.position,
50
+ position: this.drDropdownPosition,
51
51
  list: this.drDropdown,
52
52
  class: this.drDropdownClass,
53
- });
54
- }
53
+ },
54
+ });
55
55
  }
56
- closeDropdown(e) {
57
- if (!this.contentCmpRef) {
58
- return;
56
+ close() {
57
+ if (this.ref) {
58
+ this.ref.close();
59
+ this.ref = null;
59
60
  }
60
- const clickTarget = e.target;
61
- const triggerElement = this.el.nativeElement;
62
- const dropdownElement = this.contentCmpRef.location.nativeElement;
63
- const isClickTriggerElement = triggerElement.contains(clickTarget) || triggerElement === clickTarget;
64
- const isClickDropdownContents = dropdownElement.contains(clickTarget);
65
- if (!isClickTriggerElement && !isClickDropdownContents) {
66
- const elems = this._document.querySelectorAll('dr-dropdown');
67
- setTimeout(() => elems.forEach((item) => item.remove()), 100);
68
- }
69
- }
70
- showMenu(options) {
71
- const componentFactory = this.componentFactoryResolver.resolveComponentFactory(DrDropdownComponent);
72
- this.contentCmpRef = this.viewContainerRef.createComponent(componentFactory);
73
- this.service.addMenu = this.contentCmpRef;
74
- this._document.querySelector('dr-layout').appendChild(this.contentCmpRef.location.nativeElement);
75
- this.contentCmpRef.instance.options = options;
76
61
  }
77
62
  ngOnDestroy() {
78
- if (this.contentCmpRef) {
79
- this.contentCmpRef.destroy();
80
- }
63
+ this.close();
81
64
  }
82
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrDropdownDirective, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: i1.DrDropdownService }, { token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive }); }
83
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DrDropdownDirective, selector: "[drDropdown]", inputs: { position: "position", drDropdown: "drDropdown", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover" }, host: { listeners: { "mouseenter": "elementHover()", "click": "elementClick()", "mouseleave": "leaveDropdownTriggerElement()", "document:mouseup": "documentClick($event)" } }, viewQueries: [{ propertyName: "contentCmpRef", first: true, predicate: DrDropdownComponent, descendants: true, read: ViewContainerRef, static: true }], ngImport: i0 }); }
65
+ /** @nocollapse */ static { this.ɵfac = function DrDropdownDirective_Factory(t) { return new (t || DrDropdownDirective)(); }; }
66
+ /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrDropdownDirective, selectors: [["", "drDropdown", ""]], hostBindings: function DrDropdownDirective_HostBindings(rf, ctx) { if (rf & 1) {
67
+ i0.ɵɵlistener("mouseenter", function DrDropdownDirective_mouseenter_HostBindingHandler() { return ctx.elementHover(); })("click", function DrDropdownDirective_click_HostBindingHandler() { return ctx.elementClick(); })("mouseleave", function DrDropdownDirective_mouseleave_HostBindingHandler() { return ctx.leaveDropdownTriggerElement(); })("mouseup", function DrDropdownDirective_mouseup_HostBindingHandler() { return ctx.documentClick(); }, false, i0.ɵɵresolveDocument);
68
+ } }, inputs: { drDropdown: "drDropdown", drDropdownPosition: "drDropdownPosition", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover" }, outputs: { drDropdownAction: "drDropdownAction" }, features: [i0.ɵɵProvidersFeature([
69
+ {
70
+ provide: DropdownInstanceService,
71
+ useFactory: ((injector) => {
72
+ const service = injector.get(DropdownInstanceService, null, { skipSelf: true });
73
+ return service ?? new DropdownInstanceService(injector);
74
+ }),
75
+ deps: [Injector],
76
+ },
77
+ ])] }); }
78
+ }
79
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDropdownDirective, [{
80
+ type: Directive,
81
+ args: [{
82
+ selector: '[drDropdown]',
83
+ providers: [
84
+ {
85
+ provide: DropdownInstanceService,
86
+ useFactory: ((injector) => {
87
+ const service = injector.get(DropdownInstanceService, null, { skipSelf: true });
88
+ return service ?? new DropdownInstanceService(injector);
89
+ }),
90
+ deps: [Injector],
91
+ },
92
+ ],
93
+ }]
94
+ }], null, { drDropdown: [{
95
+ type: Input,
96
+ args: [{ required: true }]
97
+ }], drDropdownPosition: [{
98
+ type: Input
99
+ }], drDropdownClass: [{
100
+ type: Input
101
+ }], drDropdownInHover: [{
102
+ type: Input
103
+ }], drDropdownAction: [{
104
+ type: Output
105
+ }], elementHover: [{
106
+ type: HostListener,
107
+ args: ['mouseenter']
108
+ }], elementClick: [{
109
+ type: HostListener,
110
+ args: ['click']
111
+ }], leaveDropdownTriggerElement: [{
112
+ type: HostListener,
113
+ args: ['mouseleave']
114
+ }], documentClick: [{
115
+ type: HostListener,
116
+ args: ['document:mouseup']
117
+ }] }); })();
118
+ export class DrDropdownChildDirective {
119
+ /** @nocollapse */ static { this.ɵfac = function DrDropdownChildDirective_Factory(t) { return new (t || DrDropdownChildDirective)(); }; }
120
+ /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrDropdownChildDirective, selectors: [["", "drDropdownChild", ""]] }); }
84
121
  }
85
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrDropdownDirective, decorators: [{
86
- type: Directive,
87
- args: [{
88
- selector: '[drDropdown]',
89
- }]
90
- }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: i1.DrDropdownService }, { type: i0.ElementRef }, { type: undefined, decorators: [{
91
- type: Inject,
92
- args: [DOCUMENT]
93
- }] }]; }, propDecorators: { position: [{
94
- type: Input
95
- }], drDropdown: [{
96
- type: Input
97
- }], drDropdownClass: [{
98
- type: Input
99
- }], drDropdownInHover: [{
100
- type: Input
101
- }], contentCmpRef: [{
102
- type: ViewChild,
103
- args: [DrDropdownComponent, { static: true, read: ViewContainerRef }]
104
- }], elementHover: [{
105
- type: HostListener,
106
- args: ['mouseenter']
107
- }], elementClick: [{
108
- type: HostListener,
109
- args: ['click']
110
- }], leaveDropdownTriggerElement: [{
111
- type: HostListener,
112
- args: ['mouseleave']
113
- }], documentClick: [{
114
- type: HostListener,
115
- args: ['document:mouseup', ['$event']]
116
- }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentFactory,\n    ComponentFactoryResolver,\n    Directive,\n    ElementRef,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ElPosition, IDropdown, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrDropdownService } from './dr-dropdown.service';\n\n@Directive({\n    selector: '[drDropdown]',\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    @Input() position: ElPosition = 'left';\n    @Input() drDropdown: IDropdownItem<T>[];\n    @Input() drDropdownClass: string;\n    @Input() drDropdownInHover: boolean;\n    @ViewChild(DrDropdownComponent, { static: true, read: ViewContainerRef }) contentCmpRef;\n\n    private readonly mouseleaveTimeout = 200;\n\n    constructor(\n        private componentFactoryResolver: ComponentFactoryResolver,\n        private viewContainerRef: ViewContainerRef,\n        private service: DrDropdownService,\n        private el: ElementRef,\n        @Inject(DOCUMENT) private _document: any,\n    ) {}\n\n    @HostListener('mouseenter') elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click') elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave') leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout((_) => {\n                if (this.contentCmpRef && !this.contentCmpRef.instance.wasHovered) {\n                    this.contentCmpRef.destroy();\n                    this.contentCmpRef = null;\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup', ['$event']) documentClick(e) {\n        this.closeDropdown(e);\n    }\n\n    private openDropdown(): void {\n        const option = this.el.nativeElement.getBoundingClientRect();\n        this._document.querySelectorAll('dr-dropdown').forEach((item) => item.remove());\n        if (this.contentCmpRef && this.contentCmpRef.destroyCbs) {\n            this.contentCmpRef.destroy();\n            this.contentCmpRef = null;\n        } else {\n            this.service.destroy();\n            this.showMenu({\n                option,\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.position,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n            });\n        }\n    }\n\n    private closeDropdown(e): void {\n        if (!this.contentCmpRef) {\n            return;\n        }\n\n        const clickTarget = e.target;\n        const triggerElement = this.el.nativeElement;\n        const dropdownElement = this.contentCmpRef.location.nativeElement;\n        const isClickTriggerElement = triggerElement.contains(clickTarget) || triggerElement === clickTarget;\n        const isClickDropdownContents = dropdownElement.contains(clickTarget);\n\n        if (!isClickTriggerElement && !isClickDropdownContents) {\n            const elems = this._document.querySelectorAll('dr-dropdown');\n            setTimeout(() => elems.forEach((item) => item.remove()), 100);\n        }\n    }\n\n    private showMenu(options: IDropdown<T>) {\n        const componentFactory: ComponentFactory<DrDropdownComponent> =\n            this.componentFactoryResolver.resolveComponentFactory(DrDropdownComponent);\n        this.contentCmpRef = this.viewContainerRef.createComponent(componentFactory);\n        this.service.addMenu = this.contentCmpRef;\n        this._document.querySelector('dr-layout').appendChild(this.contentCmpRef.location.nativeElement);\n        this.contentCmpRef.instance.options = options;\n    }\n\n    public ngOnDestroy() {\n        if (this.contentCmpRef) {\n            this.contentCmpRef.destroy();\n        }\n    }\n}\n"]}
122
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDropdownChildDirective, [{
123
+ type: Directive,
124
+ args: [{
125
+ selector: '[drDropdownChild]',
126
+ }]
127
+ }], null, null); })();
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, OnDestroy, Output } from '@angular/core';\nimport { ElPosition, IDropdownAction, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrPopoverRef } from '../models/popover';\n\n@Directive({\n    selector: '[drDropdown]',\n    providers: [\n        {\n            provide: DropdownInstanceService,\n            useFactory: (injector: Injector) => {\n                const service = injector.get(DropdownInstanceService, null, { skipSelf: true });\n                return service ?? new DropdownInstanceService(injector);\n            },\n            deps: [Injector],\n        },\n    ],\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    private readonly elementRef = inject(ElementRef<HTMLElement>);\n    private readonly service = inject(DrDropdownService);\n    private readonly child = inject(DrDropdownChildDirective, { optional: true, self: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService);\n\n    @Input({ required: true })\n    drDropdown: IDropdownItem<T>[];\n    @Input()\n    drDropdownPosition: ElPosition = 'left-top';\n    @Input()\n    drDropdownClass: string;\n    @Input()\n    drDropdownInHover: boolean;\n\n    @Output()\n    drDropdownAction = new EventEmitter<IDropdownAction<T>>();\n\n    private ref: DrPopoverRef<DrDropdownComponent>;\n\n    private readonly mouseleaveTimeout = 200;\n\n    @HostListener('mouseenter')\n    elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click')\n    elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave')\n    leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(() => {\n                if (this.ref && !this.ref.instance.wasHovered) {\n                    this.close();\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup')\n    documentClick() {\n        this.close();\n    }\n\n    private openDropdown(): void {\n        if (!this.drDropdown?.length) {\n            return;\n        }\n\n        if (this.ref) {\n            this.close();\n            return;\n        }\n\n        this.ref = this.service.open({\n            hostRef: this.elementRef,\n            position: this.drDropdownPosition,\n            asChild: !!this.child,\n            providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],\n            action$: this.drDropdownAction,\n            options: {\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.drDropdownPosition,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n            },\n        });\n    }\n\n    private close(): void {\n        if (this.ref) {\n            this.ref.close();\n            this.ref = null;\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.close();\n    }\n}\n\n@Directive({\n    selector: '[drDropdownChild]',\n})\nexport class DrDropdownChildDirective {}\n"]}