@skyux/popovers 8.0.0-alpha.2 → 8.0.0-alpha.21

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 (36) hide show
  1. package/documentation.json +390 -460
  2. package/esm2020/index.mjs +2 -1
  3. package/esm2020/lib/modules/dropdown/dropdown-button.component.mjs +3 -3
  4. package/esm2020/lib/modules/dropdown/dropdown-item.component.mjs +15 -15
  5. package/esm2020/lib/modules/dropdown/dropdown-menu.component.mjs +25 -25
  6. package/esm2020/lib/modules/dropdown/dropdown.component.mjs +32 -49
  7. package/esm2020/lib/modules/dropdown/dropdown.module.mjs +4 -4
  8. package/esm2020/lib/modules/popover/popover-adapter.service.mjs +3 -3
  9. package/esm2020/lib/modules/popover/popover-content.component.mjs +26 -26
  10. package/esm2020/lib/modules/popover/popover.component.mjs +39 -39
  11. package/esm2020/lib/modules/popover/popover.directive.mjs +14 -14
  12. package/esm2020/lib/modules/popover/popover.module.mjs +4 -4
  13. package/esm2020/lib/modules/shared/sky-popovers-resources.module.mjs +4 -4
  14. package/esm2020/testing/dropdown/dropdown-fixture.mjs +8 -8
  15. package/esm2020/testing/dropdown/dropdown-testing.module.mjs +4 -4
  16. package/esm2020/testing/popover/popover-fixture.mjs +6 -6
  17. package/esm2020/testing/popover/popover-testing.module.mjs +4 -4
  18. package/fesm2015/skyux-popovers-testing.mjs +21 -21
  19. package/fesm2015/skyux-popovers-testing.mjs.map +1 -1
  20. package/fesm2015/skyux-popovers.mjs +167 -185
  21. package/fesm2015/skyux-popovers.mjs.map +1 -1
  22. package/fesm2020/skyux-popovers-testing.mjs +21 -21
  23. package/fesm2020/skyux-popovers-testing.mjs.map +1 -1
  24. package/fesm2020/skyux-popovers.mjs +166 -183
  25. package/fesm2020/skyux-popovers.mjs.map +1 -1
  26. package/index.d.ts +1 -0
  27. package/lib/modules/dropdown/dropdown.component.d.ts +4 -7
  28. package/lib/modules/dropdown/types/dropdown-button-type.d.ts +1 -1
  29. package/lib/modules/dropdown/types/dropdown-horizontal-alignment.d.ts +1 -1
  30. package/lib/modules/dropdown/types/dropdown-trigger-type.d.ts +1 -1
  31. package/lib/modules/popover/popover-animation-state.d.ts +1 -1
  32. package/lib/modules/popover/types/popover-alignment.d.ts +1 -1
  33. package/lib/modules/popover/types/popover-placement.d.ts +1 -1
  34. package/lib/modules/popover/types/popover-trigger.d.ts +1 -1
  35. package/lib/modules/popover/types/popover-type.d.ts +1 -1
  36. package/package.json +11 -11
package/esm2020/index.mjs CHANGED
@@ -1,3 +1,4 @@
1
+ export * from './lib/modules/dropdown/types/dropdown-button-type';
1
2
  export * from './lib/modules/dropdown/types/dropdown-horizontal-alignment';
2
3
  export * from './lib/modules/dropdown/types/dropdown-menu-change';
3
4
  export * from './lib/modules/dropdown/types/dropdown-message';
@@ -21,4 +22,4 @@ export { SkyDropdownMenuComponent as λ4 } from './lib/modules/dropdown/dropdown
21
22
  export { SkyPopoverContentComponent as λ5 } from './lib/modules/popover/popover-content.component';
22
23
  export { SkyPopoverComponent as λ6 } from './lib/modules/popover/popover.component';
23
24
  export { SkyPopoverDirective as λ7 } from './lib/modules/popover/popover.directive';
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvcG9wb3ZlcnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLHdDQUF3QyxDQUFDO0FBRXZELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywwQ0FBMEMsQ0FBQztBQUV6RCwwRkFBMEY7QUFDMUYsMkVBQTJFO0FBQzNFLE9BQU8sRUFBRSx3QkFBd0IsSUFBSSxFQUFFLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUsMEJBQTBCLElBQUksRUFBRSxFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDcEcsT0FBTyxFQUFFLG9CQUFvQixJQUFJLEVBQUUsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSx3QkFBd0IsSUFBSSxFQUFFLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUsMEJBQTBCLElBQUksRUFBRSxFQUFFLE1BQU0saURBQWlELENBQUM7QUFDbkcsT0FBTyxFQUFFLG1CQUFtQixJQUFJLEVBQUUsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxtQkFBbUIsSUFBSSxFQUFFLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vdHlwZXMvZHJvcGRvd24taG9yaXpvbnRhbC1hbGlnbm1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi90eXBlcy9kcm9wZG93bi1tZW51LWNoYW5nZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL3R5cGVzL2Ryb3Bkb3duLW1lc3NhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi90eXBlcy9kcm9wZG93bi1tZXNzYWdlLXR5cGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi90eXBlcy9kcm9wZG93bi10cmlnZ2VyLXR5cGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvcG9wb3Zlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3R5cGVzL3BvcG92ZXItYWxpZ25tZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci90eXBlcy9wb3BvdmVyLW1lc3NhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3R5cGVzL3BvcG92ZXItbWVzc2FnZS10eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci90eXBlcy9wb3BvdmVyLXBsYWNlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvdHlwZXMvcG9wb3Zlci1wb3NpdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvdHlwZXMvcG9wb3Zlci10cmlnZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci90eXBlcy9wb3BvdmVyLXR5cGUnO1xuXG4vLyBDb21wb25lbnRzIGFuZCBkaXJlY3RpdmVzIG11c3QgYmUgZXhwb3J0ZWQgdG8gc3VwcG9ydCBBbmd1bGFyJ3MgXCJwYXJ0aWFsXCIgSXZ5IGNvbXBpbGVyLlxuLy8gT2JzY3VyZSBuYW1lcyBhcmUgdXNlZCB0byBpbmRpY2F0ZSB0eXBlcyBhcmUgbm90IHBhcnQgb2YgdGhlIHB1YmxpYyBBUEkuXG5leHBvcnQgeyBTa3lEcm9wZG93bkl0ZW1Db21wb25lbnQgYXMgzrsxIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lEcm9wZG93bkJ1dHRvbkNvbXBvbmVudCBhcyDOuzIgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL2Ryb3Bkb3duLWJ1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RHJvcGRvd25Db21wb25lbnQgYXMgzrszIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RHJvcGRvd25NZW51Q29tcG9uZW50IGFzIM67NCB9IGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vZHJvcGRvd24tbWVudS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UG9wb3ZlckNvbnRlbnRDb21wb25lbnQgYXMgzrs1IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3BvcG92ZXItY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UG9wb3ZlckNvbXBvbmVudCBhcyDOuzYgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvcG9wb3Zlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UG9wb3ZlckRpcmVjdGl2ZSBhcyDOuzcgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvcG9wb3Zlci5kaXJlY3RpdmUnO1xuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvcG9wb3ZlcnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsd0NBQXdDLENBQUM7QUFFdkQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDBDQUEwQyxDQUFDO0FBRXpELDBGQUEwRjtBQUMxRiwyRUFBMkU7QUFDM0UsT0FBTyxFQUFFLHdCQUF3QixJQUFJLEVBQUUsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ2hHLE9BQU8sRUFBRSwwQkFBMEIsSUFBSSxFQUFFLEVBQUUsTUFBTSxrREFBa0QsQ0FBQztBQUNwRyxPQUFPLEVBQUUsb0JBQW9CLElBQUksRUFBRSxFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDdkYsT0FBTyxFQUFFLHdCQUF3QixJQUFJLEVBQUUsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ2hHLE9BQU8sRUFBRSwwQkFBMEIsSUFBSSxFQUFFLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUNuRyxPQUFPLEVBQUUsbUJBQW1CLElBQUksRUFBRSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDcEYsT0FBTyxFQUFFLG1CQUFtQixJQUFJLEVBQUUsRUFBRSxNQUFNLHlDQUF5QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi90eXBlcy9kcm9wZG93bi1idXR0b24tdHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL3R5cGVzL2Ryb3Bkb3duLWhvcml6b250YWwtYWxpZ25tZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vdHlwZXMvZHJvcGRvd24tbWVudS1jaGFuZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi90eXBlcy9kcm9wZG93bi1tZXNzYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vdHlwZXMvZHJvcGRvd24tbWVzc2FnZS10eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vdHlwZXMvZHJvcGRvd24tdHJpZ2dlci10eXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vZHJvcGRvd24ubW9kdWxlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3BvcG92ZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci90eXBlcy9wb3BvdmVyLWFsaWdubWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvdHlwZXMvcG9wb3Zlci1tZXNzYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci90eXBlcy9wb3BvdmVyLW1lc3NhZ2UtdHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvdHlwZXMvcG9wb3Zlci1wbGFjZW1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3R5cGVzL3BvcG92ZXItcG9zaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3R5cGVzL3BvcG92ZXItdHJpZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL3BvcG92ZXIvdHlwZXMvcG9wb3Zlci10eXBlJztcblxuLy8gQ29tcG9uZW50cyBhbmQgZGlyZWN0aXZlcyBtdXN0IGJlIGV4cG9ydGVkIHRvIHN1cHBvcnQgQW5ndWxhcidzIFwicGFydGlhbFwiIEl2eSBjb21waWxlci5cbi8vIE9ic2N1cmUgbmFtZXMgYXJlIHVzZWQgdG8gaW5kaWNhdGUgdHlwZXMgYXJlIG5vdCBwYXJ0IG9mIHRoZSBwdWJsaWMgQVBJLlxuZXhwb3J0IHsgU2t5RHJvcGRvd25JdGVtQ29tcG9uZW50IGFzIM67MSB9IGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vZHJvcGRvd24taXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RHJvcGRvd25CdXR0b25Db21wb25lbnQgYXMgzrsyIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreURyb3Bkb3duQ29tcG9uZW50IGFzIM67MyB9IGZyb20gJy4vbGliL21vZHVsZXMvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreURyb3Bkb3duTWVudUNvbXBvbmVudCBhcyDOuzQgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL2Ryb3Bkb3duLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVBvcG92ZXJDb250ZW50Q29tcG9uZW50IGFzIM67NSB9IGZyb20gJy4vbGliL21vZHVsZXMvcG9wb3Zlci9wb3BvdmVyLWNvbnRlbnQuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVBvcG92ZXJDb21wb25lbnQgYXMgzrs2IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3BvcG92ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVBvcG92ZXJEaXJlY3RpdmUgYXMgzrs3IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9wb3BvdmVyL3BvcG92ZXIuZGlyZWN0aXZlJztcbiJdfQ==
@@ -5,9 +5,9 @@ import * as i0 from "@angular/core";
5
5
  */
