@skyux/popovers 7.8.1 → 7.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +321 -247
- package/esm2020/lib/modules/dropdown/dropdown.component.mjs +21 -7
- package/esm2020/lib/modules/popover/popover.component.mjs +22 -7
- package/fesm2015/skyux-popovers.mjs +41 -11
- package/fesm2015/skyux-popovers.mjs.map +1 -1
- package/fesm2020/skyux-popovers.mjs +39 -11
- package/fesm2020/skyux-popovers.mjs.map +1 -1
- package/lib/modules/dropdown/dropdown.component.d.ts +3 -3
- package/lib/modules/popover/popover.component.d.ts +3 -3
- package/package.json +6 -6
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
var _SkyDropdownComponent_instances, _SkyDropdownComponent_affixer, _SkyDropdownComponent_ngUnsubscribe, _SkyDropdownComponent_overlay, _SkyDropdownComponent__buttonStyle, _SkyDropdownComponent__buttonType, _SkyDropdownComponent__dismissOnBlur, _SkyDropdownComponent__horizontalAlignment, _SkyDropdownComponent__isOpen, _SkyDropdownComponent__trigger, _SkyDropdownComponent__triggerButton, _SkyDropdownComponent_positionTimeout, _SkyDropdownComponent_changeDetector, _SkyDropdownComponent_affixService, _SkyDropdownComponent_overlayService, _SkyDropdownComponent_logService, _SkyDropdownComponent_themeSvc, _SkyDropdownComponent_addEventListeners, _SkyDropdownComponent_createOverlay, _SkyDropdownComponent_destroyAffixer, _SkyDropdownComponent_destroyOverlay, _SkyDropdownComponent_createAffixer, _SkyDropdownComponent_handleIncomingMessages, _SkyDropdownComponent_sendMessage, _SkyDropdownComponent_positionDropdownMenu;
|
|
1
|
+
var _SkyDropdownComponent_instances, _SkyDropdownComponent_affixer, _SkyDropdownComponent_ngUnsubscribe, _SkyDropdownComponent_overlay, _SkyDropdownComponent__buttonStyle, _SkyDropdownComponent__buttonType, _SkyDropdownComponent__dismissOnBlur, _SkyDropdownComponent__horizontalAlignment, _SkyDropdownComponent__isOpen, _SkyDropdownComponent__trigger, _SkyDropdownComponent__triggerButton, _SkyDropdownComponent_positionTimeout, _SkyDropdownComponent_changeDetector, _SkyDropdownComponent_affixService, _SkyDropdownComponent_overlayService, _SkyDropdownComponent_logService, _SkyDropdownComponent_themeSvc, _SkyDropdownComponent_zIndex, _SkyDropdownComponent_addEventListeners, _SkyDropdownComponent_createOverlay, _SkyDropdownComponent_destroyAffixer, _SkyDropdownComponent_destroyOverlay, _SkyDropdownComponent_createAffixer, _SkyDropdownComponent_handleIncomingMessages, _SkyDropdownComponent_sendMessage, _SkyDropdownComponent_positionDropdownMenu;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { ChangeDetectionStrategy, Component, ElementRef, Input, Optional, TemplateRef, ViewChild, } from '@angular/core';
|
|
4
|
-
import { SkyAffixAutoFitContext, } from '@skyux/core';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, ElementRef, Inject, Input, Optional, TemplateRef, ViewChild, } from '@angular/core';
|
|
4
|
+
import { SKY_STACKING_CONTEXT, SkyAffixAutoFitContext, } from '@skyux/core';
|
|
5
5
|
import { Subject, fromEvent as observableFromEvent } from 'rxjs';
|
|
6
6
|
import { takeUntil } from 'rxjs/operators';
|
|
7
7
|
import { parseAffixHorizontalAlignment } from './dropdown-extensions';
|
|
@@ -17,7 +17,7 @@ const DEFAULT_BUTTON_TYPE = 'select';
|
|
|
17
17
|
* Creates a dropdown menu that displays menu items that users may select.
|
|
18
18
|
*/
|
|
19
19
|
export class SkyDropdownComponent {
|
|
20
|
-
constructor(changeDetector, affixService, overlayService, logService, themeSvc) {
|
|
20
|
+
constructor(changeDetector, affixService, overlayService, logService, themeSvc, stackingContext) {
|
|
21
21
|
_SkyDropdownComponent_instances.add(this);
|
|
22
22
|
/**
|
|
23
23
|
* Whether to disable the dropdown button.
|
|
@@ -48,11 +48,13 @@ export class SkyDropdownComponent {
|
|
|
48
48
|
_SkyDropdownComponent_overlayService.set(this, void 0);
|
|
49
49
|
_SkyDropdownComponent_logService.set(this, void 0);
|
|
50
50
|
_SkyDropdownComponent_themeSvc.set(this, void 0);
|
|
51
|
+
_SkyDropdownComponent_zIndex.set(this, void 0);
|
|
51
52
|
__classPrivateFieldSet(this, _SkyDropdownComponent_changeDetector, changeDetector, "f");
|
|
52
53
|
__classPrivateFieldSet(this, _SkyDropdownComponent_affixService, affixService, "f");
|
|
53
54
|
__classPrivateFieldSet(this, _SkyDropdownComponent_overlayService, overlayService, "f");
|
|
54
55
|
__classPrivateFieldSet(this, _SkyDropdownComponent_logService, logService, "f");
|
|
55
56
|
__classPrivateFieldSet(this, _SkyDropdownComponent_themeSvc, themeSvc, "f");
|
|
57
|
+
__classPrivateFieldSet(this, _SkyDropdownComponent_zIndex, stackingContext?.zIndex, "f");
|
|
56
58
|
}
|
|
57
59
|
/**
|
|
58
60
|
* The background color for the dropdown button. Available values are `default`,
|
|
@@ -163,7 +165,7 @@ export class SkyDropdownComponent {
|
|
|
163
165
|
__classPrivateFieldGet(this, _SkyDropdownComponent_ngUnsubscribe, "f").complete();
|
|
164
166
|
}
|
|
165
167
|
}
|
|
166
|
-
_SkyDropdownComponent_affixer = new WeakMap(), _SkyDropdownComponent_ngUnsubscribe = new WeakMap(), _SkyDropdownComponent_overlay = new WeakMap(), _SkyDropdownComponent__buttonStyle = new WeakMap(), _SkyDropdownComponent__buttonType = new WeakMap(), _SkyDropdownComponent__dismissOnBlur = new WeakMap(), _SkyDropdownComponent__horizontalAlignment = new WeakMap(), _SkyDropdownComponent__isOpen = new WeakMap(), _SkyDropdownComponent__trigger = new WeakMap(), _SkyDropdownComponent__triggerButton = new WeakMap(), _SkyDropdownComponent_positionTimeout = new WeakMap(), _SkyDropdownComponent_changeDetector = new WeakMap(), _SkyDropdownComponent_affixService = new WeakMap(), _SkyDropdownComponent_overlayService = new WeakMap(), _SkyDropdownComponent_logService = new WeakMap(), _SkyDropdownComponent_themeSvc = new WeakMap(), _SkyDropdownComponent_instances = new WeakSet(), _SkyDropdownComponent_addEventListeners = function _SkyDropdownComponent_addEventListeners() {
|
|
168
|
+
_SkyDropdownComponent_affixer = new WeakMap(), _SkyDropdownComponent_ngUnsubscribe = new WeakMap(), _SkyDropdownComponent_overlay = new WeakMap(), _SkyDropdownComponent__buttonStyle = new WeakMap(), _SkyDropdownComponent__buttonType = new WeakMap(), _SkyDropdownComponent__dismissOnBlur = new WeakMap(), _SkyDropdownComponent__horizontalAlignment = new WeakMap(), _SkyDropdownComponent__isOpen = new WeakMap(), _SkyDropdownComponent__trigger = new WeakMap(), _SkyDropdownComponent__triggerButton = new WeakMap(), _SkyDropdownComponent_positionTimeout = new WeakMap(), _SkyDropdownComponent_changeDetector = new WeakMap(), _SkyDropdownComponent_affixService = new WeakMap(), _SkyDropdownComponent_overlayService = new WeakMap(), _SkyDropdownComponent_logService = new WeakMap(), _SkyDropdownComponent_themeSvc = new WeakMap(), _SkyDropdownComponent_zIndex = new WeakMap(), _SkyDropdownComponent_instances = new WeakSet(), _SkyDropdownComponent_addEventListeners = function _SkyDropdownComponent_addEventListeners() {
|
|
167
169
|
__classPrivateFieldGet(this, _SkyDropdownComponent_ngUnsubscribe, "f").next();
|
|
168
170
|
__classPrivateFieldGet(this, _SkyDropdownComponent_ngUnsubscribe, "f").complete();
|
|
169
171
|
__classPrivateFieldSet(this, _SkyDropdownComponent_ngUnsubscribe, new Subject(), "f");
|
|
@@ -256,6 +258,13 @@ _SkyDropdownComponent_affixer = new WeakMap(), _SkyDropdownComponent_ngUnsubscri
|
|
|
256
258
|
enableScroll: true,
|
|
257
259
|
enablePointerEvents: true,
|
|
258
260
|
});
|
|
261
|
+
if (__classPrivateFieldGet(this, _SkyDropdownComponent_zIndex, "f")) {
|
|
262
|
+
__classPrivateFieldGet(this, _SkyDropdownComponent_zIndex, "f")
|
|
263
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyDropdownComponent_ngUnsubscribe, "f")))
|
|
264
|
+
.subscribe((zIndex) => {
|
|
265
|
+
overlay.componentRef.instance.zIndex = zIndex.toString(10);
|
|
266
|
+
});
|
|
267
|
+
}
|
|
259
268
|
overlay.attachTemplate(this.menuContainerTemplateRef);
|
|
260
269
|
overlay.backdropClick
|
|
261
270
|
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyDropdownComponent_ngUnsubscribe, "f")))
|
|
@@ -332,13 +341,18 @@ _SkyDropdownComponent_affixer = new WeakMap(), _SkyDropdownComponent_ngUnsubscri
|
|
|
332
341
|
}
|
|
333
342
|
}), "f");
|
|
334
343
|
};
|
|
335
|
-
SkyDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDropdownComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyAffixService }, { token: i1.SkyOverlayService }, { token: i1.SkyLogService }, { token: i2.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
344
|
+
SkyDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDropdownComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyAffixService }, { token: i1.SkyOverlayService }, { token: i1.SkyLogService }, { token: i2.SkyThemeService, optional: true }, { token: SKY_STACKING_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
336
345
|
SkyDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyDropdownComponent, selector: "sky-dropdown", inputs: { buttonStyle: "buttonStyle", buttonType: "buttonType", disabled: "disabled", dismissOnBlur: "dismissOnBlur", label: "label", horizontalAlignment: "horizontalAlignment", messageStream: "messageStream", title: "title", trigger: "trigger" }, viewQueries: [{ propertyName: "menuContainerElementRef", first: true, predicate: ["menuContainerElementRef"], descendants: true, read: ElementRef }, { propertyName: "menuContainerTemplateRef", first: true, predicate: ["menuContainerTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButton", first: true, predicate: ["triggerButton"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<div class=\"sky-dropdown\">\n <button\n class=\"sky-btn sky-dropdown-button\"\n type=\"button\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-controls]=\"isOpen ? menuId : null\"\n [attr.aria-haspopup]=\"menuAriaRole\"\n [attr.aria-label]=\"\n label || ('skyux_dropdown_context_menu_default_label' | skyLibResources)\n \"\n [attr.title]=\"title\"\n [disabled]=\"disabled\"\n [ngClass]=\"[\n 'sky-dropdown-button-type-' + buttonType,\n 'sky-btn-' + buttonStyle\n ]\"\n #triggerButton\n >\n <ng-container [ngSwitch]=\"buttonType\">\n <ng-template ngSwitchCase=\"context-menu\">\n <sky-icon *skyThemeIf=\"'default'\" icon=\"ellipsis-h\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"ellipsis\"\n iconType=\"skyux\"\n ></sky-icon>\n </ng-template>\n\n <ng-template ngSwitchDefault>\n <div\n *ngIf=\"buttonType === 'select' || buttonType === 'tab' || !buttonType\"\n class=\"sky-dropdown-button-container\"\n >\n <div class=\"sky-dropdown-button-content-container\">\n <ng-content select=\"sky-dropdown-button\"> </ng-content>\n </div>\n <div class=\"sky-dropdown-button-icon-container\">\n <sky-icon\n *skyThemeIf=\"'default'\"\n class=\"sky-dropdown-caret\"\n icon=\"caret-down\"\n >\n </sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n class=\"sky-dropdown-caret\"\n icon=\"chevron-down\"\n iconType=\"skyux\"\n >\n </sky-icon>\n </div>\n </div>\n <div\n *ngIf=\"buttonType !== 'select' && buttonType !== 'tab' && buttonType\"\n >\n <sky-icon [icon]=\"buttonType\" size=\"lg\"></sky-icon>\n </div>\n </ng-template>\n </ng-container>\n </button>\n</div>\n\n<ng-template #menuContainerTemplateRef>\n <div\n class=\"sky-dropdown-menu-container\"\n [class.hidden]=\"!isVisible\"\n #menuContainerElementRef\n >\n <ng-content select=\"sky-dropdown-menu\"></ng-content>\n </div>\n</ng-template>\n", styles: [".sky-dropdown-button-type-tab{background-color:transparent;border:none;border-radius:4px 4px 0 0;color:var(--sky-text-color-deemphasized);cursor:pointer;display:inline-block;font-weight:600;line-height:1.8;padding:8px 16px;background-color:var(--sky-background-color-primary-dark);color:var(--sky-text-color-on-dark);max-width:100%;text-align:left}.sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:var(--sky-background-color-neutral-light);color:var(--sky-text-color-default);text-decoration:none}.sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:var(--sky-background-color-disabled);cursor:not-allowed;pointer-events:none;outline:none;text-decoration:none}.sky-dropdown-button-type-tab.sky-btn-tab-disabled:hover{color:var(--sky-text-color-deemphasized);cursor:default;text-decoration:none}.sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:var(--sky-background-color-primary-dark);color:var(--sky-text-color-on-dark)}.sky-dropdown-button-type-context-menu{border-radius:50%;padding:3px 8px}:host-context(.sky-toolbar-container) .sky-dropdown-button.sky-btn-link{color:#212327}.sky-dropdown-caret{margin-left:10px}.sky-dropdown-button-container{display:flex}.sky-dropdown-button-content-container{flex-shrink:1;overflow:hidden;text-overflow:ellipsis}.sky-dropdown-button-icon-container{flex-grow:1}.sky-dropdown-menu-container{position:fixed}.hidden{visibility:hidden}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab{border:none;border-radius:0;color:var(--sky-text-color-deemphasized);font-weight:400;padding:10px 15px;transition:box-shadow .15s;background-color:transparent;color:var(--sky-text-color-default);box-shadow:none}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:not(:active){border-bottom:solid 3px #1870B8;padding-bottom:7px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:transparent;color:var(--sky-text-color-default)}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab .sky-btn-tab-close,:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab .sky-tab-header-count{color:var(--sky-text-color-deemphasized)}:host-context(.sky-theme-modern) .sky-dropdown-caret{margin-left:10px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-context-menu{border-radius:6px;padding:3px 8px;background-color:transparent}:host-context(.sky-theme-modern) .sky-dropdown-button-type-context-menu:not(:hover):not(:focus-visible){box-shadow:none}.sky-theme-modern .sky-dropdown-button-type-tab{border:none;border-radius:0;color:var(--sky-text-color-deemphasized);font-weight:400;padding:10px 15px;transition:box-shadow .15s;background-color:transparent;color:var(--sky-text-color-default);box-shadow:none}.sky-theme-modern .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-dropdown-button-type-tab:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-dropdown-button-type-tab:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-dropdown-button-type-tab:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-dropdown-button-type-tab.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-dropdown-button-type-tab:not(:active){border-bottom:solid 3px #1870B8;padding-bottom:7px}.sky-theme-modern .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:transparent;color:var(--sky-text-color-default)}.sky-theme-modern .sky-dropdown-button-type-tab .sky-btn-tab-close,.sky-theme-modern .sky-dropdown-button-type-tab .sky-tab-header-count{color:var(--sky-text-color-deemphasized)}.sky-theme-modern .sky-dropdown-caret{margin-left:10px}.sky-theme-modern .sky-dropdown-button-type-context-menu{border-radius:6px;padding:3px 8px;background-color:transparent}.sky-theme-modern .sky-dropdown-button-type-context-menu:not(:hover):not(:focus-visible){box-shadow:none}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab{color:#fff}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab:hover{color:#fff}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab .sky-btn-tab-close,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab .sky-tab-header-count{color:#efefef}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab:hover{color:#fff}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab .sky-btn-tab-close,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab .sky-tab-header-count{color:#efefef}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i2.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
337
346
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDropdownComponent, decorators: [{
|
|
338
347
|
type: Component,
|
|
339
348
|
args: [{ selector: 'sky-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sky-dropdown\">\n <button\n class=\"sky-btn sky-dropdown-button\"\n type=\"button\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-controls]=\"isOpen ? menuId : null\"\n [attr.aria-haspopup]=\"menuAriaRole\"\n [attr.aria-label]=\"\n label || ('skyux_dropdown_context_menu_default_label' | skyLibResources)\n \"\n [attr.title]=\"title\"\n [disabled]=\"disabled\"\n [ngClass]=\"[\n 'sky-dropdown-button-type-' + buttonType,\n 'sky-btn-' + buttonStyle\n ]\"\n #triggerButton\n >\n <ng-container [ngSwitch]=\"buttonType\">\n <ng-template ngSwitchCase=\"context-menu\">\n <sky-icon *skyThemeIf=\"'default'\" icon=\"ellipsis-h\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"ellipsis\"\n iconType=\"skyux\"\n ></sky-icon>\n </ng-template>\n\n <ng-template ngSwitchDefault>\n <div\n *ngIf=\"buttonType === 'select' || buttonType === 'tab' || !buttonType\"\n class=\"sky-dropdown-button-container\"\n >\n <div class=\"sky-dropdown-button-content-container\">\n <ng-content select=\"sky-dropdown-button\"> </ng-content>\n </div>\n <div class=\"sky-dropdown-button-icon-container\">\n <sky-icon\n *skyThemeIf=\"'default'\"\n class=\"sky-dropdown-caret\"\n icon=\"caret-down\"\n >\n </sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n class=\"sky-dropdown-caret\"\n icon=\"chevron-down\"\n iconType=\"skyux\"\n >\n </sky-icon>\n </div>\n </div>\n <div\n *ngIf=\"buttonType !== 'select' && buttonType !== 'tab' && buttonType\"\n >\n <sky-icon [icon]=\"buttonType\" size=\"lg\"></sky-icon>\n </div>\n </ng-template>\n </ng-container>\n </button>\n</div>\n\n<ng-template #menuContainerTemplateRef>\n <div\n class=\"sky-dropdown-menu-container\"\n [class.hidden]=\"!isVisible\"\n #menuContainerElementRef\n >\n <ng-content select=\"sky-dropdown-menu\"></ng-content>\n </div>\n</ng-template>\n", styles: [".sky-dropdown-button-type-tab{background-color:transparent;border:none;border-radius:4px 4px 0 0;color:var(--sky-text-color-deemphasized);cursor:pointer;display:inline-block;font-weight:600;line-height:1.8;padding:8px 16px;background-color:var(--sky-background-color-primary-dark);color:var(--sky-text-color-on-dark);max-width:100%;text-align:left}.sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:var(--sky-background-color-neutral-light);color:var(--sky-text-color-default);text-decoration:none}.sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:var(--sky-background-color-disabled);cursor:not-allowed;pointer-events:none;outline:none;text-decoration:none}.sky-dropdown-button-type-tab.sky-btn-tab-disabled:hover{color:var(--sky-text-color-deemphasized);cursor:default;text-decoration:none}.sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:var(--sky-background-color-primary-dark);color:var(--sky-text-color-on-dark)}.sky-dropdown-button-type-context-menu{border-radius:50%;padding:3px 8px}:host-context(.sky-toolbar-container) .sky-dropdown-button.sky-btn-link{color:#212327}.sky-dropdown-caret{margin-left:10px}.sky-dropdown-button-container{display:flex}.sky-dropdown-button-content-container{flex-shrink:1;overflow:hidden;text-overflow:ellipsis}.sky-dropdown-button-icon-container{flex-grow:1}.sky-dropdown-menu-container{position:fixed}.hidden{visibility:hidden}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab{border:none;border-radius:0;color:var(--sky-text-color-deemphasized);font-weight:400;padding:10px 15px;transition:box-shadow .15s;background-color:transparent;color:var(--sky-text-color-default);box-shadow:none}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:active{color:var(--sky-text-color-default);padding-bottom:7px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:not(:active){border-bottom:solid 3px #1870B8;padding-bottom:7px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:transparent;color:var(--sky-text-color-default)}:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab .sky-btn-tab-close,:host-context(.sky-theme-modern) .sky-dropdown-button-type-tab .sky-tab-header-count{color:var(--sky-text-color-deemphasized)}:host-context(.sky-theme-modern) .sky-dropdown-caret{margin-left:10px}:host-context(.sky-theme-modern) .sky-dropdown-button-type-context-menu{border-radius:6px;padding:3px 8px;background-color:transparent}:host-context(.sky-theme-modern) .sky-dropdown-button-type-context-menu:not(:hover):not(:focus-visible){box-shadow:none}.sky-theme-modern .sky-dropdown-button-type-tab{border:none;border-radius:0;color:var(--sky-text-color-deemphasized);font-weight:400;padding:10px 15px;transition:box-shadow .15s;background-color:transparent;color:var(--sky-text-color-default);box-shadow:none}.sky-theme-modern .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled):not(.sky-btn-tab-selected):not(.sky-dropdown-button-type-tab):not(:focus-visible){background-color:transparent;border-bottom:solid 1px var(--sky-highlight-color-info);color:var(--sky-text-color-default);padding-bottom:9px}.sky-theme-modern .sky-dropdown-button-type-tab:focus-visible{background-color:transparent;color:var(--sky-text-color-default);outline:none}.sky-theme-modern .sky-dropdown-button-type-tab:focus-visible:not(:active){color:var(--sky-text-color-default);outline:solid 2px var(--sky-background-color-primary-dark);outline-offset:-2px;box-shadow:0 1px 8px #0000004d}.sky-theme-modern .sky-dropdown-button-type-tab:active{color:var(--sky-text-color-default);padding-bottom:7px}.sky-theme-modern .sky-dropdown-button-type-tab.sky-btn-tab-disabled{background-color:transparent;font-family:BLKB Sans,Helvetica Neue,Arial,sans-serif;color:var(--sky-text-color-deemphasized);font-weight:400;font-size:15px;font-style:italic}.sky-theme-modern .sky-dropdown-button-type-tab.sky-btn-tab-disabled .sky-btn-tab-close{font-size:16px}.sky-theme-modern .sky-dropdown-button-type-tab:not(:active){border-bottom:solid 3px #1870B8;padding-bottom:7px}.sky-theme-modern .sky-dropdown-button-type-tab:hover:not(.sky-btn-tab-disabled){background-color:transparent;color:var(--sky-text-color-default)}.sky-theme-modern .sky-dropdown-button-type-tab .sky-btn-tab-close,.sky-theme-modern .sky-dropdown-button-type-tab .sky-tab-header-count{color:var(--sky-text-color-deemphasized)}.sky-theme-modern .sky-dropdown-caret{margin-left:10px}.sky-theme-modern .sky-dropdown-button-type-context-menu{border-radius:6px;padding:3px 8px;background-color:transparent}.sky-theme-modern .sky-dropdown-button-type-context-menu:not(:hover):not(:focus-visible){box-shadow:none}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab{color:#fff}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab:hover{color:#fff}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab .sky-btn-tab-close,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-dropdown-button-type-tab .sky-tab-header-count{color:#efefef}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab:hover{color:#fff}.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab .sky-btn-tab-close,.sky-theme-modern.sky-theme-mode-dark .sky-dropdown-button-type-tab .sky-tab-header-count{color:#efefef}\n"] }]
|
|
340
349
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyAffixService }, { type: i1.SkyOverlayService }, { type: i1.SkyLogService }, { type: i2.SkyThemeService, decorators: [{
|
|
341
350
|
type: Optional
|
|
351
|
+
}] }, { type: undefined, decorators: [{
|
|
352
|
+
type: Optional
|
|
353
|
+
}, {
|
|
354
|
+
type: Inject,
|
|
355
|
+
args: [SKY_STACKING_CONTEXT]
|
|
342
356
|
}] }]; }, propDecorators: { buttonStyle: [{
|
|
343
357
|
type: Input
|
|
344
358
|
}], buttonType: [{
|
|
@@ -375,4 +389,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImpo
|
|
|
375
389
|
static: true,
|
|
376
390
|
}]
|
|
377
391
|
}] } });
|
|
378
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyLogService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { parseAffixHorizontalAlignment } from './dropdown-extensions';\nimport { SkyDropdownButtonType } from './types/dropdown-button-type';\nimport { SkyDropdownHorizontalAlignment } from './types/dropdown-horizontal-alignment';\nimport { SkyDropdownMessage } from './types/dropdown-message';\nimport { SkyDropdownMessageType } from './types/dropdown-message-type';\nimport { SkyDropdownTriggerType } from './types/dropdown-trigger-type';\n\nconst DEFAULT_BUTTON_TYPE = 'select';\n\n/**\n * Creates a dropdown menu that displays menu items that users may select.\n */\n@Component({\n  selector: 'sky-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDropdownComponent implements OnInit, OnDestroy {\n  /**\n   * The background color for the dropdown button. Available values are `default`,\n   * `primary`, and `link`. These values set the background color and hover behavior from the\n   * [secondary and primary button classes](https://developer.blackbaud.com/skyux/components/button) respectively.\n   * @default \"default\"\n   */\n  @Input()\n  public set buttonStyle(value: string | undefined) {\n    this.#_buttonStyle = value ?? 'default';\n  }\n\n  public get buttonStyle(): string {\n    return this.#_buttonStyle;\n  }\n\n  /**\n   * The type of button to render as the dropdown's trigger element. To display a button\n   * with a caret, specify `'select'` and render the button text or icon in a\n   * `sky-dropdown-button` element. To display a round button with an ellipsis, specify\n   * `'context-menu'`.\n   * @default \"select\"\n   */\n  @Input()\n  public set buttonType(value: SkyDropdownButtonType | string | undefined) {\n    this.#_buttonType = value ?? DEFAULT_BUTTON_TYPE;\n\n    if (value && !['select', 'context-menu', 'tab'].includes(value)) {\n      this.#logService.deprecated(\n        'SkyDropdownComponent.buttonType Font Awesome icon class option',\n        {\n          deprecationMajorVersion: 7,\n          replacementRecommendation:\n            'Set `buttonType` to `select` and render a `<sky-icon>` element within the `<sky-dropdown-button>` element.',\n        }\n      );\n    }\n  }\n\n  public get buttonType(): SkyDropdownButtonType | string {\n    return this.#_buttonType;\n  }\n\n  /**\n   * Whether to disable the dropdown button.\n   * @default false\n   */\n  @Input()\n  public disabled: boolean | undefined = false;\n\n  /**\n   * Whether to close the dropdown when users click away from the menu.\n   * @default true\n   */\n  @Input()\n  public set dismissOnBlur(value: boolean | undefined) {\n    this.#_dismissOnBlur = value ?? true;\n  }\n\n  public get dismissOnBlur(): boolean {\n    return this.#_dismissOnBlur;\n  }\n\n  /**\n   * The ARIA label for the dropdown. This sets the dropdown's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public label: string | undefined;\n\n  /**\n   * The horizontal alignment of the dropdown menu in relation to the dropdown button.\n   * @default \"left\"\n   */\n  @Input()\n  public set horizontalAlignment(\n    value: SkyDropdownHorizontalAlignment | undefined\n  ) {\n    this.#_horizontalAlignment = value ?? 'left';\n  }\n\n  public get horizontalAlignment(): SkyDropdownHorizontalAlignment {\n    return this.#_horizontalAlignment;\n  }\n\n  /**\n   * The observable that sends commands to the dropdown. The commands should respect\n   * the [[SkyDropdownMessage]] type.\n   * @internal\n   */\n  @Input()\n  public messageStream: Subject<SkyDropdownMessage> | undefined =\n    new Subject<SkyDropdownMessage>();\n\n  /**\n   * The title to display in a tooltip when users hover the mouse over the dropdown button.\n   */\n  @Input()\n  public title: string | undefined;\n\n  /**\n   * How users interact with the dropdown button to expose the dropdown menu.\n   * We recommend the default `click` value because the `hover` value can pose\n   * [accessibility](https://developer.blackbaud.com/skyux/learn/accessibility) issues\n   * for users on touch devices such as phones and tablets.\n   * @deprecated We recommend against using this property. If you choose to use the deprecated\n   * `hover` value anyway, we recommend that you not use it in combination with the `title`\n   * property.\n   * @default \"click\"\n   */\n  @Input()\n  public set trigger(value: SkyDropdownTriggerType | undefined) {\n    this.#_trigger = value ?? 'click';\n  }\n\n  public get trigger(): SkyDropdownTriggerType {\n    return this.#_trigger;\n  }\n\n  public set isOpen(value: boolean) {\n    this.#_isOpen = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public get isOpen(): boolean {\n    return this.#_isOpen;\n  }\n\n  @ViewChild('menuContainerElementRef', {\n    read: ElementRef,\n  })\n  public set menuContainerElementRef(value: ElementRef | undefined) {\n    if (value) {\n      this.#destroyAffixer();\n      this.#createAffixer(value);\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public isMouseEnter = false;\n\n  public isVisible = false;\n\n  public menuId: string | undefined;\n\n  public menuAriaRole: string | undefined;\n\n  @ViewChild('menuContainerTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public menuContainerTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButton', {\n    read: ElementRef,\n    static: true,\n  })\n  public set triggerButton(value: ElementRef | undefined) {\n    this.#_triggerButton = value;\n    this.#addEventListeners();\n  }\n\n  public get triggerButton(): ElementRef | undefined {\n    return this.#_triggerButton;\n  }\n\n  #affixer: SkyAffixer | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #_buttonStyle = 'default';\n\n  #_buttonType: SkyDropdownButtonType | string = DEFAULT_BUTTON_TYPE;\n\n  #_dismissOnBlur = true;\n\n  #_horizontalAlignment: SkyDropdownHorizontalAlignment = 'left';\n\n  #_isOpen = false;\n\n  #_trigger: SkyDropdownTriggerType = 'click';\n\n  #_triggerButton: ElementRef | undefined;\n\n  #positionTimeout: number | undefined;\n\n  #changeDetector: ChangeDetectorRef;\n  #affixService: SkyAffixService;\n  #overlayService: SkyOverlayService;\n  #logService: SkyLogService;\n  #themeSvc: SkyThemeService | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    affixService: SkyAffixService,\n    overlayService: SkyOverlayService,\n    logService: SkyLogService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#affixService = affixService;\n    this.#overlayService = overlayService;\n    this.#logService = logService;\n    this.#themeSvc = themeSvc;\n  }\n\n  public ngOnInit(): void {\n    this.messageStream\n      ?.pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((message: SkyDropdownMessage) => {\n        this.#handleIncomingMessages(message);\n      });\n\n    // Load proper icons on theme change.\n    this.#themeSvc?.settingsChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    clearTimeout(this.#positionTimeout);\n\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  #addEventListeners(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#ngUnsubscribe = new Subject<void>();\n    const buttonElement = this.triggerButton?.nativeElement;\n    if (buttonElement) {\n      observableFromEvent(buttonElement, 'click')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.isOpen) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n          } else {\n            this.#sendMessage(SkyDropdownMessageType.Open);\n            // Wait for dropdown to open, then set focus on first item.\n            setTimeout(() => {\n              this.#sendMessage(SkyDropdownMessageType.FocusFirstItem);\n            });\n          }\n        });\n\n      observableFromEvent<KeyboardEvent>(buttonElement, 'keydown')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((event) => {\n          const key = event.key.toLowerCase();\n\n          switch (key) {\n            case 'escape':\n              /*istanbul ignore else*/\n              if (this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n                this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n                event.stopPropagation();\n              }\n              break;\n\n            case 'tab':\n              if (this.isOpen && this.dismissOnBlur) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n              }\n              break;\n\n            case 'arrowup':\n            case 'up':\n              if (!this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Open);\n                this.#sendMessage(SkyDropdownMessageType.FocusLastItem);\n                event.preventDefault();\n                event.stopPropagation();\n              }\n              break;\n\n            case 'enter':\n            case 'arrowdown':\n            case 'down':\n            case ' ': // Spacebar.\n              /*istanbul ignore else*/\n              if (!this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Open);\n                this.#sendMessage(SkyDropdownMessageType.FocusFirstItem);\n                event.preventDefault();\n                event.stopPropagation();\n              }\n              break;\n          }\n        });\n\n      observableFromEvent(buttonElement, 'mouseenter')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.isMouseEnter = true;\n          if (this.trigger === 'hover') {\n            this.#sendMessage(SkyDropdownMessageType.Open);\n          }\n        });\n\n      observableFromEvent(buttonElement, 'mouseleave')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.isMouseEnter = false;\n          if (this.trigger === 'hover') {\n            // Allow the dropdown menu to set isMouseEnter before checking if the close action\n            // should be taken.\n            setTimeout(() => {\n              if (!this.isMouseEnter) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n              }\n            });\n          }\n        });\n    }\n  }\n\n  #createOverlay(): void {\n    if (this.#overlay) {\n      return;\n    }\n\n    if (this.menuContainerTemplateRef) {\n      const overlay = this.#overlayService.create({\n        enableScroll: true,\n        enablePointerEvents: true,\n      });\n\n      overlay.attachTemplate(this.menuContainerTemplateRef);\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.dismissOnBlur) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n          }\n        });\n\n      this.#overlay = overlay;\n    }\n  }\n\n  #destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.#affixer) {\n      this.#affixer.destroy();\n      this.#affixer = undefined;\n    }\n  }\n\n  #destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  #createAffixer(menuContainerElementRef: ElementRef): void {\n    const affixer = this.#affixService.createAffixer(menuContainerElementRef);\n\n    affixer.placementChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = change.placement !== null;\n        this.#changeDetector.markForCheck();\n      });\n\n    this.#affixer = affixer;\n  }\n\n  #handleIncomingMessages(message: SkyDropdownMessage): void {\n    if (!this.disabled) {\n      switch (message.type) {\n        case SkyDropdownMessageType.Open:\n          this.isOpen = true;\n          this.#positionDropdownMenu();\n          break;\n\n        case SkyDropdownMessageType.Close:\n          this.isOpen = false;\n          this.#destroyOverlay();\n          break;\n\n        case SkyDropdownMessageType.Reposition:\n          // Only reposition the dropdown if it is already open.\n          /* istanbul ignore else */\n          if (this.isOpen && this.#affixer) {\n            this.#affixer.reaffix();\n          }\n          break;\n\n        case SkyDropdownMessageType.FocusTriggerButton:\n          this.triggerButton?.nativeElement.focus();\n          break;\n      }\n    }\n  }\n\n  #sendMessage(type: SkyDropdownMessageType): void {\n    this.messageStream?.next({ type });\n  }\n\n  #positionDropdownMenu(): void {\n    this.isVisible = false;\n    this.#createOverlay();\n    this.#changeDetector.markForCheck();\n\n    // Explicitly declare the `setTimeout` from the `window` object in order to use the DOM typings\n    // during a unit test (instead of confusing this with Node's `setTimeout`).\n    this.#positionTimeout = window.setTimeout(() => {\n      if (this.#affixer) {\n        this.#affixer.affixTo(this.triggerButton?.nativeElement, {\n          autoFitContext: SkyAffixAutoFitContext.Viewport,\n          enableAutoFit: true,\n          horizontalAlignment: parseAffixHorizontalAlignment(\n            this.horizontalAlignment\n          ),\n          isSticky: true,\n          placement: 'below',\n        });\n\n        this.isVisible = true;\n        this.#changeDetector.markForCheck();\n      }\n    });\n  }\n}\n","<div class=\"sky-dropdown\">\n  <button\n    class=\"sky-btn sky-dropdown-button\"\n    type=\"button\"\n    [attr.aria-expanded]=\"isOpen\"\n    [attr.aria-controls]=\"isOpen ? menuId : null\"\n    [attr.aria-haspopup]=\"menuAriaRole\"\n    [attr.aria-label]=\"\n      label || ('skyux_dropdown_context_menu_default_label' | skyLibResources)\n    \"\n    [attr.title]=\"title\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"[\n      'sky-dropdown-button-type-' + buttonType,\n      'sky-btn-' + buttonStyle\n    ]\"\n    #triggerButton\n  >\n    <ng-container [ngSwitch]=\"buttonType\">\n      <ng-template ngSwitchCase=\"context-menu\">\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"ellipsis-h\"></sky-icon>\n        <sky-icon\n          *skyThemeIf=\"'modern'\"\n          icon=\"ellipsis\"\n          iconType=\"skyux\"\n        ></sky-icon>\n      </ng-template>\n\n      <ng-template ngSwitchDefault>\n        <div\n          *ngIf=\"buttonType === 'select' || buttonType === 'tab' || !buttonType\"\n          class=\"sky-dropdown-button-container\"\n        >\n          <div class=\"sky-dropdown-button-content-container\">\n            <ng-content select=\"sky-dropdown-button\"> </ng-content>\n          </div>\n          <div class=\"sky-dropdown-button-icon-container\">\n            <sky-icon\n              *skyThemeIf=\"'default'\"\n              class=\"sky-dropdown-caret\"\n              icon=\"caret-down\"\n            >\n            </sky-icon>\n            <sky-icon\n              *skyThemeIf=\"'modern'\"\n              class=\"sky-dropdown-caret\"\n              icon=\"chevron-down\"\n              iconType=\"skyux\"\n            >\n            </sky-icon>\n          </div>\n        </div>\n        <div\n          *ngIf=\"buttonType !== 'select' && buttonType !== 'tab' && buttonType\"\n        >\n          <sky-icon [icon]=\"buttonType\" size=\"lg\"></sky-icon>\n        </div>\n      </ng-template>\n    </ng-container>\n  </button>\n</div>\n\n<ng-template #menuContainerTemplateRef>\n  <div\n    class=\"sky-dropdown-menu-container\"\n    [class.hidden]=\"!isVisible\"\n    #menuContainerElementRef\n  >\n    <ng-content select=\"sky-dropdown-menu\"></ng-content>\n  </div>\n</ng-template>\n"]}
|
|
392
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyLogService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n  SkyStackingContext,\n} from '@skyux/core';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Observable, Subject, fromEvent as observableFromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { parseAffixHorizontalAlignment } from './dropdown-extensions';\nimport { SkyDropdownButtonType } from './types/dropdown-button-type';\nimport { SkyDropdownHorizontalAlignment } from './types/dropdown-horizontal-alignment';\nimport { SkyDropdownMessage } from './types/dropdown-message';\nimport { SkyDropdownMessageType } from './types/dropdown-message-type';\nimport { SkyDropdownTriggerType } from './types/dropdown-trigger-type';\n\nconst DEFAULT_BUTTON_TYPE = 'select';\n\n/**\n * Creates a dropdown menu that displays menu items that users may select.\n */\n@Component({\n  selector: 'sky-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDropdownComponent implements OnInit, OnDestroy {\n  /**\n   * The background color for the dropdown button. Available values are `default`,\n   * `primary`, and `link`. These values set the background color and hover behavior from the\n   * [secondary and primary button classes](https://developer.blackbaud.com/skyux/components/button) respectively.\n   * @default \"default\"\n   */\n  @Input()\n  public set buttonStyle(value: string | undefined) {\n    this.#_buttonStyle = value ?? 'default';\n  }\n\n  public get buttonStyle(): string {\n    return this.#_buttonStyle;\n  }\n\n  /**\n   * The type of button to render as the dropdown's trigger element. To display a button\n   * with a caret, specify `'select'` and render the button text or icon in a\n   * `sky-dropdown-button` element. To display a round button with an ellipsis, specify\n   * `'context-menu'`.\n   * @default \"select\"\n   */\n  @Input()\n  public set buttonType(value: SkyDropdownButtonType | string | undefined) {\n    this.#_buttonType = value ?? DEFAULT_BUTTON_TYPE;\n\n    if (value && !['select', 'context-menu', 'tab'].includes(value)) {\n      this.#logService.deprecated(\n        'SkyDropdownComponent.buttonType Font Awesome icon class option',\n        {\n          deprecationMajorVersion: 7,\n          replacementRecommendation:\n            'Set `buttonType` to `select` and render a `<sky-icon>` element within the `<sky-dropdown-button>` element.',\n        }\n      );\n    }\n  }\n\n  public get buttonType(): SkyDropdownButtonType | string {\n    return this.#_buttonType;\n  }\n\n  /**\n   * Whether to disable the dropdown button.\n   * @default false\n   */\n  @Input()\n  public disabled: boolean | undefined = false;\n\n  /**\n   * Whether to close the dropdown when users click away from the menu.\n   * @default true\n   */\n  @Input()\n  public set dismissOnBlur(value: boolean | undefined) {\n    this.#_dismissOnBlur = value ?? true;\n  }\n\n  public get dismissOnBlur(): boolean {\n    return this.#_dismissOnBlur;\n  }\n\n  /**\n   * The ARIA label for the dropdown. This sets the dropdown's `aria-label` attribute to provide a text equivalent for screen readers\n   * [to support accessibility](https://developer.blackbaud.com/skyux/learn/accessibility).\n   * For more information about the `aria-label` attribute, see the [WAI-ARIA definition](https://www.w3.org/TR/wai-aria/#aria-label).\n   */\n  @Input()\n  public label: string | undefined;\n\n  /**\n   * The horizontal alignment of the dropdown menu in relation to the dropdown button.\n   * @default \"left\"\n   */\n  @Input()\n  public set horizontalAlignment(\n    value: SkyDropdownHorizontalAlignment | undefined\n  ) {\n    this.#_horizontalAlignment = value ?? 'left';\n  }\n\n  public get horizontalAlignment(): SkyDropdownHorizontalAlignment {\n    return this.#_horizontalAlignment;\n  }\n\n  /**\n   * The observable that sends commands to the dropdown. The commands should respect\n   * the [[SkyDropdownMessage]] type.\n   * @internal\n   */\n  @Input()\n  public messageStream: Subject<SkyDropdownMessage> | undefined =\n    new Subject<SkyDropdownMessage>();\n\n  /**\n   * The title to display in a tooltip when users hover the mouse over the dropdown button.\n   */\n  @Input()\n  public title: string | undefined;\n\n  /**\n   * How users interact with the dropdown button to expose the dropdown menu.\n   * We recommend the default `click` value because the `hover` value can pose\n   * [accessibility](https://developer.blackbaud.com/skyux/learn/accessibility) issues\n   * for users on touch devices such as phones and tablets.\n   * @deprecated We recommend against using this property. If you choose to use the deprecated\n   * `hover` value anyway, we recommend that you not use it in combination with the `title`\n   * property.\n   * @default \"click\"\n   */\n  @Input()\n  public set trigger(value: SkyDropdownTriggerType | undefined) {\n    this.#_trigger = value ?? 'click';\n  }\n\n  public get trigger(): SkyDropdownTriggerType {\n    return this.#_trigger;\n  }\n\n  public set isOpen(value: boolean) {\n    this.#_isOpen = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public get isOpen(): boolean {\n    return this.#_isOpen;\n  }\n\n  @ViewChild('menuContainerElementRef', {\n    read: ElementRef,\n  })\n  public set menuContainerElementRef(value: ElementRef | undefined) {\n    if (value) {\n      this.#destroyAffixer();\n      this.#createAffixer(value);\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public isMouseEnter = false;\n\n  public isVisible = false;\n\n  public menuId: string | undefined;\n\n  public menuAriaRole: string | undefined;\n\n  @ViewChild('menuContainerTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public menuContainerTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButton', {\n    read: ElementRef,\n    static: true,\n  })\n  public set triggerButton(value: ElementRef | undefined) {\n    this.#_triggerButton = value;\n    this.#addEventListeners();\n  }\n\n  public get triggerButton(): ElementRef | undefined {\n    return this.#_triggerButton;\n  }\n\n  #affixer: SkyAffixer | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #_buttonStyle = 'default';\n\n  #_buttonType: SkyDropdownButtonType | string = DEFAULT_BUTTON_TYPE;\n\n  #_dismissOnBlur = true;\n\n  #_horizontalAlignment: SkyDropdownHorizontalAlignment = 'left';\n\n  #_isOpen = false;\n\n  #_trigger: SkyDropdownTriggerType = 'click';\n\n  #_triggerButton: ElementRef | undefined;\n\n  #positionTimeout: number | undefined;\n\n  #changeDetector: ChangeDetectorRef;\n  #affixService: SkyAffixService;\n  #overlayService: SkyOverlayService;\n  #logService: SkyLogService;\n  #themeSvc: SkyThemeService | undefined;\n  #zIndex: Observable<number> | undefined;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    affixService: SkyAffixService,\n    overlayService: SkyOverlayService,\n    logService: SkyLogService,\n    @Optional() themeSvc?: SkyThemeService,\n    @Optional()\n    @Inject(SKY_STACKING_CONTEXT)\n    stackingContext?: SkyStackingContext\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#affixService = affixService;\n    this.#overlayService = overlayService;\n    this.#logService = logService;\n    this.#themeSvc = themeSvc;\n    this.#zIndex = stackingContext?.zIndex;\n  }\n\n  public ngOnInit(): void {\n    this.messageStream\n      ?.pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((message: SkyDropdownMessage) => {\n        this.#handleIncomingMessages(message);\n      });\n\n    // Load proper icons on theme change.\n    this.#themeSvc?.settingsChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    clearTimeout(this.#positionTimeout);\n\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  #addEventListeners(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#ngUnsubscribe = new Subject<void>();\n    const buttonElement = this.triggerButton?.nativeElement;\n    if (buttonElement) {\n      observableFromEvent(buttonElement, 'click')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.isOpen) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n          } else {\n            this.#sendMessage(SkyDropdownMessageType.Open);\n            // Wait for dropdown to open, then set focus on first item.\n            setTimeout(() => {\n              this.#sendMessage(SkyDropdownMessageType.FocusFirstItem);\n            });\n          }\n        });\n\n      observableFromEvent<KeyboardEvent>(buttonElement, 'keydown')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((event) => {\n          const key = event.key.toLowerCase();\n\n          switch (key) {\n            case 'escape':\n              /*istanbul ignore else*/\n              if (this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n                this.#sendMessage(SkyDropdownMessageType.FocusTriggerButton);\n                event.stopPropagation();\n              }\n              break;\n\n            case 'tab':\n              if (this.isOpen && this.dismissOnBlur) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n              }\n              break;\n\n            case 'arrowup':\n            case 'up':\n              if (!this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Open);\n                this.#sendMessage(SkyDropdownMessageType.FocusLastItem);\n                event.preventDefault();\n                event.stopPropagation();\n              }\n              break;\n\n            case 'enter':\n            case 'arrowdown':\n            case 'down':\n            case ' ': // Spacebar.\n              /*istanbul ignore else*/\n              if (!this.isOpen) {\n                this.#sendMessage(SkyDropdownMessageType.Open);\n                this.#sendMessage(SkyDropdownMessageType.FocusFirstItem);\n                event.preventDefault();\n                event.stopPropagation();\n              }\n              break;\n          }\n        });\n\n      observableFromEvent(buttonElement, 'mouseenter')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.isMouseEnter = true;\n          if (this.trigger === 'hover') {\n            this.#sendMessage(SkyDropdownMessageType.Open);\n          }\n        });\n\n      observableFromEvent(buttonElement, 'mouseleave')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.isMouseEnter = false;\n          if (this.trigger === 'hover') {\n            // Allow the dropdown menu to set isMouseEnter before checking if the close action\n            // should be taken.\n            setTimeout(() => {\n              if (!this.isMouseEnter) {\n                this.#sendMessage(SkyDropdownMessageType.Close);\n              }\n            });\n          }\n        });\n    }\n  }\n\n  #createOverlay(): void {\n    if (this.#overlay) {\n      return;\n    }\n\n    if (this.menuContainerTemplateRef) {\n      const overlay = this.#overlayService.create({\n        enableScroll: true,\n        enablePointerEvents: true,\n      });\n\n      if (this.#zIndex) {\n        this.#zIndex\n          .pipe(takeUntil(this.#ngUnsubscribe))\n          .subscribe((zIndex) => {\n            overlay.componentRef.instance.zIndex = zIndex.toString(10);\n          });\n      }\n\n      overlay.attachTemplate(this.menuContainerTemplateRef);\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.dismissOnBlur) {\n            this.#sendMessage(SkyDropdownMessageType.Close);\n          }\n        });\n\n      this.#overlay = overlay;\n    }\n  }\n\n  #destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.#affixer) {\n      this.#affixer.destroy();\n      this.#affixer = undefined;\n    }\n  }\n\n  #destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  #createAffixer(menuContainerElementRef: ElementRef): void {\n    const affixer = this.#affixService.createAffixer(menuContainerElementRef);\n\n    affixer.placementChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = change.placement !== null;\n        this.#changeDetector.markForCheck();\n      });\n\n    this.#affixer = affixer;\n  }\n\n  #handleIncomingMessages(message: SkyDropdownMessage): void {\n    if (!this.disabled) {\n      switch (message.type) {\n        case SkyDropdownMessageType.Open:\n          this.isOpen = true;\n          this.#positionDropdownMenu();\n          break;\n\n        case SkyDropdownMessageType.Close:\n          this.isOpen = false;\n          this.#destroyOverlay();\n          break;\n\n        case SkyDropdownMessageType.Reposition:\n          // Only reposition the dropdown if it is already open.\n          /* istanbul ignore else */\n          if (this.isOpen && this.#affixer) {\n            this.#affixer.reaffix();\n          }\n          break;\n\n        case SkyDropdownMessageType.FocusTriggerButton:\n          this.triggerButton?.nativeElement.focus();\n          break;\n      }\n    }\n  }\n\n  #sendMessage(type: SkyDropdownMessageType): void {\n    this.messageStream?.next({ type });\n  }\n\n  #positionDropdownMenu(): void {\n    this.isVisible = false;\n    this.#createOverlay();\n    this.#changeDetector.markForCheck();\n\n    // Explicitly declare the `setTimeout` from the `window` object in order to use the DOM typings\n    // during a unit test (instead of confusing this with Node's `setTimeout`).\n    this.#positionTimeout = window.setTimeout(() => {\n      if (this.#affixer) {\n        this.#affixer.affixTo(this.triggerButton?.nativeElement, {\n          autoFitContext: SkyAffixAutoFitContext.Viewport,\n          enableAutoFit: true,\n          horizontalAlignment: parseAffixHorizontalAlignment(\n            this.horizontalAlignment\n          ),\n          isSticky: true,\n          placement: 'below',\n        });\n\n        this.isVisible = true;\n        this.#changeDetector.markForCheck();\n      }\n    });\n  }\n}\n","<div class=\"sky-dropdown\">\n  <button\n    class=\"sky-btn sky-dropdown-button\"\n    type=\"button\"\n    [attr.aria-expanded]=\"isOpen\"\n    [attr.aria-controls]=\"isOpen ? menuId : null\"\n    [attr.aria-haspopup]=\"menuAriaRole\"\n    [attr.aria-label]=\"\n      label || ('skyux_dropdown_context_menu_default_label' | skyLibResources)\n    \"\n    [attr.title]=\"title\"\n    [disabled]=\"disabled\"\n    [ngClass]=\"[\n      'sky-dropdown-button-type-' + buttonType,\n      'sky-btn-' + buttonStyle\n    ]\"\n    #triggerButton\n  >\n    <ng-container [ngSwitch]=\"buttonType\">\n      <ng-template ngSwitchCase=\"context-menu\">\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"ellipsis-h\"></sky-icon>\n        <sky-icon\n          *skyThemeIf=\"'modern'\"\n          icon=\"ellipsis\"\n          iconType=\"skyux\"\n        ></sky-icon>\n      </ng-template>\n\n      <ng-template ngSwitchDefault>\n        <div\n          *ngIf=\"buttonType === 'select' || buttonType === 'tab' || !buttonType\"\n          class=\"sky-dropdown-button-container\"\n        >\n          <div class=\"sky-dropdown-button-content-container\">\n            <ng-content select=\"sky-dropdown-button\"> </ng-content>\n          </div>\n          <div class=\"sky-dropdown-button-icon-container\">\n            <sky-icon\n              *skyThemeIf=\"'default'\"\n              class=\"sky-dropdown-caret\"\n              icon=\"caret-down\"\n            >\n            </sky-icon>\n            <sky-icon\n              *skyThemeIf=\"'modern'\"\n              class=\"sky-dropdown-caret\"\n              icon=\"chevron-down\"\n              iconType=\"skyux\"\n            >\n            </sky-icon>\n          </div>\n        </div>\n        <div\n          *ngIf=\"buttonType !== 'select' && buttonType !== 'tab' && buttonType\"\n        >\n          <sky-icon [icon]=\"buttonType\" size=\"lg\"></sky-icon>\n        </div>\n      </ng-template>\n    </ng-container>\n  </button>\n</div>\n\n<ng-template #menuContainerTemplateRef>\n  <div\n    class=\"sky-dropdown-menu-container\"\n    [class.hidden]=\"!isVisible\"\n    #menuContainerElementRef\n  >\n    <ng-content select=\"sky-dropdown-menu\"></ng-content>\n  </div>\n</ng-template>\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
var _SkyPopoverComponent_instances, _SkyPopoverComponent_contentRef, _SkyPopoverComponent_isMarkedForCloseOnMouseLeave, _SkyPopoverComponent_ngUnsubscribe, _SkyPopoverComponent_overlay, _SkyPopoverComponent__alignment, _SkyPopoverComponent__dismissOnBlur, _SkyPopoverComponent__placement, _SkyPopoverComponent__popoverType, _SkyPopoverComponent_overlayService, _SkyPopoverComponent_setupOverlay;
|
|
1
|
+
var _SkyPopoverComponent_instances, _SkyPopoverComponent_contentRef, _SkyPopoverComponent_isMarkedForCloseOnMouseLeave, _SkyPopoverComponent_ngUnsubscribe, _SkyPopoverComponent_overlay, _SkyPopoverComponent__alignment, _SkyPopoverComponent__dismissOnBlur, _SkyPopoverComponent__placement, _SkyPopoverComponent__popoverType, _SkyPopoverComponent_overlayService, _SkyPopoverComponent_zIndex, _SkyPopoverComponent_setupOverlay;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { Component, EventEmitter, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
|
|
3
|
+
import { Component, EventEmitter, Inject, Input, Optional, Output, TemplateRef, ViewChild, } from '@angular/core';
|
|
4
|
+
import { SKY_STACKING_CONTEXT, } from '@skyux/core';
|
|
4
5
|
import { Subject } from 'rxjs';
|
|
5
6
|
import { takeUntil } from 'rxjs/operators';
|
|
6
7
|
import { SkyPopoverContentComponent } from './popover-content.component';
|
|
@@ -8,7 +9,7 @@ import { SkyPopoverContext } from './popover-context';
|
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@skyux/core";
|
|
10
11
|
export class SkyPopoverComponent {
|
|
11
|
-
constructor(overlayService) {
|
|
12
|
+
constructor(overlayService, stackingContext) {
|
|
12
13
|
_SkyPopoverComponent_instances.add(this);
|
|
13
14
|
/**
|
|
14
15
|
* Fires when users close the popover.
|
|
@@ -39,7 +40,9 @@ export class SkyPopoverComponent {
|
|
|
39
40
|
_SkyPopoverComponent__placement.set(this, 'above');
|
|
40
41
|
_SkyPopoverComponent__popoverType.set(this, 'info');
|
|
41
42
|
_SkyPopoverComponent_overlayService.set(this, void 0);
|
|
43
|
+
_SkyPopoverComponent_zIndex.set(this, void 0);
|
|
42
44
|
__classPrivateFieldSet(this, _SkyPopoverComponent_overlayService, overlayService, "f");
|
|
45
|
+
__classPrivateFieldSet(this, _SkyPopoverComponent_zIndex, stackingContext?.zIndex, "f");
|
|
43
46
|
}
|
|
44
47
|
/**
|
|
45
48
|
* The horizontal alignment of the popover in relation to the trigger element.
|
|
@@ -140,12 +143,19 @@ export class SkyPopoverComponent {
|
|
|
140
143
|
__classPrivateFieldSet(this, _SkyPopoverComponent_isMarkedForCloseOnMouseLeave, true, "f");
|
|
141
144
|
}
|
|
142
145
|
}
|
|
143
|
-
_SkyPopoverComponent_contentRef = new WeakMap(), _SkyPopoverComponent_isMarkedForCloseOnMouseLeave = new WeakMap(), _SkyPopoverComponent_ngUnsubscribe = new WeakMap(), _SkyPopoverComponent_overlay = new WeakMap(), _SkyPopoverComponent__alignment = new WeakMap(), _SkyPopoverComponent__dismissOnBlur = new WeakMap(), _SkyPopoverComponent__placement = new WeakMap(), _SkyPopoverComponent__popoverType = new WeakMap(), _SkyPopoverComponent_overlayService = new WeakMap(), _SkyPopoverComponent_instances = new WeakSet(), _SkyPopoverComponent_setupOverlay = function _SkyPopoverComponent_setupOverlay() {
|
|
146
|
+
_SkyPopoverComponent_contentRef = new WeakMap(), _SkyPopoverComponent_isMarkedForCloseOnMouseLeave = new WeakMap(), _SkyPopoverComponent_ngUnsubscribe = new WeakMap(), _SkyPopoverComponent_overlay = new WeakMap(), _SkyPopoverComponent__alignment = new WeakMap(), _SkyPopoverComponent__dismissOnBlur = new WeakMap(), _SkyPopoverComponent__placement = new WeakMap(), _SkyPopoverComponent__popoverType = new WeakMap(), _SkyPopoverComponent_overlayService = new WeakMap(), _SkyPopoverComponent_zIndex = new WeakMap(), _SkyPopoverComponent_instances = new WeakSet(), _SkyPopoverComponent_setupOverlay = function _SkyPopoverComponent_setupOverlay() {
|
|
144
147
|
if (this.templateRef) {
|
|
145
148
|
const overlay = __classPrivateFieldGet(this, _SkyPopoverComponent_overlayService, "f").create({
|
|
146
149
|
enableScroll: true,
|
|
147
150
|
enablePointerEvents: true,
|
|
148
151
|
});
|
|
152
|
+
if (__classPrivateFieldGet(this, _SkyPopoverComponent_zIndex, "f")) {
|
|
153
|
+
__classPrivateFieldGet(this, _SkyPopoverComponent_zIndex, "f")
|
|
154
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyPopoverComponent_ngUnsubscribe, "f")))
|
|
155
|
+
.subscribe((zIndex) => {
|
|
156
|
+
overlay.componentRef.instance.zIndex = zIndex.toString(10);
|
|
157
|
+
});
|
|
158
|
+
}
|
|
149
159
|
overlay.backdropClick
|
|
150
160
|
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyPopoverComponent_ngUnsubscribe, "f")))
|
|
151
161
|
.subscribe(() => {
|
|
@@ -186,12 +196,17 @@ _SkyPopoverComponent_contentRef = new WeakMap(), _SkyPopoverComponent_isMarkedFo
|
|
|
186
196
|
__classPrivateFieldSet(this, _SkyPopoverComponent_contentRef, contentRef, "f");
|
|
187
197
|
}
|
|
188
198
|
};
|
|
189
|
-
SkyPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyPopoverComponent, deps: [{ token: i1.SkyOverlayService }], target: i0.ɵɵFactoryTarget.Component });
|
|
199
|
+
SkyPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyPopoverComponent, deps: [{ token: i1.SkyOverlayService }, { token: SKY_STACKING_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
190
200
|
SkyPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyPopoverComponent, selector: "sky-popover", inputs: { alignment: "alignment", dismissOnBlur: "dismissOnBlur", placement: "placement", popoverTitle: "popoverTitle", popoverType: "popoverType" }, outputs: { popoverClosed: "popoverClosed", popoverOpened: "popoverOpened" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<ng-template #templateRef>\n <ng-content></ng-content>\n</ng-template>\n" });
|
|
191
201
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyPopoverComponent, decorators: [{
|
|
192
202
|
type: Component,
|
|
193
203
|
args: [{ selector: 'sky-popover', template: "<ng-template #templateRef>\n <ng-content></ng-content>\n</ng-template>\n" }]
|
|
194
|
-
}], ctorParameters: function () { return [{ type: i1.SkyOverlayService }
|
|
204
|
+
}], ctorParameters: function () { return [{ type: i1.SkyOverlayService }, { type: undefined, decorators: [{
|
|
205
|
+
type: Optional
|
|
206
|
+
}, {
|
|
207
|
+
type: Inject,
|
|
208
|
+
args: [SKY_STACKING_CONTEXT]
|
|
209
|
+
}] }]; }, propDecorators: { alignment: [{
|
|
195
210
|
type: Input
|
|
196
211
|
}], dismissOnBlur: [{
|
|
197
212
|
type: Input
|
|
@@ -212,4 +227,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImpo
|
|
|
212
227
|
static: true,
|
|
213
228
|
}]
|
|
214
229
|
}] } });
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/popover/popover.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { SkyOverlayInstance, SkyOverlayService } from '@skyux/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyPopoverContentComponent } from './popover-content.component';\nimport { SkyPopoverContext } from './popover-context';\nimport { SkyPopoverAlignment } from './types/popover-alignment';\nimport { SkyPopoverPlacement } from './types/popover-placement';\nimport { SkyPopoverType } from './types/popover-type';\n\n@Component({\n  selector: 'sky-popover',\n  templateUrl: './popover.component.html',\n})\nexport class SkyPopoverComponent implements OnDestroy {\n  /**\n   * The horizontal alignment of the popover in relation to the trigger element.\n   * The `skyPopoverAlignment` property on the popover directive takes precedence over this property when specified.\n   * @default \"center\"\n   */\n  @Input()\n  public set alignment(value: SkyPopoverAlignment | undefined) {\n    this.#_alignment = value ?? 'center';\n  }\n\n  public get alignment(): SkyPopoverAlignment {\n    return this.#_alignment;\n  }\n\n  /**\n   * Whether to close the popover when it loses focus.\n   * To require users to click a trigger button to close the popover, set this input to false.\n   * @default true\n   */\n  @Input()\n  public set dismissOnBlur(value: boolean | undefined) {\n    this.#_dismissOnBlur = value ?? true;\n  }\n\n  public get dismissOnBlur(): boolean {\n    return this.#_dismissOnBlur;\n  }\n\n  /**\n   * The placement of the popover in relation to the trigger element.\n   * The `skyPopoverPlacement` property on the popover directive takes precedence over this property when specified.\n   * @default \"above\"\n   */\n  @Input()\n  public set placement(value: SkyPopoverPlacement | undefined) {\n    this.#_placement = value ?? 'above';\n  }\n\n  public get placement(): SkyPopoverPlacement {\n    return this.#_placement;\n  }\n\n  /**\n   * The title for the popover.\n   */\n  @Input()\n  public popoverTitle: string | undefined;\n\n  /**\n   * The type of popover.\n   * @default \"info\"\n   */\n  @Input()\n  public set popoverType(value: SkyPopoverType | undefined) {\n    this.#_popoverType = value ?? 'info';\n  }\n\n  public get popoverType(): SkyPopoverType {\n    return this.#_popoverType;\n  }\n\n  /**\n   * Fires when users close the popover.\n   */\n  @Output()\n  public popoverClosed = new EventEmitter<SkyPopoverComponent>();\n\n  /**\n   * Fires when users open the popover.\n   */\n  @Output()\n  public popoverOpened = new EventEmitter<SkyPopoverComponent>();\n\n  /**\n   * Whether the popover is in the process of being opened or closed.\n   * @internal\n   */\n  public isActive = false;\n\n  /**\n   * Used by unit tests to disable animations since the component is injected at the bottom of the\n   * document body.\n   * @internal\n   */\n  public enableAnimations = true;\n\n  public isMouseEnter = false;\n\n  @ViewChild('templateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public templateRef: TemplateRef<unknown> | undefined;\n\n  #contentRef!: SkyPopoverContentComponent;\n\n  #isMarkedForCloseOnMouseLeave = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #_alignment: SkyPopoverAlignment = 'center';\n\n  #_dismissOnBlur = true;\n\n  #_placement: SkyPopoverPlacement = 'above';\n\n  #_popoverType: SkyPopoverType = 'info';\n\n  #overlayService: SkyOverlayService;\n\n  constructor(overlayService: SkyOverlayService) {\n    this.#overlayService = overlayService;\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  /**\n   * Positions the popover next to a given caller element.\n   * @param caller The element that opened the popover.\n   * @param placement The placement of the popover.\n   * @param alignment The horizontal alignment of the popover.\n   * @internal\n   */\n  public positionNextTo(\n    caller: ElementRef,\n    placement?: SkyPopoverPlacement,\n    alignment?: SkyPopoverAlignment\n  ): void {\n    if (!this.#overlay) {\n      this.#setupOverlay();\n    }\n\n    this.placement = placement ?? this.placement;\n    this.alignment = alignment ?? this.alignment;\n    this.isActive = true;\n\n    this.#contentRef.open(caller, {\n      dismissOnBlur: this.dismissOnBlur,\n      enableAnimations: this.enableAnimations,\n      horizontalAlignment: this.alignment,\n      isStatic: false,\n      placement: this.placement,\n      popoverTitle: this.popoverTitle,\n      popoverType: this.popoverType,\n    });\n  }\n\n  /**\n   * Closes the popover.\n   * @internal\n   */\n  public close(): void {\n    /*istanbul ignore next*/\n    this.#contentRef?.close();\n  }\n\n  /**\n   * Brings focus to the popover element if its open.\n   * @internal\n   */\n  public applyFocus(): void {\n    /*istanbul ignore next*/\n    this.#contentRef?.applyFocus();\n  }\n\n  /**\n   * Adds a flag to the popover to close when the mouse leaves the popover's bounds.\n   * @internal\n   */\n  public markForCloseOnMouseLeave(): void {\n    this.#isMarkedForCloseOnMouseLeave = true;\n  }\n\n  #setupOverlay(): void {\n    if (this.templateRef) {\n      const overlay = this.#overlayService.create({\n        enableScroll: true,\n        enablePointerEvents: true,\n      });\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.dismissOnBlur) {\n            this.close();\n          }\n        });\n\n      const contentRef = overlay.attachComponent(SkyPopoverContentComponent, [\n        {\n          provide: SkyPopoverContext,\n          useValue: new SkyPopoverContext({\n            contentTemplateRef: this.templateRef,\n          }),\n        },\n      ]);\n\n      contentRef.opened.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n        this.popoverOpened.emit(this);\n      });\n\n      contentRef.closed.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n        /*istanbul ignore else*/\n        if (this.isActive && this.#overlay) {\n          this.#overlayService.close(this.#overlay);\n          this.#overlay = undefined;\n          this.isActive = false;\n          this.popoverClosed.emit(this);\n        }\n      });\n\n      contentRef.isMouseEnter\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((isMouseEnter) => {\n          this.isMouseEnter = isMouseEnter;\n          if (this.#isMarkedForCloseOnMouseLeave) {\n            this.#isMarkedForCloseOnMouseLeave = false;\n            this.close();\n          }\n        });\n\n      this.#overlay = overlay;\n      this.#contentRef = contentRef;\n    }\n  }\n}\n","<ng-template #templateRef>\n  <ng-content></ng-content>\n</ng-template>\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/popovers/src/lib/modules/popover/popover.component.ts","../../../../../../../../libs/components/popovers/src/lib/modules/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyOverlayInstance,\n  SkyOverlayService,\n  SkyStackingContext,\n} from '@skyux/core';\n\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyPopoverContentComponent } from './popover-content.component';\nimport { SkyPopoverContext } from './popover-context';\nimport { SkyPopoverAlignment } from './types/popover-alignment';\nimport { SkyPopoverPlacement } from './types/popover-placement';\nimport { SkyPopoverType } from './types/popover-type';\n\n@Component({\n  selector: 'sky-popover',\n  templateUrl: './popover.component.html',\n})\nexport class SkyPopoverComponent implements OnDestroy {\n  /**\n   * The horizontal alignment of the popover in relation to the trigger element.\n   * The `skyPopoverAlignment` property on the popover directive takes precedence over this property when specified.\n   * @default \"center\"\n   */\n  @Input()\n  public set alignment(value: SkyPopoverAlignment | undefined) {\n    this.#_alignment = value ?? 'center';\n  }\n\n  public get alignment(): SkyPopoverAlignment {\n    return this.#_alignment;\n  }\n\n  /**\n   * Whether to close the popover when it loses focus.\n   * To require users to click a trigger button to close the popover, set this input to false.\n   * @default true\n   */\n  @Input()\n  public set dismissOnBlur(value: boolean | undefined) {\n    this.#_dismissOnBlur = value ?? true;\n  }\n\n  public get dismissOnBlur(): boolean {\n    return this.#_dismissOnBlur;\n  }\n\n  /**\n   * The placement of the popover in relation to the trigger element.\n   * The `skyPopoverPlacement` property on the popover directive takes precedence over this property when specified.\n   * @default \"above\"\n   */\n  @Input()\n  public set placement(value: SkyPopoverPlacement | undefined) {\n    this.#_placement = value ?? 'above';\n  }\n\n  public get placement(): SkyPopoverPlacement {\n    return this.#_placement;\n  }\n\n  /**\n   * The title for the popover.\n   */\n  @Input()\n  public popoverTitle: string | undefined;\n\n  /**\n   * The type of popover.\n   * @default \"info\"\n   */\n  @Input()\n  public set popoverType(value: SkyPopoverType | undefined) {\n    this.#_popoverType = value ?? 'info';\n  }\n\n  public get popoverType(): SkyPopoverType {\n    return this.#_popoverType;\n  }\n\n  /**\n   * Fires when users close the popover.\n   */\n  @Output()\n  public popoverClosed = new EventEmitter<SkyPopoverComponent>();\n\n  /**\n   * Fires when users open the popover.\n   */\n  @Output()\n  public popoverOpened = new EventEmitter<SkyPopoverComponent>();\n\n  /**\n   * Whether the popover is in the process of being opened or closed.\n   * @internal\n   */\n  public isActive = false;\n\n  /**\n   * Used by unit tests to disable animations since the component is injected at the bottom of the\n   * document body.\n   * @internal\n   */\n  public enableAnimations = true;\n\n  public isMouseEnter = false;\n\n  @ViewChild('templateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public templateRef: TemplateRef<unknown> | undefined;\n\n  #contentRef!: SkyPopoverContentComponent;\n\n  #isMarkedForCloseOnMouseLeave = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #_alignment: SkyPopoverAlignment = 'center';\n\n  #_dismissOnBlur = true;\n\n  #_placement: SkyPopoverPlacement = 'above';\n\n  #_popoverType: SkyPopoverType = 'info';\n\n  #overlayService: SkyOverlayService;\n\n  #zIndex: Observable<number> | undefined;\n\n  constructor(\n    overlayService: SkyOverlayService,\n    @Optional()\n    @Inject(SKY_STACKING_CONTEXT)\n    stackingContext?: SkyStackingContext\n  ) {\n    this.#overlayService = overlayService;\n    this.#zIndex = stackingContext?.zIndex;\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  /**\n   * Positions the popover next to a given caller element.\n   * @param caller The element that opened the popover.\n   * @param placement The placement of the popover.\n   * @param alignment The horizontal alignment of the popover.\n   * @internal\n   */\n  public positionNextTo(\n    caller: ElementRef,\n    placement?: SkyPopoverPlacement,\n    alignment?: SkyPopoverAlignment\n  ): void {\n    if (!this.#overlay) {\n      this.#setupOverlay();\n    }\n\n    this.placement = placement ?? this.placement;\n    this.alignment = alignment ?? this.alignment;\n    this.isActive = true;\n\n    this.#contentRef.open(caller, {\n      dismissOnBlur: this.dismissOnBlur,\n      enableAnimations: this.enableAnimations,\n      horizontalAlignment: this.alignment,\n      isStatic: false,\n      placement: this.placement,\n      popoverTitle: this.popoverTitle,\n      popoverType: this.popoverType,\n    });\n  }\n\n  /**\n   * Closes the popover.\n   * @internal\n   */\n  public close(): void {\n    /*istanbul ignore next*/\n    this.#contentRef?.close();\n  }\n\n  /**\n   * Brings focus to the popover element if its open.\n   * @internal\n   */\n  public applyFocus(): void {\n    /*istanbul ignore next*/\n    this.#contentRef?.applyFocus();\n  }\n\n  /**\n   * Adds a flag to the popover to close when the mouse leaves the popover's bounds.\n   * @internal\n   */\n  public markForCloseOnMouseLeave(): void {\n    this.#isMarkedForCloseOnMouseLeave = true;\n  }\n\n  #setupOverlay(): void {\n    if (this.templateRef) {\n      const overlay = this.#overlayService.create({\n        enableScroll: true,\n        enablePointerEvents: true,\n      });\n\n      if (this.#zIndex) {\n        this.#zIndex\n          .pipe(takeUntil(this.#ngUnsubscribe))\n          .subscribe((zIndex) => {\n            overlay.componentRef.instance.zIndex = zIndex.toString(10);\n          });\n      }\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          if (this.dismissOnBlur) {\n            this.close();\n          }\n        });\n\n      const contentRef = overlay.attachComponent(SkyPopoverContentComponent, [\n        {\n          provide: SkyPopoverContext,\n          useValue: new SkyPopoverContext({\n            contentTemplateRef: this.templateRef,\n          }),\n        },\n      ]);\n\n      contentRef.opened.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n        this.popoverOpened.emit(this);\n      });\n\n      contentRef.closed.pipe(takeUntil(this.#ngUnsubscribe)).subscribe(() => {\n        /*istanbul ignore else*/\n        if (this.isActive && this.#overlay) {\n          this.#overlayService.close(this.#overlay);\n          this.#overlay = undefined;\n          this.isActive = false;\n          this.popoverClosed.emit(this);\n        }\n      });\n\n      contentRef.isMouseEnter\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((isMouseEnter) => {\n          this.isMouseEnter = isMouseEnter;\n          if (this.#isMarkedForCloseOnMouseLeave) {\n            this.#isMarkedForCloseOnMouseLeave = false;\n            this.close();\n          }\n        });\n\n      this.#overlay = overlay;\n      this.#contentRef = contentRef;\n    }\n  }\n}\n","<ng-template #templateRef>\n  <ng-content></ng-content>\n</ng-template>\n"]}
|