@design-system-rte/angular 1.2.1-rc5 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/esm2022/lib/components/dropdown/dropdown-item/dropdown-item.component.mjs +157 -14
  2. package/esm2022/lib/components/dropdown/dropdown-menu/dropdown-menu.component.mjs +71 -6
  3. package/esm2022/lib/components/dropdown/dropdown.directive.mjs +48 -39
  4. package/esm2022/lib/components/dropdown/dropdown.types.mjs +2 -0
  5. package/esm2022/lib/components/dropdown/index.mjs +1 -3
  6. package/esm2022/lib/components/icon/icon-map.mjs +112 -112
  7. package/esm2022/lib/components/modal/modal.component.mjs +3 -3
  8. package/esm2022/lib/components/segmented-control/segmented-control.component.mjs +5 -3
  9. package/esm2022/lib/components/side-nav/side-nav.component.mjs +1 -1
  10. package/esm2022/lib/components/stepper/stepper.component.mjs +3 -3
  11. package/esm2022/lib/components/tab/tab-item/tab-item.component.mjs +3 -3
  12. package/esm2022/lib/components/tab/tab.component.mjs +1 -1
  13. package/esm2022/lib/components/tag/tag.component.mjs +4 -3
  14. package/esm2022/public-api.mjs +9 -1
  15. package/fesm2022/design-system-rte-angular.mjs +431 -219
  16. package/fesm2022/design-system-rte-angular.mjs.map +1 -1
  17. package/lib/components/assistive-text/assistive-text.component.d.ts +1 -1
  18. package/lib/components/chip/chip.component.d.ts +1 -1
  19. package/lib/components/dropdown/dropdown-item/dropdown-item.component.d.ts +28 -16
  20. package/lib/components/dropdown/dropdown-menu/dropdown-menu.component.d.ts +14 -3
  21. package/lib/components/dropdown/dropdown.directive.d.ts +8 -4
  22. package/lib/components/dropdown/dropdown.types.d.ts +30 -0
  23. package/lib/components/dropdown/index.d.ts +1 -0
  24. package/lib/components/segmented-control/segmented-control.component.d.ts +3 -1
  25. package/lib/components/side-nav/side-nav.component.d.ts +2 -2
  26. package/lib/components/tab/tab.component.d.ts +1 -1
  27. package/lib/components/tag/tag.component.d.ts +2 -1
  28. package/lib/components/text-input/base-text-input/base-text-input.component.d.ts +1 -1
  29. package/package.json +2 -2
  30. package/public-api.d.ts +8 -0
@@ -48,20 +48,25 @@ export class DropdownDirective {
48
48
  };
49
49
  });
50
50
  this.dropdownMenuRef = null;