6
6
  export class SkyDropdownButtonComponent {
7
7
  }
8
- SkyDropdownButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
- SkyDropdownButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SkyDropdownButtonComponent, selector: "sky-dropdown-button", ngImport: i0, template: "<ng-content></ng-content>\n" });
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownButtonComponent, decorators: [{
8
+ SkyDropdownButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
+ SkyDropdownButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkyDropdownButtonComponent, selector: "sky-dropdown-button", ngImport: i0, template: "<ng-content></ng-content>\n" });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownButtonComponent, decorators: [{
11
11
  type: Component,
12
12
  args: [{ selector: 'sky-dropdown-button', template: "<ng-content></ng-content>\n" }]
13
13
  }] });
@@ -7,17 +7,6 @@ import * as i1 from "@angular/common";
7
7
  * Specifies the items to display on the dropdown menu.
8
8
  */
9
9
  export class SkyDropdownItemComponent {
10
- constructor(elementRef, changeDetector, renderer) {
11
- this.elementRef = elementRef;
12
- _SkyDropdownItemComponent_instances.add(this);
13
- this.isActive = false;
14
- this.isDisabled = false;
15
- _SkyDropdownItemComponent__ariaRole.set(this, 'menuitem');
16
- _SkyDropdownItemComponent_changeDetector.set(this, void 0);
17
- _SkyDropdownItemComponent_renderer.set(this, void 0);
18
- __classPrivateFieldSet(this, _SkyDropdownItemComponent_changeDetector, changeDetector, "f");
19
- __classPrivateFieldSet(this, _SkyDropdownItemComponent_renderer, renderer, "f");
20
- }
21
10
  /**
22
11
  * The ARIA role for the dropdown menu item
23
12
  * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility)
@@ -32,6 +21,17 @@ export class SkyDropdownItemComponent {
32
21
  get ariaRole() {
33
22
  return __classPrivateFieldGet(this, _SkyDropdownItemComponent__ariaRole, "f");
34
23
  }
24
+ constructor(elementRef, changeDetector, renderer) {
25
+ this.elementRef = elementRef;
26
+ _SkyDropdownItemComponent_instances.add(this);
27
+ this.isActive = false;
28
+ this.isDisabled = false;
29
+ _SkyDropdownItemComponent__ariaRole.set(this, 'menuitem');
30
+ _SkyDropdownItemComponent_changeDetector.set(this, void 0);
31
+ _SkyDropdownItemComponent_renderer.set(this, void 0);
32
+ __classPrivateFieldSet(this, _SkyDropdownItemComponent_changeDetector, changeDetector, "f");
33
+ __classPrivateFieldSet(this, _SkyDropdownItemComponent_renderer, renderer, "f");
34
+ }
35
35
  ngAfterViewInit() {
36
36
  this.isDisabled = !this.isFocusable();
37
37
  // Make sure anchor elements are tab-able.
@@ -61,12 +61,12 @@ export class SkyDropdownItemComponent {
61
61
  _SkyDropdownItemComponent__ariaRole = new WeakMap(), _SkyDropdownItemComponent_changeDetector = new WeakMap(), _SkyDropdownItemComponent_renderer = new WeakMap(), _SkyDropdownItemComponent_instances = new WeakSet(), _SkyDropdownItemComponent_getButtonElement = function _SkyDropdownItemComponent_getButtonElement() {
62
62
  return this.elementRef.nativeElement.querySelector('button,a');
63
63
  };
64
- SkyDropdownItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
65
- SkyDropdownItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SkyDropdownItemComponent, selector: "sky-dropdown-item", inputs: { ariaRole: "ariaRole" }, ngImport: i0, template: "<div\n class=\"sky-dropdown-item\"\n [attr.role]=\"ariaRole\"\n [ngClass]=\"{\n 'sky-dropdown-item-active': isActive,\n 'sky-dropdown-item-disabled': isDisabled\n }\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left}.sky-dropdown-item.sky-dropdown-item-active,.sky-dropdown-item:hover{background-color:#eeeeef}.sky-dropdown-item.sky-dropdown-item-disabled{cursor:default}.sky-dropdown-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-dropdown-item>a,.sky-dropdown-item>button{background-color:transparent;border:none;color:#212327;cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-dropdown-item>a:hover,.sky-dropdown-item>button:hover{text-decoration:none}.sky-dropdown-item>a[disabled],.sky-dropdown-item>button[disabled]{color:#686c73}.sky-dropdown-item>a[disabled]:hover,.sky-dropdown-item>button[disabled]:hover{cursor:default}.sky-theme-modern .sky-dropdown-item{margin:0}.sky-theme-modern .sky-dropdown-item.sky-dropdown-item-active,.sky-theme-modern .sky-dropdown-item:hover{background-color:transparent}.sky-theme-modern .sky-dropdown-item>a,.sky-theme-modern .sky-dropdown-item>button{padding:10px 20px;border-radius:6px;transition:box-shadow .15s}.sky-theme-modern .sky-dropdown-item>a:hover,.sky-theme-modern .sky-dropdown-item>button:hover{outline:solid 1px #1870B8;outline-offset:-1px}.sky-theme-modern .sky-dropdown-item>a:focus-visible,.sky-theme-modern .sky-dropdown-item>a:active,.sky-theme-modern .sky-dropdown-item>button:focus-visible,.sky-theme-modern .sky-dropdown-item>button:active{outline:solid 2px #1870B8;outline-offset:-2px}.sky-theme-modern .sky-dropdown-item>a:focus-visible:not(:active),.sky-theme-modern .sky-dropdown-item>button:focus-visible:not(:active){box-shadow:0 1px 8px #0000004d}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>a,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>button{color:#fbfcfe}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
66
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownItemComponent, decorators: [{
64
+ SkyDropdownItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
65
+ SkyDropdownItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkyDropdownItemComponent, selector: "sky-dropdown-item", inputs: { ariaRole: "ariaRole" }, ngImport: i0, template: "<div\n class=\"sky-dropdown-item\"\n [attr.role]=\"ariaRole\"\n [ngClass]=\"{\n 'sky-dropdown-item-active': isActive,\n 'sky-dropdown-item-disabled': isDisabled\n }\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left}.sky-dropdown-item.sky-dropdown-item-active,.sky-dropdown-item:hover{background-color:#eeeeef}.sky-dropdown-item.sky-dropdown-item-disabled{cursor:default}.sky-dropdown-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-dropdown-item>a,.sky-dropdown-item>button{background-color:transparent;border:none;color:#212327;cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-dropdown-item>a:hover,.sky-dropdown-item>button:hover{text-decoration:none}.sky-dropdown-item>a[disabled],.sky-dropdown-item>button[disabled]{color:#686c73}.sky-dropdown-item>a[disabled]:hover,.sky-dropdown-item>button[disabled]:hover{cursor:default}.sky-theme-modern .sky-dropdown-item{margin:0}.sky-theme-modern .sky-dropdown-item.sky-dropdown-item-active,.sky-theme-modern .sky-dropdown-item:hover{background-color:transparent}.sky-theme-modern .sky-dropdown-item>a,.sky-theme-modern .sky-dropdown-item>button{padding:10px 20px;border-radius:6px;transition:box-shadow .15s}.sky-theme-modern .sky-dropdown-item>a:hover,.sky-theme-modern .sky-dropdown-item>button:hover{outline:solid 1px #1870B8;outline-offset:-1px}.sky-theme-modern .sky-dropdown-item>a:focus-visible,.sky-theme-modern .sky-dropdown-item>a:active,.sky-theme-modern .sky-dropdown-item>button:focus-visible,.sky-theme-modern .sky-dropdown-item>button:active{outline:solid 2px #1870B8;outline-offset:-2px}.sky-theme-modern .sky-dropdown-item>a:focus-visible:not(:active),.sky-theme-modern .sky-dropdown-item>button:focus-visible:not(:active){box-shadow:0 1px 8px #0000004d}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>a,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>button{color:#fbfcfe}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
66
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownItemComponent, decorators: [{
67
67
  type: Component,
68
68
  args: [{ selector: 'sky-dropdown-item', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div\n class=\"sky-dropdown-item\"\n [attr.role]=\"ariaRole\"\n [ngClass]=\"{\n 'sky-dropdown-item-active': isActive,\n 'sky-dropdown-item-disabled': isDisabled\n }\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-item{background-color:transparent;border:none;display:block;margin:4px;min-width:160px;text-align:left}.sky-dropdown-item.sky-dropdown-item-active,.sky-dropdown-item:hover{background-color:#eeeeef}.sky-dropdown-item.sky-dropdown-item-disabled{cursor:default}.sky-dropdown-item.sky-dropdown-item-disabled:hover{background-color:transparent}.sky-dropdown-item>a,.sky-dropdown-item>button{background-color:transparent;border:none;color:#212327;cursor:pointer;display:block;padding:3px 20px;text-align:left;width:100%}.sky-dropdown-item>a:hover,.sky-dropdown-item>button:hover{text-decoration:none}.sky-dropdown-item>a[disabled],.sky-dropdown-item>button[disabled]{color:#686c73}.sky-dropdown-item>a[disabled]:hover,.sky-dropdown-item>button[disabled]:hover{cursor:default}.sky-theme-modern .sky-dropdown-item{margin:0}.sky-theme-modern .sky-dropdown-item.sky-dropdown-item-active,.sky-theme-modern .sky-dropdown-item:hover{background-color:transparent}.sky-theme-modern .sky-dropdown-item>a,.sky-theme-modern .sky-dropdown-item>button{padding:10px 20px;border-radius:6px;transition:box-shadow .15s}.sky-theme-modern .sky-dropdown-item>a:hover,.sky-theme-modern .sky-dropdown-item>button:hover{outline:solid 1px #1870B8;outline-offset:-1px}.sky-theme-modern .sky-dropdown-item>a:focus-visible,.sky-theme-modern .sky-dropdown-item>a:active,.sky-theme-modern .sky-dropdown-item>button:focus-visible,.sky-theme-modern .sky-dropdown-item>button:active{outline:solid 2px #1870B8;outline-offset:-2px}.sky-theme-modern .sky-dropdown-item>a:focus-visible:not(:active),.sky-theme-modern .sky-dropdown-item>button:focus-visible:not(:active){box-shadow:0 1px 8px #0000004d}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>a,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-item>button{color:#fbfcfe}\n"] }]
69
69
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }]; }, propDecorators: { ariaRole: [{
70
70
  type: Input
71
71
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvcG9wb3ZlcnMvc3JjL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3BvcG92ZXJzL3NyYy9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUVMLHVCQUF1QixFQUV2QixTQUFTLEVBRVQsS0FBSyxFQUVMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7O0FBRXZCOztHQUVHO0FBUUgsTUFBTSxPQUFPLHdCQUF3QjtJQTJCbkMsWUFDUyxVQUFzQixFQUM3QixjQUFpQyxFQUNqQyxRQUFtQjtRQUZaLGVBQVUsR0FBVixVQUFVLENBQVk7O1FBVnhCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFakIsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUUxQiw4Q0FBYSxVQUFVLEVBQUM7UUFFeEIsMkRBQW1DO1FBQ25DLHFEQUFxQjtRQU9uQix1QkFBQSxJQUFJLDRDQUFtQixjQUFjLE1BQUEsQ0FBQztRQUN0Qyx1QkFBQSxJQUFJLHNDQUFhLFFBQVEsTUFBQSxDQUFDO0lBQzVCLENBQUM7SUFqQ0Q7Ozs7Ozs7T0FPRztJQUNILElBQ1csUUFBUSxDQUFDLEtBQXlCO1FBQzNDLHVCQUFBLElBQUksdUNBQWMsS0FBSyxJQUFJLFVBQVUsTUFBQSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyx1QkFBQSxJQUFJLDJDQUFXLENBQUM7SUFDekIsQ0FBQztJQW9CTSxlQUFlO1FBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFFdEMsMENBQTBDO1FBQzFDLE1BQU0sYUFBYSxHQUFHLHVCQUFBLElBQUksdUZBQWtCLE1BQXRCLElBQUksQ0FBb0IsQ0FBQztRQUMvQywwQkFBMEI7UUFDMUIsSUFBSSxhQUFhLEVBQUU7WUFDakIsdUJBQUEsSUFBSSwwQ0FBVSxDQUFDLFlBQVksQ0FBQyxhQUFhLEVBQUUsVUFBVSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1NBQzdEO1FBRUQsdUJBQUEsSUFBSSxnREFBZ0IsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN2QyxDQUFDO0lBRU0sWUFBWSxDQUFDLGlCQUEwQjtRQUM1QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztRQUVyQixJQUFJLGlCQUFpQixFQUFFO1lBQ3JCLHVCQUFBLElBQUksdUZBQWtCLE1BQXRCLElBQUksQ0FBb0IsRUFBRSxLQUFLLEVBQUUsQ0FBQztTQUNuQztRQUVELHVCQUFBLElBQUksZ0RBQWdCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsTUFBTSxXQUFXLEdBQ2YsdUJBQUEsSUFBSSx1RkFBa0IsTUFBdEIsSUFBSSxDQUFvQixFQUFFLFlBQVksQ0FBQyxVQUFVLENBQUMsS0FBSyxJQUFJLENBQUM7UUFDOUQsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQztJQUVNLFVBQVU7UUFDZixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0Qix1QkFBQSxJQUFJLGdEQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RDLENBQUM7OztJQUdDLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ2pFLENBQUM7cUhBeEVVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLDJGQ3JCckMsNk5BVUE7MkZEV2Esd0JBQXdCO2tCQVBwQyxTQUFTOytCQUNFLG1CQUFtQixtQkFHWix1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJO3lKQVkxQixRQUFRO3NCQURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBTcGVjaWZpZXMgdGhlIGl0ZW1zIHRvIGRpc3BsYXkgb24gdGhlIGRyb3Bkb3duIG1lbnUuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1kcm9wZG93bi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lEcm9wZG93bkl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgLyoqXG4gICAqIFRoZSBBUklBIHJvbGUgZm9yIHRoZSBkcm9wZG93biBtZW51IGl0ZW1cbiAgICogW3RvIHN1cHBvcnQgYWNjZXNzaWJpbGl0eV0oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC9sZWFybi9hY2Nlc3NpYmlsaXR5KVxuICAgKiBieSBpbmRpY2F0aW5nIGhvdyB0aGUgaXRlbSBmdW5jdGlvbnMgYW5kIHdoYXQgaXQgY29udHJvbHMuIEZvciBpbmZvcm1hdGlvbiBhYm91dFxuICAgKiBob3cgYW4gQVJJQSByb2xlIGluZGljYXRlcyB3aGF0IGFuIGl0ZW0gcmVwcmVzZW50cyBvbiBhIHdlYiBwYWdlLCBzZWUgdGhlXG4gICAqIFtXQUktQVJJQSByb2xlcyBtb2RlbF0oaHR0cHM6Ly93d3cudzMub3JnL1dBSS9QRi9hcmlhLyNyb2xlcykuXG4gICAqIEBkZWZhdWx0IFwibWVudWl0ZW1cIlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIHNldCBhcmlhUm9sZSh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy4jX2FyaWFSb2xlID0gdmFsdWUgPz8gJ21lbnVpdGVtJztcbiAgfVxuXG4gIHB1YmxpYyBnZXQgYXJpYVJvbGUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy4jX2FyaWFSb2xlO1xuICB9XG5cbiAgcHVibGljIGlzQWN0aXZlID0gZmFsc2U7XG5cbiAgcHVibGljIGlzRGlzYWJsZWQgPSBmYWxzZTtcblxuICAjX2FyaWFSb2xlID0gJ21lbnVpdGVtJztcblxuICAjY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmO1xuICAjcmVuZGVyZXI6IFJlbmRlcmVyMjtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXG4gICAgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHJlbmRlcmVyOiBSZW5kZXJlcjJcbiAgKSB7XG4gICAgdGhpcy4jY2hhbmdlRGV0ZWN0b3IgPSBjaGFuZ2VEZXRlY3RvcjtcbiAgICB0aGlzLiNyZW5kZXJlciA9IHJlbmRlcmVyO1xuICB9XG5cbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmlzRGlzYWJsZWQgPSAhdGhpcy5pc0ZvY3VzYWJsZSgpO1xuXG4gICAgLy8gTWFrZSBzdXJlIGFuY2hvciBlbGVtZW50cyBhcmUgdGFiLWFibGUuXG4gICAgY29uc3QgYnV0dG9uRWxlbWVudCA9IHRoaXMuI2dldEJ1dHRvbkVsZW1lbnQoKTtcbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgZWxzZSAqL1xuICAgIGlmIChidXR0b25FbGVtZW50KSB7XG4gICAgICB0aGlzLiNyZW5kZXJlci5zZXRBdHRyaWJ1dGUoYnV0dG9uRWxlbWVudCwgJ3RhYkluZGV4JywgJzAnKTtcbiAgICB9XG5cbiAgICB0aGlzLiNjaGFuZ2VEZXRlY3Rvci5kZXRlY3RDaGFuZ2VzKCk7XG4gIH1cblxuICBwdWJsaWMgZm9jdXNFbGVtZW50KGVuYWJsZU5hdGl2ZUZvY3VzOiBib29sZWFuKTogdm9pZCB7XG4gICAgdGhpcy5pc0FjdGl2ZSA9IHRydWU7XG5cbiAgICBpZiAoZW5hYmxlTmF0aXZlRm9jdXMpIHtcbiAgICAgIHRoaXMuI2dldEJ1dHRvbkVsZW1lbnQoKT8uZm9jdXMoKTtcbiAgICB9XG5cbiAgICB0aGlzLiNjaGFuZ2VEZXRlY3Rvci5kZXRlY3RDaGFuZ2VzKCk7XG4gIH1cblxuICBwdWJsaWMgaXNGb2N1c2FibGUoKTogYm9vbGVhbiB7XG4gICAgY29uc3QgaXNGb2N1c2FibGUgPVxuICAgICAgdGhpcy4jZ2V0QnV0dG9uRWxlbWVudCgpPy5nZXRBdHRyaWJ1dGUoJ2Rpc2FibGVkJykgPT09IG51bGw7XG4gICAgcmV0dXJuIGlzRm9jdXNhYmxlO1xuICB9XG5cbiAgcHVibGljIHJlc2V0U3RhdGUoKTogdm9pZCB7XG4gICAgdGhpcy5pc0FjdGl2ZSA9IGZhbHNlO1xuICAgIHRoaXMuI2NoYW5nZURldGVjdG9yLm1hcmtGb3JDaGVjaygpO1xuICB9XG5cbiAgI2dldEJ1dHRvbkVsZW1lbnQoKTogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQucXVlcnlTZWxlY3RvcignYnV0dG9uLGEnKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInNreS1kcm9wZG93bi1pdGVtXCJcbiAgW2F0dHIucm9sZV09XCJhcmlhUm9sZVwiXG4gIFtuZ0NsYXNzXT1cIntcbiAgICAnc2t5LWRyb3Bkb3duLWl0ZW0tYWN0aXZlJzogaXNBY3RpdmUsXG4gICAgJ3NreS1kcm9wZG93bi1pdGVtLWRpc2FibGVkJzogaXNEaXNhYmxlZFxuICB9XCJcbj5cbiAgPG5nLWNvbnRlbnQ+IDwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvcG9wb3ZlcnMvc3JjL2xpYi9tb2R1bGVzL2Ryb3Bkb3duL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3BvcG92ZXJzL3NyYy9saWIvbW9kdWxlcy9kcm9wZG93bi9kcm9wZG93bi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUVMLHVCQUF1QixFQUV2QixTQUFTLEVBRVQsS0FBSyxFQUVMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7O0FBRXZCOztHQUVHO0FBUUgsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQzs7Ozs7OztPQU9HO0lBQ0gsSUFDVyxRQUFRLENBQUMsS0FBeUI7UUFDM0MsdUJBQUEsSUFBSSx1Q0FBYyxLQUFLLElBQUksVUFBVSxNQUFBLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNqQixPQUFPLHVCQUFBLElBQUksMkNBQVcsQ0FBQztJQUN6QixDQUFDO0lBV0QsWUFDUyxVQUFzQixFQUM3QixjQUFpQyxFQUNqQyxRQUFtQjtRQUZaLGVBQVUsR0FBVixVQUFVLENBQVk7O1FBVnhCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFakIsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUUxQiw4Q0FBYSxVQUFVLEVBQUM7UUFFeEIsMkRBQW1DO1FBQ25DLHFEQUFxQjtRQU9uQix1QkFBQSxJQUFJLDRDQUFtQixjQUFjLE1BQUEsQ0FBQztRQUN0Qyx1QkFBQSxJQUFJLHNDQUFhLFFBQVEsTUFBQSxDQUFDO0lBQzVCLENBQUM7SUFFTSxlQUFlO1FBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFFdEMsMENBQTBDO1FBQzFDLE1BQU0sYUFBYSxHQUFHLHVCQUFBLElBQUksdUZBQWtCLE1BQXRCLElBQUksQ0FBb0IsQ0FBQztRQUMvQywwQkFBMEI7UUFDMUIsSUFBSSxhQUFhLEVBQUU7WUFDakIsdUJBQUEsSUFBSSwwQ0FBVSxDQUFDLFlBQVksQ0FBQyxhQUFhLEVBQUUsVUFBVSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1NBQzdEO1FBRUQsdUJBQUEsSUFBSSxnREFBZ0IsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN2QyxDQUFDO0lBRU0sWUFBWSxDQUFDLGlCQUEwQjtRQUM1QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztRQUVyQixJQUFJLGlCQUFpQixFQUFFO1lBQ3JCLHVCQUFBLElBQUksdUZBQWtCLE1BQXRCLElBQUksQ0FBb0IsRUFBRSxLQUFLLEVBQUUsQ0FBQztTQUNuQztRQUVELHVCQUFBLElBQUksZ0RBQWdCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsTUFBTSxXQUFXLEdBQ2YsdUJBQUEsSUFBSSx1RkFBa0IsTUFBdEIsSUFBSSxDQUFvQixFQUFFLFlBQVksQ0FBQyxVQUFVLENBQUMsS0FBSyxJQUFJLENBQUM7UUFDOUQsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQztJQUVNLFVBQVU7UUFDZixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0Qix1QkFBQSxJQUFJLGdEQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RDLENBQUM7OztJQUdDLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ2pFLENBQUM7cUhBeEVVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLDJGQ3JCckMsNk5BVUE7MkZEV2Esd0JBQXdCO2tCQVBwQyxTQUFTOytCQUNFLG1CQUFtQixtQkFHWix1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJO3lKQVkxQixRQUFRO3NCQURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBSZW5kZXJlcjIsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBTcGVjaWZpZXMgdGhlIGl0ZW1zIHRvIGRpc3BsYXkgb24gdGhlIGRyb3Bkb3duIG1lbnUuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1kcm9wZG93bi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lEcm9wZG93bkl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgLyoqXG4gICAqIFRoZSBBUklBIHJvbGUgZm9yIHRoZSBkcm9wZG93biBtZW51IGl0ZW1cbiAgICogW3RvIHN1cHBvcnQgYWNjZXNzaWJpbGl0eV0oaHR0cHM6Ly9kZXZlbG9wZXIuYmxhY2tiYXVkLmNvbS9za3l1eC9sZWFybi9hY2Nlc3NpYmlsaXR5KVxuICAgKiBieSBpbmRpY2F0aW5nIGhvdyB0aGUgaXRlbSBmdW5jdGlvbnMgYW5kIHdoYXQgaXQgY29udHJvbHMuIEZvciBpbmZvcm1hdGlvbiBhYm91dFxuICAgKiBob3cgYW4gQVJJQSByb2xlIGluZGljYXRlcyB3aGF0IGFuIGl0ZW0gcmVwcmVzZW50cyBvbiBhIHdlYiBwYWdlLCBzZWUgdGhlXG4gICAqIFtXQUktQVJJQSByb2xlcyBtb2RlbF0oaHR0cHM6Ly93d3cudzMub3JnL1dBSS9QRi9hcmlhLyNyb2xlcykuXG4gICAqIEBkZWZhdWx0IFwibWVudWl0ZW1cIlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIHNldCBhcmlhUm9sZSh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy4jX2FyaWFSb2xlID0gdmFsdWUgPz8gJ21lbnVpdGVtJztcbiAgfVxuXG4gIHB1YmxpYyBnZXQgYXJpYVJvbGUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy4jX2FyaWFSb2xlO1xuICB9XG5cbiAgcHVibGljIGlzQWN0aXZlID0gZmFsc2U7XG5cbiAgcHVibGljIGlzRGlzYWJsZWQgPSBmYWxzZTtcblxuICAjX2FyaWFSb2xlID0gJ21lbnVpdGVtJztcblxuICAjY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmO1xuICAjcmVuZGVyZXI6IFJlbmRlcmVyMjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZWxlbWVudFJlZjogRWxlbWVudFJlZixcbiAgICBjaGFuZ2VEZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgcmVuZGVyZXI6IFJlbmRlcmVyMlxuICApIHtcbiAgICB0aGlzLiNjaGFuZ2VEZXRlY3RvciA9IGNoYW5nZURldGVjdG9yO1xuICAgIHRoaXMuI3JlbmRlcmVyID0gcmVuZGVyZXI7XG4gIH1cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMuaXNEaXNhYmxlZCA9ICF0aGlzLmlzRm9jdXNhYmxlKCk7XG5cbiAgICAvLyBNYWtlIHN1cmUgYW5jaG9yIGVsZW1lbnRzIGFyZSB0YWItYWJsZS5cbiAgICBjb25zdCBidXR0b25FbGVtZW50ID0gdGhpcy4jZ2V0QnV0dG9uRWxlbWVudCgpO1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBlbHNlICovXG4gICAgaWYgKGJ1dHRvbkVsZW1lbnQpIHtcbiAgICAgIHRoaXMuI3JlbmRlcmVyLnNldEF0dHJpYnV0ZShidXR0b25FbGVtZW50LCAndGFiSW5kZXgnLCAnMCcpO1xuICAgIH1cblxuICAgIHRoaXMuI2NoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIHB1YmxpYyBmb2N1c0VsZW1lbnQoZW5hYmxlTmF0aXZlRm9jdXM6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmlzQWN0aXZlID0gdHJ1ZTtcblxuICAgIGlmIChlbmFibGVOYXRpdmVGb2N1cykge1xuICAgICAgdGhpcy4jZ2V0QnV0dG9uRWxlbWVudCgpPy5mb2N1cygpO1xuICAgIH1cblxuICAgIHRoaXMuI2NoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIHB1YmxpYyBpc0ZvY3VzYWJsZSgpOiBib29sZWFuIHtcbiAgICBjb25zdCBpc0ZvY3VzYWJsZSA9XG4gICAgICB0aGlzLiNnZXRCdXR0b25FbGVtZW50KCk/LmdldEF0dHJpYnV0ZSgnZGlzYWJsZWQnKSA9PT0gbnVsbDtcbiAgICByZXR1cm4gaXNGb2N1c2FibGU7XG4gIH1cblxuICBwdWJsaWMgcmVzZXRTdGF0ZSgpOiB2b2lkIHtcbiAgICB0aGlzLmlzQWN0aXZlID0gZmFsc2U7XG4gICAgdGhpcy4jY2hhbmdlRGV0ZWN0b3IubWFya0ZvckNoZWNrKCk7XG4gIH1cblxuICAjZ2V0QnV0dG9uRWxlbWVudCgpOiBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCdidXR0b24sYScpO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwic2t5LWRyb3Bkb3duLWl0ZW1cIlxuICBbYXR0ci5yb2xlXT1cImFyaWFSb2xlXCJcbiAgW25nQ2xhc3NdPVwie1xuICAgICdza3ktZHJvcGRvd24taXRlbS1hY3RpdmUnOiBpc0FjdGl2ZSxcbiAgICAnc2t5LWRyb3Bkb3duLWl0ZW0tZGlzYWJsZWQnOiBpc0Rpc2FibGVkXG4gIH1cIlxuPlxuICA8bmctY29udGVudD4gPC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
@@ -13,27 +13,6 @@ let nextId = 0;
13
13
  *
14
14
  */
15
15
  export class SkyDropdownMenuComponent {
16
- constructor(changeDetector, elementRef, dropdownComponent) {
17
- _SkyDropdownMenuComponent_instances.add(this);
18
- /**
19
- * Fires when the dropdown menu's active index or selected item changes. This event provides an
20
- * observable to emit changes, and the response is of
21
- * the SkyDropdownMenuChange type.
22
- * @internal
23
- */
24
- this.menuChanges = new EventEmitter();
25
- this.dropdownMenuId = `sky-dropdown-menu-${++nextId}`;
26
- _SkyDropdownMenuComponent_ngUnsubscribe.set(this, new Subject());
27
- _SkyDropdownMenuComponent__ariaRole.set(this, 'menu');
28
- _SkyDropdownMenuComponent__menuIndex.set(this, 0);
29
- _SkyDropdownMenuComponent__useNativeFocus.set(this, true);
30
- _SkyDropdownMenuComponent_changeDetector.set(this, void 0);
31
- _SkyDropdownMenuComponent_elementRef.set(this, void 0);
32
- _SkyDropdownMenuComponent_dropdownComponent.set(this, void 0);
33
- __classPrivateFieldSet(this, _SkyDropdownMenuComponent_changeDetector, changeDetector, "f");
34
- __classPrivateFieldSet(this, _SkyDropdownMenuComponent_elementRef, elementRef, "f");
35
- __classPrivateFieldSet(this, _SkyDropdownMenuComponent_dropdownComponent, dropdownComponent, "f");
36
- }
37
16
  /**
38
17
  * The ARIA role for the dropdown menu
39
18
  * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility)
@@ -75,6 +54,27 @@ export class SkyDropdownMenuComponent {
75
54
  get menuIndex() {
76
55
  return __classPrivateFieldGet(this, _SkyDropdownMenuComponent__menuIndex, "f");
77
56
  }
57
+ constructor(changeDetector, elementRef, dropdownComponent) {
58
+ _SkyDropdownMenuComponent_instances.add(this);
59
+ /**
60
+ * Fires when the dropdown menu's active index or selected item changes. This event provides an
61
+ * observable to emit changes, and the response is of
62
+ * the SkyDropdownMenuChange type.
63
+ * @internal
64
+ */
65
+ this.menuChanges = new EventEmitter();
66
+ this.dropdownMenuId = `sky-dropdown-menu-${++nextId}`;
67
+ _SkyDropdownMenuComponent_ngUnsubscribe.set(this, new Subject());
68
+ _SkyDropdownMenuComponent__ariaRole.set(this, 'menu');
69
+ _SkyDropdownMenuComponent__menuIndex.set(this, 0);
70
+ _SkyDropdownMenuComponent__useNativeFocus.set(this, true);
71
+ _SkyDropdownMenuComponent_changeDetector.set(this, void 0);
72
+ _SkyDropdownMenuComponent_elementRef.set(this, void 0);
73
+ _SkyDropdownMenuComponent_dropdownComponent.set(this, void 0);
74
+ __classPrivateFieldSet(this, _SkyDropdownMenuComponent_changeDetector, changeDetector, "f");
75
+ __classPrivateFieldSet(this, _SkyDropdownMenuComponent_elementRef, elementRef, "f");
76
+ __classPrivateFieldSet(this, _SkyDropdownMenuComponent_dropdownComponent, dropdownComponent, "f");
77
+ }
78
78
  ngAfterContentInit() {
79
79
  /* istanbul ignore else */
80
80
  if (__classPrivateFieldGet(this, _SkyDropdownMenuComponent_dropdownComponent, "f")) {
@@ -285,9 +285,9 @@ _SkyDropdownMenuComponent_ngUnsubscribe = new WeakMap(), _SkyDropdownMenuCompone
285
285
  const found = this.menuItems.find((item) => item.isFocusable());
286
286
  return found !== undefined;
287
287
  };
288
- SkyDropdownMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownMenuComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.SkyDropdownComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
289
- SkyDropdownMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: SkyDropdownMenuComponent, selector: "sky-dropdown-menu", inputs: { ariaLabelledBy: "ariaLabelledBy", ariaRole: "ariaRole", useNativeFocus: "useNativeFocus" }, outputs: { menuChanges: "menuChanges" }, queries: [{ propertyName: "menuItems", predicate: SkyDropdownItemComponent, descendants: true }], ngImport: i0, template: "<div\n class=\"sky-dropdown-menu sky-shadow sky-elevation-4\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [id]=\"dropdownMenuId\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-menu{overflow-y:auto;overflow-x:hidden;min-height:35px;max-height:calc(50vh - 50px);display:flex;flex-direction:column;background-color:#fff}.sky-dropdown-menu button{overflow:hidden;text-overflow:ellipsis}.sky-theme-modern .sky-dropdown-menu{border-radius:6px;padding:10px 0}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-menu{background-color:#252a2e;color:#fff}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
290
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SkyDropdownMenuComponent, decorators: [{
288
+ SkyDropdownMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownMenuComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.SkyDropdownComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
289
+ SkyDropdownMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: SkyDropdownMenuComponent, selector: "sky-dropdown-menu", inputs: { ariaLabelledBy: "ariaLabelledBy", ariaRole: "ariaRole", useNativeFocus: "useNativeFocus" }, outputs: { menuChanges: "menuChanges" }, queries: [{ propertyName: "menuItems", predicate: SkyDropdownItemComponent, descendants: true }], ngImport: i0, template: "<div\n class=\"sky-dropdown-menu sky-shadow sky-elevation-4\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [id]=\"dropdownMenuId\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-menu{overflow-y:auto;overflow-x:hidden;min-height:35px;max-height:calc(50vh - 50px);display:flex;flex-direction:column;background-color:#fff}.sky-dropdown-menu button{overflow:hidden;text-overflow:ellipsis}.sky-theme-modern .sky-dropdown-menu{border-radius:6px;padding:10px 0}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-menu{background-color:#252a2e;color:#fff}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
290
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: SkyDropdownMenuComponent, decorators: [{
291
291
  type: Component,
292
292
  args: [{ selector: 'sky-dropdown-menu', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div\n class=\"sky-dropdown-menu sky-shadow sky-elevation-4\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [id]=\"dropdownMenuId\"\n>\n <ng-content> </ng-content>\n</div>\n", styles: [".sky-dropdown-menu{overflow-y:auto;overflow-x:hidden;min-height:35px;max-height:calc(50vh - 50px);display:flex;flex-direction:column;background-color:#fff}.sky-dropdown-menu button{overflow:hidden;text-overflow:ellipsis}.sky-theme-modern .sky-dropdown-menu{border-radius:6px;padding:10px 0}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-menu{background-color:#252a2e;color:#fff}\n"] }]
293
293
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.SkyDropdownComponent, decorators: [{
@@ -304,4 +304,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
304
304
  type: ContentChildren,
305
305
  args: [SkyDropdownItemComponent, { descendants: true }]
306
306
  }] } });
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown-menu.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDropdownItemComponent } from './dropdown-item.component';\nimport { SkyDropdownComponent } from './dropdown.component';\nimport { SkyDropdownMenuChange } from './types/dropdown-menu-change';\nimport { SkyDropdownMessage } from './types/dropdown-message';\nimport { SkyDropdownMessageType } from './types/dropdown-message-type';\n\nlet nextId = 0;\n/**\n * Creates a menu that contains dropdown menu items.\n *\n */\n@Component({\n  selector: 'sky-dropdown-menu',\n  templateUrl: './dropdown-menu.component.html',\n  styleUrls: ['./dropdown-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDropdownMenuComponent implements AfterContentInit, OnDestroy {\n  /**\n   * The HTML element ID of the element that labels\n   * the dropdown menu. This sets the dropdown menu's `aria-labelledby` attribute to provide a text equivalent for\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-labelledby` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-labelledby).\n   */\n  @Input()\n  public ariaLabelledBy: string | undefined;\n\n  /**\n   * The ARIA role for the dropdown menu\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility)\n   * by indicating how the dropdown menu functions and what it controls. The dropdown button\n   * inherits this value to set its `aria-haspopup` property. For information\n   * about how an ARIA role indicates what an item represents on a web page, see the\n   * [WAI-ARIA roles model](https://www.w3.org/WAI/PF/aria/#roles).\n   * @default \"menu\"\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\n    this.#_ariaRole = value ?? 'menu';\n  }\n\n  public get ariaRole(): string {\n    return this.#_ariaRole;\n  }\n\n  /**\n   * Whether to use the browser's native focus function when users navigate through menu\n   * items with the keyboard. To disable the native focus function, set this property to `false`.\n   * For example, to let users interact with the dropdown menu but keep the keyboard focus on a\n   * different element, set this property to `false`.\n   * @default true\n   * @internal\n   */\n  @Input()\n  public set useNativeFocus(value: boolean | undefined) {\n    this.#_useNativeFocus = value ?? true;\n  }\n\n  public get useNativeFocus(): boolean {\n    return this.#_useNativeFocus;\n  }\n\n  /**\n   * Fires when the dropdown menu's active index or selected item changes. This event provides an\n   * observable to emit changes, and the response is of\n   * the SkyDropdownMenuChange type.\n   * @internal\n   */\n  @Output()\n  public menuChanges = new EventEmitter<SkyDropdownMenuChange>();\n\n  public dropdownMenuId = `sky-dropdown-menu-${++nextId}`;\n\n  public set menuIndex(value: number) {\n    if (value < 0) {\n      value = this.menuItems.length - 1;\n    }\n\n    if (value >= this.menuItems.length) {\n      value = 0;\n    }\n\n    this.#_menuIndex = value;\n  }\n\n  public get menuIndex(): number {\n    return this.#_menuIndex;\n  }\n\n  @ContentChildren(SkyDropdownItemComponent, { descendants: true })\n  public menuItems!: QueryList<SkyDropdownItemComponent>;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaRole = 'menu';\n\n  #_menuIndex = 0;\n\n  #_useNativeFocus = true;\n\n  #changeDetector: ChangeDetectorRef;\n  #elementRef: ElementRef;\n  #dropdownComponent: SkyDropdownComponent | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    elementRef: ElementRef,\n    @Optional() dropdownComponent?: SkyDropdownComponent\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#elementRef = elementRef;\n    this.#dropdownComponent = dropdownComponent;\n  }\n\n  public ngAfterContentInit(): void {\n    /* istanbul ignore else */\n    if (this.#dropdownComponent) {\n      this.#dropdownComponent.menuId = this.dropdownMenuId;\n      this.#dropdownComponent.menuAriaRole = this.ariaRole;\n\n      this.#dropdownComponent.messageStream\n        ?.pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((message: SkyDropdownMessage) => {\n          switch (message.type) {\n            case SkyDropdownMessageType.Open:\n            case SkyDropdownMessageType.Close:\n              this.reset();\n              break;\n\n            case SkyDropdownMessageType.FocusFirstItem:\n              this.focusFirstItem();\n              break;\n\n            case SkyDropdownMessageType.FocusNextItem:\n              this.focusNextItem();\n              break;\n\n            case SkyDropdownMessageType.FocusPreviousItem:\n              this.focusPreviousItem();\n              break;\n\n            case SkyDropdownMessageType.FocusLastItem:\n              this.focusLastItem();\n              break;\n          }\n        });\n\n      this.menuChanges\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((change: SkyDropdownMenuChange) => {\n          // Close the dropdown when a menu item is selected.\n          if (change.selectedItem) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n          }\n\n          if (change.items) {\n            // Update the popover style and position whenever the number of items changes.\n            this.#sendMessage(SkyDropdownMessageType.Reposition);\n          }\n        });\n    }\n\n    // Reset dropdown whenever the menu items change.\n    this.menuItems.changes\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((items: QueryList<SkyDropdownItemComponent>) => {\n        this.reset();\n        this.menuChanges.emit({\n          items: items.toArray(),\n        });\n      });\n\n    this.#addEventListeners();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public focusFirstItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex = 0;\n\n    const firstItem = this.#getItemByIndex(this.menuIndex);\n    if (firstItem && firstItem.isFocusable()) {\n      this.#focusItem(firstItem);\n    } else {\n      this.focusNextItem();\n    }\n  }\n\n  public focusLastItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex = this.menuItems.length - 1;\n\n    const lastItem = this.#getItemByIndex(this.menuIndex);\n    if (lastItem && lastItem.isFocusable()) {\n      this.#focusItem(lastItem);\n    } else {\n      this.focusPreviousItem();\n    }\n  }\n\n  public focusPreviousItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex--;\n\n    const previousItem = this.#getItemByIndex(this.menuIndex);\n    if (previousItem && previousItem.isFocusable()) {\n      this.#focusItem(previousItem);\n    } else {\n      this.focusPreviousItem();\n    }\n  }\n\n  public focusNextItem() {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex++;\n\n    const nextItem = this.#getItemByIndex(this.menuIndex);\n    if (nextItem && nextItem.isFocusable()) {\n      this.#focusItem(nextItem);\n    } else {\n      this.focusNextItem();\n    }\n  }\n\n  public reset(): void {\n    this.#_menuIndex = -1;\n    this.#resetItemsActiveState();\n    this.#changeDetector.markForCheck();\n  }\n\n  #resetItemsActiveState() {\n    this.menuItems.forEach((item: SkyDropdownItemComponent) => {\n      item.resetState();\n    });\n  }\n\n  #focusItem(item: SkyDropdownItemComponent): void {\n    this.#resetItemsActiveState();\n    item.focusElement(this.useNativeFocus);\n    this.menuChanges.emit({\n      activeIndex: this.menuIndex,\n    });\n  }\n\n  #getItemByIndex(index: number): SkyDropdownItemComponent | undefined {\n    return this.menuItems.find((_, i) => i === index);\n  }\n\n  #selectItemByEventTarget(target: EventTarget): void {\n    const selectedItem = this.menuItems.find(\n      (item: SkyDropdownItemComponent, i: number) => {\n        const found = item.elementRef.nativeElement.contains(target);\n\n        if (found) {\n          this.menuIndex = i;\n          this.menuChanges.next({\n            activeIndex: this.menuIndex,\n          });\n        }\n\n        return found;\n      }\n    );\n\n    /* istanbul ignore else */\n    if (selectedItem) {\n      this.menuChanges.next({\n        selectedItem,\n      });\n    }\n  }\n\n  #sendMessage(type: SkyDropdownMessageType): void {\n    this.#dropdownComponent?.messageStream?.next({ type });\n  }\n\n  #addEventListeners(): void {\n    const dropdownMenuElement = this.#elementRef.nativeElement;\n\n    observableFromEvent<MouseEvent>(dropdownMenuElement, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        this.#selectItemByEventTarget(event.target as EventTarget);\n      });\n\n    observableFromEvent<KeyboardEvent>(dropdownMenuElement, 'keydown')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        const key = event.key.toLowerCase();\n\n        switch (key) {\n          case 'escape':\n            this.#sendMessage(SkyDropdownMessageType.Close);\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n            event.stopPropagation();\n            event.preventDefault();\n            break;\n\n          case 'arrowdown':\n          case 'down':\n            this.focusNextItem();\n            event.preventDefault();\n            break;\n\n          case 'arrowup':\n          case 'up':\n            this.focusPreviousItem();\n            event.preventDefault();\n            break;\n\n          case 'tab':\n            if (this.#dropdownComponent?.dismissOnBlur) {\n              this.#sendMessage(SkyDropdownMessageType.Close);\n            }\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n            break;\n        }\n      });\n\n    observableFromEvent(dropdownMenuElement, 'mouseenter')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.#dropdownComponent) {\n          this.#dropdownComponent.isMouseEnter = true;\n        }\n      });\n\n    observableFromEvent(dropdownMenuElement, 'mouseleave')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.#dropdownComponent) {\n          this.#dropdownComponent.isMouseEnter = false;\n          // Allow the dropdown component to set isMouseEnter before checking if the close action\n          // should be taken.\n          setTimeout(() => {\n            if (\n              this.#dropdownComponent &&\n              this.#dropdownComponent.trigger === 'hover' &&\n              this.#dropdownComponent.isMouseEnter === false\n            ) {\n              this.#sendMessage(SkyDropdownMessageType.Close);\n            }\n          });\n        }\n      });\n  }\n\n  #hasFocusableItems(): boolean {\n    const found = this.menuItems.find((item) => item.isFocusable());\n    return found !== undefined;\n  }\n}\n","<div\n  class=\"sky-dropdown-menu sky-shadow sky-elevation-4\"\n  [attr.aria-labelledby]=\"ariaLabelledBy\"\n  [attr.role]=\"ariaRole\"\n  [id]=\"dropdownMenuId\"\n>\n  <ng-content> </ng-content>\n</div>\n"]}
307
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-menu.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown-menu.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDropdownItemComponent } from './dropdown-item.component';\nimport { SkyDropdownComponent } from './dropdown.component';\nimport { SkyDropdownMenuChange } from './types/dropdown-menu-change';\nimport { SkyDropdownMessage } from './types/dropdown-message';\nimport { SkyDropdownMessageType } from './types/dropdown-message-type';\n\nlet nextId = 0;\n/**\n * Creates a menu that contains dropdown menu items.\n *\n */\n@Component({\n  selector: 'sky-dropdown-menu',\n  templateUrl: './dropdown-menu.component.html',\n  styleUrls: ['./dropdown-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDropdownMenuComponent implements AfterContentInit, OnDestroy {\n  /**\n   * The HTML element ID of the element that labels\n   * the dropdown menu. This sets the dropdown menu's `aria-labelledby` attribute to provide a text equivalent for\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-labelledby` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-labelledby).\n   */\n  @Input()\n  public ariaLabelledBy: string | undefined;\n\n  /**\n   * The ARIA role for the dropdown menu\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility)\n   * by indicating how the dropdown menu functions and what it controls. The dropdown button\n   * inherits this value to set its `aria-haspopup` property. For information\n   * about how an ARIA role indicates what an item represents on a web page, see the\n   * [WAI-ARIA roles model](https://www.w3.org/WAI/PF/aria/#roles).\n   * @default \"menu\"\n   */\n  @Input()\n  public set ariaRole(value: string | undefined) {\n    this.#_ariaRole = value ?? 'menu';\n  }\n\n  public get ariaRole(): string {\n    return this.#_ariaRole;\n  }\n\n  /**\n   * Whether to use the browser's native focus function when users navigate through menu\n   * items with the keyboard. To disable the native focus function, set this property to `false`.\n   * For example, to let users interact with the dropdown menu but keep the keyboard focus on a\n   * different element, set this property to `false`.\n   * @default true\n   * @internal\n   */\n  @Input()\n  public set useNativeFocus(value: boolean | undefined) {\n    this.#_useNativeFocus = value ?? true;\n  }\n\n  public get useNativeFocus(): boolean {\n    return this.#_useNativeFocus;\n  }\n\n  /**\n   * Fires when the dropdown menu's active index or selected item changes. This event provides an\n   * observable to emit changes, and the response is of\n   * the SkyDropdownMenuChange type.\n   * @internal\n   */\n  @Output()\n  public menuChanges = new EventEmitter<SkyDropdownMenuChange>();\n\n  public dropdownMenuId = `sky-dropdown-menu-${++nextId}`;\n\n  public set menuIndex(value: number) {\n    if (value < 0) {\n      value = this.menuItems.length - 1;\n    }\n\n    if (value >= this.menuItems.length) {\n      value = 0;\n    }\n\n    this.#_menuIndex = value;\n  }\n\n  public get menuIndex(): number {\n    return this.#_menuIndex;\n  }\n\n  @ContentChildren(SkyDropdownItemComponent, { descendants: true })\n  public menuItems!: QueryList<SkyDropdownItemComponent>;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_ariaRole = 'menu';\n\n  #_menuIndex = 0;\n\n  #_useNativeFocus = true;\n\n  #changeDetector: ChangeDetectorRef;\n  #elementRef: ElementRef;\n  #dropdownComponent: SkyDropdownComponent | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    elementRef: ElementRef,\n    @Optional() dropdownComponent?: SkyDropdownComponent\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#elementRef = elementRef;\n    this.#dropdownComponent = dropdownComponent;\n  }\n\n  public ngAfterContentInit(): void {\n    /* istanbul ignore else */\n    if (this.#dropdownComponent) {\n      this.#dropdownComponent.menuId = this.dropdownMenuId;\n      this.#dropdownComponent.menuAriaRole = this.ariaRole;\n\n      this.#dropdownComponent.messageStream\n        ?.pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((message: SkyDropdownMessage) => {\n          switch (message.type) {\n            case SkyDropdownMessageType.Open:\n            case SkyDropdownMessageType.Close:\n              this.reset();\n              break;\n\n            case SkyDropdownMessageType.FocusFirstItem:\n              this.focusFirstItem();\n              break;\n\n            case SkyDropdownMessageType.FocusNextItem:\n              this.focusNextItem();\n              break;\n\n            case SkyDropdownMessageType.FocusPreviousItem:\n              this.focusPreviousItem();\n              break;\n\n            case SkyDropdownMessageType.FocusLastItem:\n              this.focusLastItem();\n              break;\n          }\n        });\n\n      this.menuChanges\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((change: SkyDropdownMenuChange) => {\n          // Close the dropdown when a menu item is selected.\n          if (change.selectedItem) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n          }\n\n          if (change.items) {\n            // Update the popover style and position whenever the number of items changes.\n            this.#sendMessage(SkyDropdownMessageType.Reposition);\n          }\n        });\n    }\n\n    // Reset dropdown whenever the menu items change.\n    this.menuItems.changes\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((items: QueryList<SkyDropdownItemComponent>) => {\n        this.reset();\n        this.menuChanges.emit({\n          items: items.toArray(),\n        });\n      });\n\n    this.#addEventListeners();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public focusFirstItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex = 0;\n\n    const firstItem = this.#getItemByIndex(this.menuIndex);\n    if (firstItem && firstItem.isFocusable()) {\n      this.#focusItem(firstItem);\n    } else {\n      this.focusNextItem();\n    }\n  }\n\n  public focusLastItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex = this.menuItems.length - 1;\n\n    const lastItem = this.#getItemByIndex(this.menuIndex);\n    if (lastItem && lastItem.isFocusable()) {\n      this.#focusItem(lastItem);\n    } else {\n      this.focusPreviousItem();\n    }\n  }\n\n  public focusPreviousItem(): void {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex--;\n\n    const previousItem = this.#getItemByIndex(this.menuIndex);\n    if (previousItem && previousItem.isFocusable()) {\n      this.#focusItem(previousItem);\n    } else {\n      this.focusPreviousItem();\n    }\n  }\n\n  public focusNextItem() {\n    if (!this.#hasFocusableItems()) {\n      return;\n    }\n\n    this.menuIndex++;\n\n    const nextItem = this.#getItemByIndex(this.menuIndex);\n    if (nextItem && nextItem.isFocusable()) {\n      this.#focusItem(nextItem);\n    } else {\n      this.focusNextItem();\n    }\n  }\n\n  public reset(): void {\n    this.#_menuIndex = -1;\n    this.#resetItemsActiveState();\n    this.#changeDetector.markForCheck();\n  }\n\n  #resetItemsActiveState() {\n    this.menuItems.forEach((item: SkyDropdownItemComponent) => {\n      item.resetState();\n    });\n  }\n\n  #focusItem(item: SkyDropdownItemComponent): void {\n    this.#resetItemsActiveState();\n    item.focusElement(this.useNativeFocus);\n    this.menuChanges.emit({\n      activeIndex: this.menuIndex,\n    });\n  }\n\n  #getItemByIndex(index: number): SkyDropdownItemComponent | undefined {\n    return this.menuItems.find((_, i) => i === index);\n  }\n\n  #selectItemByEventTarget(target: EventTarget): void {\n    const selectedItem = this.menuItems.find(\n      (item: SkyDropdownItemComponent, i: number) => {\n        const found = item.elementRef.nativeElement.contains(target);\n\n        if (found) {\n          this.menuIndex = i;\n          this.menuChanges.next({\n            activeIndex: this.menuIndex,\n          });\n        }\n\n        return found;\n      }\n    );\n\n    /* istanbul ignore else */\n    if (selectedItem) {\n      this.menuChanges.next({\n        selectedItem,\n      });\n    }\n  }\n\n  #sendMessage(type: SkyDropdownMessageType): void {\n    this.#dropdownComponent?.messageStream?.next({ type });\n  }\n\n  #addEventListeners(): void {\n    const dropdownMenuElement = this.#elementRef.nativeElement;\n\n    observableFromEvent<MouseEvent>(dropdownMenuElement, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        this.#selectItemByEventTarget(event.target as EventTarget);\n      });\n\n    observableFromEvent<KeyboardEvent>(dropdownMenuElement, 'keydown')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        const key = event.key.toLowerCase();\n\n        switch (key) {\n          case 'escape':\n            this.#sendMessage(SkyDropdownMessageType.Close);\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n            event.stopPropagation();\n            event.preventDefault();\n            break;\n\n          case 'arrowdown':\n          case 'down':\n            this.focusNextItem();\n            event.preventDefault();\n            break;\n\n          case 'arrowup':\n          case 'up':\n            this.focusPreviousItem();\n            event.preventDefault();\n            break;\n\n          case 'tab':\n            if (this.#dropdownComponent?.dismissOnBlur) {\n              this.#sendMessage(SkyDropdownMessageType.Close);\n            }\n            this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n            break;\n        }\n      });\n\n    observableFromEvent(dropdownMenuElement, 'mouseenter')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.#dropdownComponent) {\n          this.#dropdownComponent.isMouseEnter = true;\n        }\n      });\n\n    observableFromEvent(dropdownMenuElement, 'mouseleave')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.#dropdownComponent) {\n          this.#dropdownComponent.isMouseEnter = false;\n          // Allow the dropdown component to set isMouseEnter before checking if the close action\n          // should be taken.\n          setTimeout(() => {\n            if (\n              this.#dropdownComponent &&\n              this.#dropdownComponent.trigger === 'hover' &&\n              this.#dropdownComponent.isMouseEnter === false\n            ) {\n              this.#sendMessage(SkyDropdownMessageType.Close);\n            }\n          });\n        }\n      });\n  }\n\n  #hasFocusableItems(): boolean {\n    const found = this.menuItems.find((item) => item.isFocusable());\n    return found !== undefined;\n  }\n}\n","<div\n  class=\"sky-dropdown-menu sky-shadow sky-elevation-4\"\n  [attr.aria-labelledby]=\"ariaLabelledBy\"\n  [attr.role]=\"ariaRole\"\n  [id]=\"dropdownMenuId\"\n>\n  <ng-content> </ng-content>\n</div>\n"]}