51
+ this.itemEventSubscription = null;
51
52
  this.handleClickOutside = (event) => {
52
53
  const target = event.target;
53
- const isMenuItemClick = target.closest(".rte-dropdown-item") !== null;
54
- if (isMenuItemClick) {
55
- return;
56
- }
57
54
  const clickedInTrigger = this.hostElement.contains(target);
58
- const clickedInMenu = this.dropdownMenuRef?.location.nativeElement.contains(target);
59
- if (!clickedInTrigger && !clickedInMenu) {
60
- this.closeDropdown();
61
- this.clickedOutside.emit();
55
+ const dropdownMenuElement = this.dropdownMenuRef?.location.nativeElement;
56
+ const clickedInThisMenu = dropdownMenuElement ? dropdownMenuElement.contains(target) : false;
57
+ if (clickedInTrigger || clickedInThisMenu) {
58
+ return;
62
59
  }
60
+ this.closeDropdown();
61
+ this.clickedOutside.emit();
63
62
  };
64
63
  this.hostElement = this.elementRef.nativeElement;
64
+ this.destroyRef.onDestroy(() => {
65
+ this.unsubscribeItemEvent();
66
+ this.removeClickOutsideListener();
67
+ this.dropdownMenuRef?.destroy();
68
+ this.dropdownMenuRef = null;
69
+ });
65
70
  effect(() => {
66
71
  const isOpen = this.rteDropdownIsOpen();
67
72
  if (isOpen) {
@@ -92,9 +97,12 @@ export class DropdownDirective {
92
97
  }
93
98
  }
94
99
  onTriggerKeyEvent(event) {
95
- if (event.key === SPACE_KEY ||
100
+ const shouldOpen = event.key === SPACE_KEY ||
96
101
  event.key === ENTER_KEY ||
97
- (event.key === ARROW_DOWN_KEY && this.trigger()?.rteDropdownTriggerActivateWithArrowDown())) {
102
+ (event.key === ARROW_DOWN_KEY && this.trigger()?.rteDropdownTriggerActivateWithArrowDown());
103
+ if (shouldOpen) {
104
+ event.preventDefault();
105
+ event.stopPropagation();
98
106
  this.showDropdownMenu();
99
107
  if (this.rteDropdownAutofocus()) {
100
108
  waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));
@@ -103,31 +111,29 @@ export class DropdownDirective {
103
111
  }
104
112
  onMenuEvent(event) {
105
113
  this.menuEvent.emit(event);
106
- this.isActive.set(false);
107
- this.dropdownService.closeAllMenus();
114
+ if (!event.item?.children?.length) {
115
+ this.isActive.set(false);
116
+ this.dropdownService.closeAllMenus();
117
+ }
108
118
  }
109
119
  ngAfterContentInit() {
110
- if (this.trigger()) {
111
- this.trigger()?.dropdownTriggered.subscribe(() => {
112
- this.onTrigger();
113
- });
114
- this.trigger()?.dropdownKeyDown.subscribe((event) => {
115
- this.onTriggerKeyEvent(event);
116
- });
117
- this.trigger()?.dropdownTriggerClearContent.subscribe(() => {
118
- this.closeDropdown();
119
- });
120
- this.trigger()?.dropdownTriggerOpenDropdown.subscribe(() => {
121
- this.showDropdownMenu();
122
- });
123
- this.trigger()?.dropdownTriggerCloseDropdown.subscribe(() => {
124
- this.closeDropdown();
125
- });
126
- }
120
+ const trigger = this.trigger();
121
+ if (!trigger)
122
+ return;
123
+ const triggerSubscriptions = [
124
+ trigger.dropdownTriggered.subscribe(() => this.onTrigger()),
125
+ trigger.dropdownKeyDown.subscribe((event) => this.onTriggerKeyEvent(event)),
126
+ trigger.dropdownTriggerClearContent.subscribe(() => this.closeDropdown()),
127
+ trigger.dropdownTriggerOpenDropdown.subscribe(() => this.showDropdownMenu()),
128
+ trigger.dropdownTriggerCloseDropdown.subscribe(() => this.closeDropdown()),
129
+ ];
130
+ this.destroyRef.onDestroy(() => triggerSubscriptions.forEach((subscription) => subscription.unsubscribe()));
127
131
  }
128
132
  showDropdownMenu() {
133
+ this.unsubscribeItemEvent();
129
134
  if (this.dropdownMenuRef) {
130
135
  this.dropdownMenuRef.destroy();
136
+ this.dropdownMenuRef = null;
131
137
  }
132
138
  this.dropdownMenuRef = this.overlayService.create(DropdownMenuComponent, this.viewContainerRef);
133
139
  const menuId = this.rteDropdownId() || this.dropdownId;
@@ -136,12 +142,11 @@ export class DropdownDirective {
136
142
  this.assignInputs();
137
143
  this.positionDropdownMenu(this.rteDropdownPosition());
138
144
  this.addClickOutsideListener();
139
- this.dropdownMenuRef.instance.itemEvent.subscribe((event) => {
140
- this.onMenuEvent(event);
141
- });
145
+ this.itemEventSubscription = this.dropdownMenuRef.instance.itemEvent.subscribe((event) => this.onMenuEvent(event));
142
146
  const dropdownStateSubscription = this.dropdownService.state$.subscribe((state) => {
143
147
  if (state === null) {
144
148
  if (this.dropdownMenuRef) {
149
+ this.unsubscribeItemEvent();
145
150
  this.dropdownMenuRef.destroy();
146
151
  this.dropdownMenuRef = null;
147
152
  this.removeClickOutsideListener();
@@ -187,7 +192,13 @@ export class DropdownDirective {
187
192
  if (triggerElement) {
188
193
  this.renderer.setStyle(dropdownMenuElement, "display", "block");
189
194
  this.cdr.detectChanges();
190
- const computedPosition = position === "auto" ? getAutoPlacementDropdown(triggerElement, dropdownMenuElement, "bottom") : position;
195
+ const computedPosition = position === "auto"
196
+ ? getAutoPlacementDropdown({
197
+ hostElement: triggerElement,
198
+ castedElement: dropdownMenuElement,
199
+ defaultPosition: "bottom",
200
+ })
201
+ : position;
191
202
  const autoAlignment = this.rteDropdownAlignment() ?? getAutoAlignment(triggerElement, dropdownMenuElement, computedPosition);
192
203
  const computedCoordinates = getCoordinates(computedPosition, triggerElement, dropdownMenuElement.children[0], this.rteDropdownOffset(), autoAlignment);
193
204
  this.renderer.setStyle(dropdownMenuElement, "top", `${computedCoordinates.top}px`);
@@ -196,11 +207,9 @@ export class DropdownDirective {
196
207
  }
197
208
  }
198
209
  }
199
- ngOnDestroy() {
200
- this.removeClickOutsideListener();
201
- if (this.dropdownMenuRef) {
202
- this.dropdownMenuRef.destroy();
203
- }
210
+ unsubscribeItemEvent() {
211
+ this.itemEventSubscription?.unsubscribe();
212
+ this.itemEventSubscription = null;
204
213
  }
205
214
  addClickOutsideListener() {
206
215
  document.addEventListener("mousedown", this.handleClickOutside);
@@ -229,4 +238,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
229
238
  standalone: true,
230
239
  }]
231
240
  }], ctorParameters: () => [] });
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../../projects/ds-rte-lib/src/lib/components/dropdown/dropdown.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EAEjB,QAAQ,EACR,YAAY,EACZ,UAAU,EACV,SAAS,EACT,MAAM,EACN,UAAU,EACV,MAAM,EACN,KAAK,EAEL,MAAM,EACN,SAAS,EACT,MAAM,EACN,gBAAgB,GACjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAE,2BAA2B,EAAE,MAAM,gEAAgE,CAAC;AAC7G,OAAO,EACL,gBAAgB,EAChB,wBAAwB,EACxB,cAAc,GACf,MAAM,yDAAyD,CAAC;AACjE,OAAO,EAAE,uBAAuB,EAAE,MAAM,qDAAqD,CAAC;AAC9F,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,+DAA+D,CAAC;AAErH,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAEhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAC;AACzF,OAAO,EAAE,yBAAyB,EAAE,MAAM,kBAAkB,CAAC;;AAU7D,MAAM,OAAO,iBAAiB;aACb,cAAS,GAAG,CAAC,AAAJ,CAAK;IA4C7B;QA1CS,YAAO,GAAG,YAAY,CAAC,wBAAwB,CAAC,CAAC;QACjD,SAAI,GAAG,YAAY,CAAC,qBAAqB,CAAC,CAAC;QAE3C,kBAAa,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACrD,wBAAmB,GAAG,KAAK,CAAW,QAAQ,CAAC,CAAC;QAChD,yBAAoB,GAAG,KAAK,CAAY,OAAO,CAAC,CAAC;QACjD,sBAAiB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC1C,sBAAiB,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;QACrC,yBAAoB,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAC5C,wBAAmB,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAC3C,qBAAgB,GAAG,KAAK,CAAgB,IAAI,CAAC,CAAC;QAE9C,cAAS,GAAG,MAAM,EAAgC,CAAC;QACnD,eAAU,GAAG,YAAY,EAAE,iBAAiB,CAAC,SAAS,EAAE,CAAC;QAEzD,mBAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAE7B,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEhC,mBAAc,GAAG,MAAM,EAAQ,CAAC;QAChC,mBAAc,GAAG,MAAM,EAAQ,CAAC;QAEhC,aAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEzB,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YAClC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,OAAO,IAAI,CAAC;YACd,CAAC;YACD,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;gBACnB,cAAc,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,WAAW;gBACnD,cAAc,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,WAAW;gBACnD,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;aACpB,CAAC;QACJ,CAAC,CAAC,CAAC;QA2BH,oBAAe,GAA+C,IAAI,CAAC;QA4JlD,uBAAkB,GAAG,CAAC,KAAiB,EAAQ,EAAE;YAChE,MAAM,MAAM,GAAG,KAAK,CAAC,MAAiB,CAAC;YAEvC,MAAM,eAAe,GAAG,MAAM,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,IAAI,CAAC;YACtE,IAAI,eAAe,EAAE,CAAC;gBACpB,OAAO;YACT,CAAC;YAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC3D,MAAM,aAAa,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAEpF,IAAI,CAAC,gBAAgB,IAAI,CAAC,aAAa,EAAE,CAAC;gBACxC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;YAC7B,CAAC;QACH,CAAC,CAAC;QAnMA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAEjD,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACxC,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;oBAC1B,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,IAAI,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;wBAChC,gBAAgB,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;oBACrE,CAAC;gBACH,CAAC;YACH,CAAC;iBAAM,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBAChC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;YACvC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACjC,IAAI,IAAI,CAAC,eAAe,IAAI,MAAM,EAAE,CAAC;gBACnC,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAID,SAAS;QACP,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC;YAC/B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;QACD,IAAI,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;YAChC,gBAAgB,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,KAAoB;QACpC,IACE,KAAK,CAAC,GAAG,KAAK,SAAS;YACvB,KAAK,CAAC,GAAG,KAAK,SAAS;YACvB,CAAC,KAAK,CAAC,GAAG,KAAK,cAAc,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,uCAAuC,EAAE,CAAC,EAC3F,CAAC;YACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;gBAChC,gBAAgB,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACrE,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,KAAmC;QAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,EAAE,EAAE,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC/C,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,OAAO,EAAE,EAAE,eAAe,CAAC,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;gBACjE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAChC,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,OAAO,EAAE,EAAE,2BAA2B,CAAC,SAAS,CAAC,GAAG,EAAE;gBACzD,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,EAAE,EAAE,2BAA2B,CAAC,SAAS,CAAC,GAAG,EAAE;gBACzD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,EAAE,EAAE,4BAA4B,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC1D,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QACjC,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,qBAAqB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAEhG,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,UAAU,CAAC;QAEvD,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEhD,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAEtC,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAE/B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,KAAmC,EAAE,EAAE;YACxF,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,MAAM,yBAAyB,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAChF,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;gBACnB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;oBACzB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;oBAC/B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;oBAE5B,IAAI,CAAC,0BAA0B,EAAE,CAAC;oBAClC,yBAAyB,CAAC,WAAW,EAAE,CAAC;oBACxC,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAC7E,uBAAuB,CACxB,CAAC,CAAC,CAAgB,CAAC;oBACpB,IAAI,aAAa,EAAE,CAAC;wBAClB,aAAa,CAAC,KAAK,EAAE,CAAC;oBACxB,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;oBACnD,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3E,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;YACzC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAC9C,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,gBAAgB,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,eAAe,EAAE,EAAE,WAAW,CAAC,CAAC;YAC7F,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,gBAAgB,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,eAAe,EAAE,EAAE,WAAW,CAAC,CAAC;QAC/F,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,KAAK,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAClE,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YAC1C,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAC9C,gBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QACzE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAEO,oBAAoB,CAAC,WAAqB,QAAQ;QACxD,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YAC3C,MAAM,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,aAAa,CAAC;YACxE,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,aAAa,CAAC;YAEhE,IAAI,cAAc,EAAE,CAAC;gBACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;gBAChE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBACzB,MAAM,gBAAgB,GACpB,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,wBAAwB,CAAC,cAAc,EAAE,mBAAmB,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAC3G,MAAM,aAAa,GACjB,IAAI,CAAC,oBAAoB,EAAE,IAAI,gBAAgB,CAAC,cAAc,EAAE,mBAAmB,EAAE,gBAAgB,CAAC,CAAC;gBACzG,MAAM,mBAAmB,GAAG,cAAc,CACxC,gBAAgB,EAChB,cAAc,EACd,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,EAC/B,IAAI,CAAC,iBAAiB,EAAE,EACxB,aAAa,CACd,CAAC;gBAEF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,GAAG,IAAI,CAAC,CAAC;gBACnF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAAC,IAAI,IAAI,CAAC,CAAC;gBAErF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;YAC9D,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IAmBO,uBAAuB;QAC7B,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAClE,CAAC;IAEO,0BAA0B;QAChC,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;IACrE,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEzB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC,EAAE,2BAA2B,CAAC,CAAC;IAClC,CAAC;+GAlQU,iBAAiB;mGAAjB,iBAAiB,6iDAGI,wBAAwB,uFAC3B,qBAAqB;;4FAJvC,iBAAiB;kBAR7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,IAAI,EAAE;wBACJ,kBAAkB,EAAE,MAAM;wBAC1B,yBAAyB,EAAE,YAAY;qBACxC;oBACD,UAAU,EAAE,IAAI;iBACjB","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  ComponentRef,\n  computed,\n  contentChild,\n  DestroyRef,\n  Directive,\n  effect,\n  ElementRef,\n  inject,\n  input,\n  OnDestroy,\n  output,\n  Renderer2,\n  signal,\n  ViewContainerRef,\n} from \"@angular/core\";\nimport { Alignment, Position } from \"@design-system-rte/core\";\nimport { waitForNextFrame } from \"@design-system-rte/core/common/animation\";\nimport { DROPDOWN_ANIMATION_DURATION } from \"@design-system-rte/core/components/dropdown/dropdown.constants\";\nimport {\n  getAutoAlignment,\n  getAutoPlacementDropdown,\n  getCoordinates,\n} from \"@design-system-rte/core/components/utils/auto-placement\";\nimport { FOCUSABLE_BUTTONS_QUERY } from \"@design-system-rte/core/constants/dom/dom.constants\";\nimport { ARROW_DOWN_KEY, ENTER_KEY, SPACE_KEY } from \"@design-system-rte/core/constants/keyboard/keyboard.constants\";\n\nimport { DropdownService } from \"../../services/dropdown.service\";\nimport { OverlayService } from \"../../services/overlay.service\";\n\nimport { DropdownMenuComponent } from \"./dropdown-menu/dropdown-menu.component\";\nimport { DropdownTriggerDirective } from \"./dropdown-trigger/dropdown-trigger.directive\";\nimport { focusDropdownFirstElement } from \"./dropdown.utils\";\n\n@Directive({\n  selector: \"[rteDropdown]\",\n  host: {\n    \"[class.dropdown]\": \"true\",\n    \"[attr.data-dropdown-id]\": \"dropdownId\",\n  },\n  standalone: true,\n})\nexport class DropdownDirective implements AfterContentInit, OnDestroy {\n  private static idCounter = 0;\n\n  readonly trigger = contentChild(DropdownTriggerDirective);\n  readonly menu = contentChild(DropdownMenuComponent);\n\n  readonly rteDropdownId = input<string | undefined>(undefined);\n  readonly rteDropdownPosition = input<Position>(\"bottom\");\n  readonly rteDropdownAlignment = input<Alignment>(\"start\");\n  readonly rteDropdownIsOpen = input<boolean>(false);\n  readonly rteDropdownOffset = input<number>(0);\n  readonly rteDropdownAutofocus = input<boolean>(true);\n  readonly rteDropdownAutoOpen = input<boolean>(true);\n  readonly rteDropdownWidth = input<number | null>(null);\n\n  readonly menuEvent = output<{ event: Event; id: string }>();\n  readonly dropdownId = `dropdown_${++DropdownDirective.idCounter}`;\n\n  readonly overlayService = inject(OverlayService);\n  readonly dropdownService = inject(DropdownService);\n  readonly viewContainerRef = inject(ViewContainerRef);\n  readonly elementRef = inject(ElementRef);\n  readonly renderer = inject(Renderer2);\n  readonly hostElement: HTMLElement;\n  readonly destroyRef = inject(DestroyRef);\n  readonly cdr = inject(ChangeDetectorRef);\n\n  readonly clickedOutside = output<void>();\n  readonly closedDropdown = output<void>();\n\n  readonly isActive = signal(false);\n\n  readonly menuInputs = computed(() => {\n    const menu = this.menu();\n    if (!menu) {\n      return null;\n    }\n    return {\n      items: menu.items(),\n      headerTemplate: menu.headerDirective()?.templateRef,\n      footerTemplate: menu.footerDirective()?.templateRef,\n      width: menu.width(),\n    };\n  });\n\n  constructor() {\n    this.hostElement = this.elementRef.nativeElement;\n\n    effect(() => {\n      const isOpen = this.rteDropdownIsOpen();\n      if (isOpen) {\n        if (!this.dropdownMenuRef) {\n          this.showDropdownMenu();\n          if (this.rteDropdownAutofocus()) {\n            waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n          }\n        }\n      } else if (this.dropdownMenuRef) {\n        this.dropdownService.closeAllMenus();\n      }\n    });\n\n    effect(() => {\n      const inputs = this.menuInputs();\n      if (this.dropdownMenuRef && inputs) {\n        this.assignInputs();\n      }\n    });\n  }\n\n  dropdownMenuRef: ComponentRef<DropdownMenuComponent> | null = null;\n\n  onTrigger(): void {\n    if (this.rteDropdownAutoOpen()) {\n      this.showDropdownMenu();\n    }\n    if (this.rteDropdownAutofocus()) {\n      waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n    }\n  }\n\n  onTriggerKeyEvent(event: KeyboardEvent): void {\n    if (\n      event.key === SPACE_KEY ||\n      event.key === ENTER_KEY ||\n      (event.key === ARROW_DOWN_KEY && this.trigger()?.rteDropdownTriggerActivateWithArrowDown())\n    ) {\n      this.showDropdownMenu();\n      if (this.rteDropdownAutofocus()) {\n        waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n      }\n    }\n  }\n\n  onMenuEvent(event: { event: Event; id: string }): void {\n    this.menuEvent.emit(event);\n    this.isActive.set(false);\n    this.dropdownService.closeAllMenus();\n  }\n\n  ngAfterContentInit(): void {\n    if (this.trigger()) {\n      this.trigger()?.dropdownTriggered.subscribe(() => {\n        this.onTrigger();\n      });\n\n      this.trigger()?.dropdownKeyDown.subscribe((event: KeyboardEvent) => {\n        this.onTriggerKeyEvent(event);\n      });\n\n      this.trigger()?.dropdownTriggerClearContent.subscribe(() => {\n        this.closeDropdown();\n      });\n      this.trigger()?.dropdownTriggerOpenDropdown.subscribe(() => {\n        this.showDropdownMenu();\n      });\n      this.trigger()?.dropdownTriggerCloseDropdown.subscribe(() => {\n        this.closeDropdown();\n      });\n    }\n  }\n\n  showDropdownMenu(): void {\n    if (this.dropdownMenuRef) {\n      this.dropdownMenuRef.destroy();\n    }\n\n    this.dropdownMenuRef = this.overlayService.create(DropdownMenuComponent, this.viewContainerRef);\n\n    const menuId = this.rteDropdownId() || this.dropdownId;\n\n    this.dropdownMenuRef.setInput(\"menuId\", menuId);\n\n    this.dropdownService.openMenu(menuId);\n\n    this.assignInputs();\n    this.positionDropdownMenu(this.rteDropdownPosition());\n    this.addClickOutsideListener();\n\n    this.dropdownMenuRef.instance.itemEvent.subscribe((event: { event: Event; id: string }) => {\n      this.onMenuEvent(event);\n    });\n\n    const dropdownStateSubscription = this.dropdownService.state$.subscribe((state) => {\n      if (state === null) {\n        if (this.dropdownMenuRef) {\n          this.dropdownMenuRef.destroy();\n          this.dropdownMenuRef = null;\n\n          this.removeClickOutsideListener();\n          dropdownStateSubscription.unsubscribe();\n          const buttonTrigger = this.trigger()?.elementRef.nativeElement.querySelectorAll(\n            FOCUSABLE_BUTTONS_QUERY,\n          )[0] as HTMLElement;\n          if (buttonTrigger) {\n            buttonTrigger.focus();\n          } else {\n            this.trigger()?.elementRef.nativeElement.focus();\n          }\n        }\n      }\n    });\n\n    this.destroyRef.onDestroy(() => dropdownStateSubscription.unsubscribe());\n  }\n\n  private assignInputs(): void {\n    if (this.dropdownMenuRef) {\n      const items = this.menu()?.items() ?? [];\n      this.dropdownMenuRef.setInput(\"items\", items);\n      this.dropdownMenuRef.setInput(\"headerTemplate\", this.menu()?.headerDirective()?.templateRef);\n      this.dropdownMenuRef.setInput(\"footerTemplate\", this.menu()?.footerDirective()?.templateRef);\n    }\n\n    this.assignWidth();\n  }\n\n  private assignWidth(): void {\n    if (!this.dropdownMenuRef) {\n      return;\n    }\n\n    const width = this.menuInputs()?.width ?? this.rteDropdownWidth();\n    if (width !== undefined && width !== null) {\n      this.dropdownMenuRef.setInput(\"width\", width);\n      waitForNextFrame(() => this.dropdownMenuRef?.setInput(\"isOpen\", true));\n    } else {\n      this.dropdownMenuRef.setInput(\"isOpen\", true);\n    }\n  }\n\n  private positionDropdownMenu(position: Position = \"bottom\"): void {\n    if (this.dropdownMenuRef && this.trigger()) {\n      const dropdownMenuElement = this.dropdownMenuRef.location.nativeElement;\n      const triggerElement = this.trigger()?.elementRef.nativeElement;\n\n      if (triggerElement) {\n        this.renderer.setStyle(dropdownMenuElement, \"display\", \"block\");\n        this.cdr.detectChanges();\n        const computedPosition: Exclude<Position, \"auto\"> =\n          position === \"auto\" ? getAutoPlacementDropdown(triggerElement, dropdownMenuElement, \"bottom\") : position;\n        const autoAlignment =\n          this.rteDropdownAlignment() ?? getAutoAlignment(triggerElement, dropdownMenuElement, computedPosition);\n        const computedCoordinates = getCoordinates(\n          computedPosition,\n          triggerElement,\n          dropdownMenuElement.children[0],\n          this.rteDropdownOffset(),\n          autoAlignment,\n        );\n\n        this.renderer.setStyle(dropdownMenuElement, \"top\", `${computedCoordinates.top}px`);\n        this.renderer.setStyle(dropdownMenuElement, \"left\", `${computedCoordinates.left}px`);\n\n        this.renderer.setStyle(dropdownMenuElement, \"opacity\", \"1\");\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.removeClickOutsideListener();\n    if (this.dropdownMenuRef) {\n      this.dropdownMenuRef.destroy();\n    }\n  }\n\n  private readonly handleClickOutside = (event: MouseEvent): void => {\n    const target = event.target as Element;\n\n    const isMenuItemClick = target.closest(\".rte-dropdown-item\") !== null;\n    if (isMenuItemClick) {\n      return;\n    }\n\n    const clickedInTrigger = this.hostElement.contains(target);\n    const clickedInMenu = this.dropdownMenuRef?.location.nativeElement.contains(target);\n\n    if (!clickedInTrigger && !clickedInMenu) {\n      this.closeDropdown();\n      this.clickedOutside.emit();\n    }\n  };\n\n  private addClickOutsideListener(): void {\n    document.addEventListener(\"mousedown\", this.handleClickOutside);\n  }\n\n  private removeClickOutsideListener(): void {\n    document.removeEventListener(\"mousedown\", this.handleClickOutside);\n  }\n\n  private closeDropdown(): void {\n    this.dropdownMenuRef?.setInput(\"isOpen\", false);\n    this.isActive.set(false);\n\n    setTimeout(() => {\n      this.dropdownService.closeAllMenus();\n    }, DROPDOWN_ANIMATION_DURATION);\n  }\n}\n"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../../projects/ds-rte-lib/src/lib/components/dropdown/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  ComponentRef,\n  computed,\n  contentChild,\n  DestroyRef,\n  Directive,\n  effect,\n  ElementRef,\n  inject,\n  input,\n  output,\n  Renderer2,\n  signal,\n  ViewContainerRef,\n} from \"@angular/core\";\nimport { Alignment, Position } from \"@design-system-rte/core\";\nimport { waitForNextFrame } from \"@design-system-rte/core/common/animation\";\nimport { DROPDOWN_ANIMATION_DURATION } from \"@design-system-rte/core/components/dropdown/dropdown.constants\";\nimport {\n  getAutoAlignment,\n  getAutoPlacementDropdown,\n  getCoordinates,\n} from \"@design-system-rte/core/components/utils/auto-placement\";\nimport { FOCUSABLE_BUTTONS_QUERY } from \"@design-system-rte/core/constants/dom/dom.constants\";\nimport { ARROW_DOWN_KEY, ENTER_KEY, SPACE_KEY } from \"@design-system-rte/core/constants/keyboard/keyboard.constants\";\n\nimport { DropdownService } from \"../../services/dropdown.service\";\nimport { OverlayService } from \"../../services/overlay.service\";\n\nimport { DropdownMenuComponent } from \"./dropdown-menu/dropdown-menu.component\";\nimport { DropdownTriggerDirective } from \"./dropdown-trigger/dropdown-trigger.directive\";\nimport { DropdownItemConfig } from \"./dropdown.types\";\nimport { focusDropdownFirstElement } from \"./dropdown.utils\";\n\n@Directive({\n  selector: \"[rteDropdown]\",\n  host: {\n    \"[class.dropdown]\": \"true\",\n    \"[attr.data-dropdown-id]\": \"dropdownId\",\n  },\n  standalone: true,\n})\nexport class DropdownDirective implements AfterContentInit {\n  private static idCounter = 0;\n\n  readonly trigger = contentChild(DropdownTriggerDirective);\n  readonly menu = contentChild(DropdownMenuComponent);\n\n  readonly rteDropdownId = input<string | undefined>(undefined);\n  readonly rteDropdownPosition = input<Position>(\"bottom\");\n  readonly rteDropdownAlignment = input<Alignment>(\"start\");\n  readonly rteDropdownIsOpen = input<boolean>(false);\n  readonly rteDropdownOffset = input<number>(0);\n  readonly rteDropdownAutofocus = input<boolean>(true);\n  readonly rteDropdownAutoOpen = input<boolean>(true);\n  readonly rteDropdownWidth = input<number | null>(null);\n\n  readonly menuEvent = output<{ event: Event; id: string; item?: DropdownItemConfig }>();\n  readonly dropdownId = `dropdown_${++DropdownDirective.idCounter}`;\n\n  readonly overlayService = inject(OverlayService);\n  readonly dropdownService = inject(DropdownService);\n  readonly viewContainerRef = inject(ViewContainerRef);\n  readonly elementRef = inject(ElementRef);\n  readonly renderer = inject(Renderer2);\n  readonly hostElement: HTMLElement;\n  readonly destroyRef = inject(DestroyRef);\n  readonly cdr = inject(ChangeDetectorRef);\n\n  readonly clickedOutside = output<void>();\n  readonly closedDropdown = output<void>();\n\n  readonly isActive = signal(false);\n\n  readonly menuInputs = computed(() => {\n    const menu = this.menu();\n    if (!menu) {\n      return null;\n    }\n    return {\n      items: menu.items(),\n      headerTemplate: menu.headerDirective()?.templateRef,\n      footerTemplate: menu.footerDirective()?.templateRef,\n      width: menu.width(),\n    };\n  });\n\n  constructor() {\n    this.hostElement = this.elementRef.nativeElement;\n\n    this.destroyRef.onDestroy(() => {\n      this.unsubscribeItemEvent();\n      this.removeClickOutsideListener();\n      this.dropdownMenuRef?.destroy();\n      this.dropdownMenuRef = null;\n    });\n\n    effect(() => {\n      const isOpen = this.rteDropdownIsOpen();\n      if (isOpen) {\n        if (!this.dropdownMenuRef) {\n          this.showDropdownMenu();\n          if (this.rteDropdownAutofocus()) {\n            waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n          }\n        }\n      } else if (this.dropdownMenuRef) {\n        this.dropdownService.closeAllMenus();\n      }\n    });\n\n    effect(() => {\n      const inputs = this.menuInputs();\n      if (this.dropdownMenuRef && inputs) {\n        this.assignInputs();\n      }\n    });\n  }\n\n  dropdownMenuRef: ComponentRef<DropdownMenuComponent> | null = null;\n  private itemEventSubscription: { unsubscribe: () => void } | null = null;\n\n  onTrigger(): void {\n    if (this.rteDropdownAutoOpen()) {\n      this.showDropdownMenu();\n    }\n    if (this.rteDropdownAutofocus()) {\n      waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n    }\n  }\n\n  onTriggerKeyEvent(event: KeyboardEvent): void {\n    const shouldOpen =\n      event.key === SPACE_KEY ||\n      event.key === ENTER_KEY ||\n      (event.key === ARROW_DOWN_KEY && this.trigger()?.rteDropdownTriggerActivateWithArrowDown());\n\n    if (shouldOpen) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.showDropdownMenu();\n      if (this.rteDropdownAutofocus()) {\n        waitForNextFrame(() => focusDropdownFirstElement(this.dropdownId));\n      }\n    }\n  }\n\n  onMenuEvent(event: { event: Event; id: string; item?: DropdownItemConfig }): void {\n    this.menuEvent.emit(event);\n    if (!event.item?.children?.length) {\n      this.isActive.set(false);\n      this.dropdownService.closeAllMenus();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    const trigger = this.trigger();\n    if (!trigger) return;\n\n    const triggerSubscriptions = [\n      trigger.dropdownTriggered.subscribe(() => this.onTrigger()),\n      trigger.dropdownKeyDown.subscribe((event: KeyboardEvent) => this.onTriggerKeyEvent(event)),\n      trigger.dropdownTriggerClearContent.subscribe(() => this.closeDropdown()),\n      trigger.dropdownTriggerOpenDropdown.subscribe(() => this.showDropdownMenu()),\n      trigger.dropdownTriggerCloseDropdown.subscribe(() => this.closeDropdown()),\n    ];\n    this.destroyRef.onDestroy(() => triggerSubscriptions.forEach((subscription) => subscription.unsubscribe()));\n  }\n\n  showDropdownMenu(): void {\n    this.unsubscribeItemEvent();\n    if (this.dropdownMenuRef) {\n      this.dropdownMenuRef.destroy();\n      this.dropdownMenuRef = null;\n    }\n\n    this.dropdownMenuRef = this.overlayService.create(DropdownMenuComponent, this.viewContainerRef);\n\n    const menuId = this.rteDropdownId() || this.dropdownId;\n\n    this.dropdownMenuRef.setInput(\"menuId\", menuId);\n\n    this.dropdownService.openMenu(menuId);\n\n    this.assignInputs();\n    this.positionDropdownMenu(this.rteDropdownPosition());\n    this.addClickOutsideListener();\n\n    this.itemEventSubscription = this.dropdownMenuRef.instance.itemEvent.subscribe(\n      (event: { event: Event; id: string; item?: DropdownItemConfig }) => this.onMenuEvent(event),\n    );\n\n    const dropdownStateSubscription = this.dropdownService.state$.subscribe((state) => {\n      if (state === null) {\n        if (this.dropdownMenuRef) {\n          this.unsubscribeItemEvent();\n          this.dropdownMenuRef.destroy();\n          this.dropdownMenuRef = null;\n\n          this.removeClickOutsideListener();\n          dropdownStateSubscription.unsubscribe();\n          const buttonTrigger = this.trigger()?.elementRef.nativeElement.querySelectorAll(\n            FOCUSABLE_BUTTONS_QUERY,\n          )[0] as HTMLElement;\n          if (buttonTrigger) {\n            buttonTrigger.focus();\n          } else {\n            this.trigger()?.elementRef.nativeElement.focus();\n          }\n        }\n      }\n    });\n\n    this.destroyRef.onDestroy(() => dropdownStateSubscription.unsubscribe());\n  }\n\n  private assignInputs(): void {\n    if (this.dropdownMenuRef) {\n      const items = this.menu()?.items() ?? [];\n      this.dropdownMenuRef.setInput(\"items\", items);\n      this.dropdownMenuRef.setInput(\"headerTemplate\", this.menu()?.headerDirective()?.templateRef);\n      this.dropdownMenuRef.setInput(\"footerTemplate\", this.menu()?.footerDirective()?.templateRef);\n    }\n\n    this.assignWidth();\n  }\n\n  private assignWidth(): void {\n    if (!this.dropdownMenuRef) {\n      return;\n    }\n\n    const width = this.menuInputs()?.width ?? this.rteDropdownWidth();\n    if (width !== undefined && width !== null) {\n      this.dropdownMenuRef.setInput(\"width\", width);\n      waitForNextFrame(() => this.dropdownMenuRef?.setInput(\"isOpen\", true));\n    } else {\n      this.dropdownMenuRef.setInput(\"isOpen\", true);\n    }\n  }\n\n  private positionDropdownMenu(position: Position = \"bottom\"): void {\n    if (this.dropdownMenuRef && this.trigger()) {\n      const dropdownMenuElement = this.dropdownMenuRef.location.nativeElement;\n      const triggerElement = this.trigger()?.elementRef.nativeElement;\n\n      if (triggerElement) {\n        this.renderer.setStyle(dropdownMenuElement, \"display\", \"block\");\n        this.cdr.detectChanges();\n        const computedPosition: Exclude<Position, \"auto\"> =\n          position === \"auto\"\n            ? getAutoPlacementDropdown({\n                hostElement: triggerElement,\n                castedElement: dropdownMenuElement,\n                defaultPosition: \"bottom\",\n              })\n            : position;\n        const autoAlignment =\n          this.rteDropdownAlignment() ?? getAutoAlignment(triggerElement, dropdownMenuElement, computedPosition);\n        const computedCoordinates = getCoordinates(\n          computedPosition,\n          triggerElement,\n          dropdownMenuElement.children[0],\n          this.rteDropdownOffset(),\n          autoAlignment,\n        );\n\n        this.renderer.setStyle(dropdownMenuElement, \"top\", `${computedCoordinates.top}px`);\n        this.renderer.setStyle(dropdownMenuElement, \"left\", `${computedCoordinates.left}px`);\n\n        this.renderer.setStyle(dropdownMenuElement, \"opacity\", \"1\");\n      }\n    }\n  }\n\n  private unsubscribeItemEvent(): void {\n    this.itemEventSubscription?.unsubscribe();\n    this.itemEventSubscription = null;\n  }\n\n  private readonly handleClickOutside = (event: MouseEvent): void => {\n    const target = event.target as Element;\n\n    const clickedInTrigger = this.hostElement.contains(target);\n    const dropdownMenuElement = this.dropdownMenuRef?.location.nativeElement as HTMLElement | undefined;\n    const clickedInThisMenu = dropdownMenuElement ? dropdownMenuElement.contains(target) : false;\n    if (clickedInTrigger || clickedInThisMenu) {\n      return;\n    }\n\n    this.closeDropdown();\n    this.clickedOutside.emit();\n  };\n\n  private addClickOutsideListener(): void {\n    document.addEventListener(\"mousedown\", this.handleClickOutside);\n  }\n\n  private removeClickOutsideListener(): void {\n    document.removeEventListener(\"mousedown\", this.handleClickOutside);\n  }\n\n  private closeDropdown(): void {\n    this.dropdownMenuRef?.setInput(\"isOpen\", false);\n    this.isActive.set(false);\n\n    setTimeout(() => {\n      this.dropdownService.closeAllMenus();\n    }, DROPDOWN_ANIMATION_DURATION);\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24udHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kcy1ydGUtbGliL3NyYy9saWIvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50UmVmLCBFdmVudEVtaXR0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgRHJvcGRvd25JdGVtUHJvcHMgfSBmcm9tIFwiQGRlc2lnbi1zeXN0ZW0tcnRlL2NvcmUvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi5pbnRlcmZhY2VcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTdWJtZW51Q3JlYXRlZFJlc3VsdCB7XG4gIGNvbXBvbmVudFJlZjogQ29tcG9uZW50UmVmPHVua25vd24+O1xuICBob3N0RWxlbWVudDogSFRNTEVsZW1lbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3VibWVudVJlcXVlc3RFdmVudCB7XG4gIGNoaWxkcmVuOiBEcm9wZG93bkl0ZW1Db25maWdbXTtcbiAgY2hpbGRJZDogc3RyaW5nO1xuICB0cmlnZ2VyRWxlbWVudDogSFRNTEVsZW1lbnQ7XG4gIG9uQ3JlYXRlZDogKHJlc3VsdDogU3VibWVudUNyZWF0ZWRSZXN1bHQpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJvcGRvd25JdGVtQ29uZmlnIGV4dGVuZHMgT21pdDxEcm9wZG93bkl0ZW1Qcm9wcywgXCJvbkNsaWNrXCI+IHtcbiAgaWQ/OiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbiAgbGFiZWw6IHN0cmluZztcbiAgbGVmdEljb24/OiBzdHJpbmc7XG4gIHRyYWlsaW5nVGV4dD86IHN0cmluZztcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBoYXNTZXBhcmF0b3I/OiBib29sZWFuO1xuICBoYXNJbmRlbnQ/OiBib29sZWFuO1xuICBsaW5rPzogc3RyaW5nO1xuICBjbGljaz86IEV2ZW50RW1pdHRlcjxFdmVudD47XG4gIGNoaWxkcmVuPzogRHJvcGRvd25JdGVtQ29uZmlnW107XG59XG5cbmV4cG9ydCB0eXBlIERyb3Bkb3duSXRlbUV2ZW50ID0ge1xuICBldmVudDogRXZlbnQ7XG4gIGlkOiBzdHJpbmc7XG4gIGl0ZW0/OiBEcm9wZG93bkl0ZW1Db25maWc7XG59O1xuIl19
@@ -1,8 +1,6 @@
1
- // Main dropdown module - import this to get everything
2
1
  export { DropdownModule } from "./dropdown.module";
3
- // Individual exports for advanced use cases
4
2
  export { DropdownDirective } from "./dropdown.directive";
5
3
  export { DropdownTriggerDirective } from "./dropdown-trigger/dropdown-trigger.directive";
6
4
  export { DropdownMenuComponent } from "./dropdown-menu/dropdown-menu.component";
7
5
  export { DropdownItemComponent } from "./dropdown-item/dropdown-item.component";
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kcy1ydGUtbGliL3NyYy9saWIvY29tcG9uZW50cy9kcm9wZG93bi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5ELDRDQUE0QztBQUM1QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUN6RixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIE1haW4gZHJvcGRvd24gbW9kdWxlIC0gaW1wb3J0IHRoaXMgdG8gZ2V0IGV2ZXJ5dGhpbmdcbmV4cG9ydCB7IERyb3Bkb3duTW9kdWxlIH0gZnJvbSBcIi4vZHJvcGRvd24ubW9kdWxlXCI7XG5cbi8vIEluZGl2aWR1YWwgZXhwb3J0cyBmb3IgYWR2YW5jZWQgdXNlIGNhc2VzXG5leHBvcnQgeyBEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gXCIuL2Ryb3Bkb3duLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgRHJvcGRvd25UcmlnZ2VyRGlyZWN0aXZlIH0gZnJvbSBcIi4vZHJvcGRvd24tdHJpZ2dlci9kcm9wZG93bi10cmlnZ2VyLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgRHJvcGRvd25NZW51Q29tcG9uZW50IH0gZnJvbSBcIi4vZHJvcGRvd24tbWVudS9kcm9wZG93bi1tZW51LmNvbXBvbmVudFwiO1xuZXhwb3J0IHsgRHJvcGRvd25JdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZHJvcGRvd24taXRlbS9kcm9wZG93bi1pdGVtLmNvbXBvbmVudFwiO1xuIl19
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kcy1ydGUtbGliL3NyYy9saWIvY29tcG9uZW50cy9kcm9wZG93bi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDekYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEcm9wZG93bk1vZHVsZSB9IGZyb20gXCIuL2Ryb3Bkb3duLm1vZHVsZVwiO1xuXG5leHBvcnQgeyBEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gXCIuL2Ryb3Bkb3duLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgRHJvcGRvd25UcmlnZ2VyRGlyZWN0aXZlIH0gZnJvbSBcIi4vZHJvcGRvd24tdHJpZ2dlci9kcm9wZG93bi10cmlnZ2VyLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgRHJvcGRvd25NZW51Q29tcG9uZW50IH0gZnJvbSBcIi4vZHJvcGRvd24tbWVudS9kcm9wZG93bi1tZW51LmNvbXBvbmVudFwiO1xuZXhwb3J0IHsgRHJvcGRvd25JdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZHJvcGRvd24taXRlbS9kcm9wZG93bi1pdGVtLmNvbXBvbmVudFwiO1xuZXhwb3J0IHR5cGUgeyBEcm9wZG93bkl0ZW1Db25maWcgfSBmcm9tIFwiLi9kcm9wZG93bi50eXBlc1wiO1xuIl19