UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

294 lines 44.9 kB
// © 2022 SolarWinds Worldwide, LLC. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. import { ApplicationRef, ChangeDetectorRef, Component, ComponentFactoryResolver, ContentChild, ElementRef, EventEmitter, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation, } from "@angular/core"; import _isUndefined from "lodash/isUndefined"; import { filter, Subject } from "rxjs"; import { PopupContainerComponent } from "./popup-container.component"; import { PopupContainerService } from "./popup-container.service"; import { PopupToggleDirective } from "./popup-toggle.directive"; import { DOCUMENT_CLICK_EVENT } from "../../constants/event.constants"; import { EdgeDetectionService } from "../../services/edge-detection.service"; import { EventBusService } from "../../services/event-bus.service"; import { LoggerService } from "../../services/log-service"; import * as i0 from "@angular/core"; import * as i1 from "../../services/edge-detection.service"; import * as i2 from "../../services/event-bus.service"; import * as i3 from "../../services/log-service"; import * as i4 from "./popup-container.service"; import * as i5 from "../../common/directives/click-interceptor/click-interceptor.directive"; const isMouseEvent = (event) => event instanceof MouseEvent; // <example-url>./../examples/index.html#/popup</example-url> /** * @deprecated in v11 - Use PopupComponent instead - Removal: NUI-5796 */ /** * __Name :__ * NUI Pop-up component. * * __Usage :__ * Component represents basic functionality for dropdowns, popups, etc. * May be used directly. Use "nuiPopupToggle" attribute inside any layer of content * to define element that will toggle popover. Use "popupAreaContent" attribute inside * 1st layer of content to define "popup area". DO NOT USE "opened" WITH "nuiPopupToggle". * IT IS NEEDED TO CHOOSE ONE. */ export class PopupDeprecatedComponent { get popupInstance() { return this._popupInstance; } constructor(elementRef, edgeDetector, changeDetectorRef, eventBusService, componentFactoryResolver, injector, appRef, logger, popupContainer) { this.elementRef = elementRef; this.edgeDetector = edgeDetector; this.changeDetectorRef = changeDetectorRef; this.eventBusService = eventBusService; this.componentFactoryResolver = componentFactoryResolver; this.injector = injector; this.appRef = appRef; this.logger = logger; this.popupContainer = popupContainer; this.isOpen = false; this.ariaLabel = "Popup"; this.opened = new EventEmitter(); this.popupSubscriptions = []; /** * switches visibility of popup area */ this.visible = false; this.logger.warn("<nui-popup-deprecated> is deprecated as of Nova v11. Please use <nui-popup> instead."); } ngOnInit() { if (this.manualOpenControl) { this.popupSubscriptions.push(this.manualOpenControl.subscribe((event) => { this.toggleOpened(event); })); } this.popupSubscriptions.push(this.eventBusService .getStream(DOCUMENT_CLICK_EVENT) .pipe(filter(isMouseEvent)) .subscribe((event) => { if (this.isOpen) { this.closePopup(event); } })); // This is needed to make the isOpen @Input work. this.visible = this.isOpen; } ngAfterContentInit() { this.setPopupPosition(); if (!this.popupToggle) { return; } this.popupSubscriptions.push(this.popupToggle.toggle.subscribe((event) => { this.toggleOpened(event); })); } toggleOpened(event) { this.visible = false; let emit = true; if (event) { // since click triggers focusin event, we need to prevent popup from closing // when focus on the input is gained via click if (this.lastEventType === "focusin" && event.type === "click") { emit = false; } // if popup is already closed, prevent it from opening on focusout if (event.type === "focusout" && !this.isOpen) { emit = false; } this.lastEventType = event.type; } if (emit) { this.isOpen = !this.isOpen; this.changeDetectorRef.detectChanges(); this.changeDetectorRef.detach(); if (this.isOpen) { if (!this._popupInstance && this.appendToBody) { const popupContainerFactory = this.componentFactoryResolver.resolveComponentFactory(PopupContainerComponent); this._popupInstance = popupContainerFactory.create(this.injector, [[this.popupAreaContent.nativeElement]]); this._popupInstance.instance.hostElement = this.popupToggle.host.nativeElement; this.appRef.attachView(this._popupInstance.hostView); const hostElement = this._popupInstance.hostView.rootNodes[0]; if (this.popupContainer?.parent) { hostElement.setAttribute("parent", this.popupContainer.parent.constructor.name); } document.body.appendChild(hostElement); } else { this.setPopupPosition(); } this.visible = true; this.changeDetectorRef.detectChanges(); this.changeDetectorRef.detach(); // If closed, remove popup instance from DOM if there's one } else if (this._popupInstance && this.appendToBody) { this.deletePopupInstance(); } this.opened.emit(this.isOpen); } } closePopup(event) { const isToggle = this.popupToggle && event ? this.popupToggle.host.nativeElement.contains(event.target) : false; if (!isToggle) { this.deletePopupInstance(); this.isOpen = false; this.visible = false; this.opened.emit(this.isOpen); this.changeDetectorRef.detectChanges(); this.changeDetectorRef.detach(); } } setPopupPosition() { let parentEl; if (!this.baseElementSelector && !this.popupToggle) { return; } if (this.popupToggle) { parentEl = this.popupToggle.host.nativeElement; } else { parentEl = document.querySelector(this.baseElementSelector) ?? undefined; } if (!parentEl) { return; } const canBe = this.edgeDetector.canBe(parentEl, this.popupAreaContent.nativeElement); this._directionTop = _isUndefined(this.directionTop) ? !canBe?.placed.bottom : this.directionTop; this._directionRight = _isUndefined(this.directionRight) ? !canBe?.aligned.left : this.directionRight; } deletePopupInstance() { if (this._popupInstance) { this.appRef.detachView(this._popupInstance.hostView); this._popupInstance.destroy(); this._popupInstance = undefined; } } ngOnDestroy() { this.popupSubscriptions.forEach((subscription) => subscription.unsubscribe()); this.deletePopupInstance(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupDeprecatedComponent, deps: [{ token: i0.ElementRef }, { token: i1.EdgeDetectionService }, { token: i0.ChangeDetectorRef }, { token: i2.EventBusService }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i0.ApplicationRef }, { token: i3.LoggerService }, { token: i4.PopupContainerService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopupDeprecatedComponent, selector: "nui-popup-deprecated", inputs: { width: "width", contextClass: "contextClass", appendToBody: "appendToBody", isOpen: "isOpen", manualOpenControl: "manualOpenControl", directionTop: "directionTop", directionRight: "directionRight", baseElementSelector: "baseElementSelector", ariaLabel: "ariaLabel" }, outputs: { opened: "opened" }, host: { attributes: { "role": "dialog" }, properties: { "attr.aria-label": "ariaLabel" }, classAttribute: "nui-popup" }, queries: [{ propertyName: "popupToggle", first: true, predicate: PopupToggleDirective, descendants: true }], viewQueries: [{ propertyName: "popupAreaContainer", first: true, predicate: ["popupAreaContainer"], descendants: true }, { propertyName: "popupAreaContent", first: true, predicate: ["popupArea"], descendants: true, static: true }], ngImport: i0, template: ` <div class="nui-popup-container" [class.nui-popup--opened]="isOpen" nuiClickInterceptor > <div class="nui-popup__content"> <ng-content></ng-content> </div> <div #popupArea class="nui-popup__area {{ contextClass }}" [style.width]="width" [class.nui-popup__area--visible]="visible" [class.nui-popup__area--top]="_directionTop && !appendToBody" [class.nui-popup__area--right]=" _directionRight && !appendToBody " > <div #popupAreaContainer tabindex="-1" class="nui-popup__area--container" > <ng-content select="[popupAreaContent]"></ng-content> </div> </div> </div> `, isInline: true, styles: [".nui-menu-popup-host.nui-popup__area{min-width:150px;max-width:450px;max-height:300px}.nui-menu-popup-host.nui-popup__area .nui-popup__area--container{overflow-x:hidden;overflow-y:auto;max-height:290px;margin:5px 0}.nui-select-popup-host.nui-popup__area{width:auto}.nui-select-popup-host.nui-popup__area .nui-menu-item .nui-menu-item__action{color:var(--nui-color-text-default,#111)}.nui-select-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111);font-weight:600}.nui-select-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui-select-popup-host.nui-select--justified.nui-popup__area{max-width:none}.nui-select-popup-host.nui-select--justified .nui-popup__content .menu-button{display:flex;flex-grow:1;max-width:none}.nui-combobox-popup-host.nui-popup__area .nui-menu-item .nui-menu-item__action{color:var(--nui-color-text-default,#111)}.nui-combobox-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111);font-weight:600}.nui-combobox-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui-combobox-popup-host .nui-combobox__menu{max-height:300px;overflow-y:auto;max-width:400px}.nui-combobox-popup-host.nui-combobox--justified .nui-combobox__menu{max-width:none}.nui-selector-append-to-body-host.nui-popup__area{left:-35px;min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-append-to-body-host.nui-popup__area .nui-repeat .nui-repeat-item{border:0}.nui-selector-host.nui-popup__area{min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-host.nui-popup__area .nui-repeat .nui-repeat-item{border:0}.nui-selector-popup-area{min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-popup-area .nui-repeat .nui-repeat-item{border:0}.nui-popup{display:inline-flex;position:relative;font-size:13px;line-height:1.66666667;border-radius:0}.nui-popup-container{pointer-events:all;flex-direction:column}.nui-popup-container.nui-popup--opened .nui-popup__area{display:block}.nui-popup-container.nui-popup--opened .nui-popup__area.nui-popup__area--visible{visibility:visible}.nui-popup__content{display:inline-flex;flex-direction:row}.nui-popup--detached{position:absolute}.nui-popup__area{display:none;visibility:hidden;position:absolute;top:100%;margin:0;z-index:1050;box-shadow:var(--nui-shadow-default,0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3)));background-color:var(--nui-color-bg-content_popover,#fff)}.nui-popup__area.nui-popup__area--top{top:0;transform:translateY(-100%)}.nui-popup__area.nui-popup__area--right{right:0;left:auto}.nui-popup:not(.nui-popup--opened){background:none}\n"], dependencies: [{ kind: "directive", type: i5.ClickInterceptorDirective, selector: "[nuiClickInterceptor]" }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupDeprecatedComponent, decorators: [{ type: Component, args: [{ selector: "nui-popup-deprecated", host: { class: "nui-popup", role: "dialog", "[attr.aria-label]": "ariaLabel", }, template: ` <div class="nui-popup-container" [class.nui-popup--opened]="isOpen" nuiClickInterceptor > <div class="nui-popup__content"> <ng-content></ng-content> </div> <div #popupArea class="nui-popup__area {{ contextClass }}" [style.width]="width" [class.nui-popup__area--visible]="visible" [class.nui-popup__area--top]="_directionTop && !appendToBody" [class.nui-popup__area--right]=" _directionRight && !appendToBody " > <div #popupAreaContainer tabindex="-1" class="nui-popup__area--container" > <ng-content select="[popupAreaContent]"></ng-content> </div> </div> </div> `, encapsulation: ViewEncapsulation.None, styles: [".nui-menu-popup-host.nui-popup__area{min-width:150px;max-width:450px;max-height:300px}.nui-menu-popup-host.nui-popup__area .nui-popup__area--container{overflow-x:hidden;overflow-y:auto;max-height:290px;margin:5px 0}.nui-select-popup-host.nui-popup__area{width:auto}.nui-select-popup-host.nui-popup__area .nui-menu-item .nui-menu-item__action{color:var(--nui-color-text-default,#111)}.nui-select-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111);font-weight:600}.nui-select-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui-select-popup-host.nui-select--justified.nui-popup__area{max-width:none}.nui-select-popup-host.nui-select--justified .nui-popup__content .menu-button{display:flex;flex-grow:1;max-width:none}.nui-combobox-popup-host.nui-popup__area .nui-menu-item .nui-menu-item__action{color:var(--nui-color-text-default,#111)}.nui-combobox-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111);font-weight:600}.nui-combobox-popup-host.nui-popup__area .nui-menu-item.item-selected .nui-menu-item__action:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui-combobox-popup-host .nui-combobox__menu{max-height:300px;overflow-y:auto;max-width:400px}.nui-combobox-popup-host.nui-combobox--justified .nui-combobox__menu{max-width:none}.nui-selector-append-to-body-host.nui-popup__area{left:-35px;min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-append-to-body-host.nui-popup__area .nui-repeat .nui-repeat-item{border:0}.nui-selector-host.nui-popup__area{min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-host.nui-popup__area .nui-repeat .nui-repeat-item{border:0}.nui-selector-popup-area{min-width:100px;border:none;color:var(--nui-color-text-link,#0079aa)}.nui-selector-popup-area .nui-repeat .nui-repeat-item{border:0}.nui-popup{display:inline-flex;position:relative;font-size:13px;line-height:1.66666667;border-radius:0}.nui-popup-container{pointer-events:all;flex-direction:column}.nui-popup-container.nui-popup--opened .nui-popup__area{display:block}.nui-popup-container.nui-popup--opened .nui-popup__area.nui-popup__area--visible{visibility:visible}.nui-popup__content{display:inline-flex;flex-direction:row}.nui-popup--detached{position:absolute}.nui-popup__area{display:none;visibility:hidden;position:absolute;top:100%;margin:0;z-index:1050;box-shadow:var(--nui-shadow-default,0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3)));background-color:var(--nui-color-bg-content_popover,#fff)}.nui-popup__area.nui-popup__area--top{top:0;transform:translateY(-100%)}.nui-popup__area.nui-popup__area--right{right:0;left:auto}.nui-popup:not(.nui-popup--opened){background:none}\n"] }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.EdgeDetectionService }, { type: i0.ChangeDetectorRef }, { type: i2.EventBusService }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i0.ApplicationRef }, { type: i3.LoggerService }, { type: i4.PopupContainerService, decorators: [{ type: Optional }] }], propDecorators: { width: [{ type: Input }], contextClass: [{ type: Input }], appendToBody: [{ type: Input }], isOpen: [{ type: Input }], manualOpenControl: [{ type: Input }], directionTop: [{ type: Input }], directionRight: [{ type: Input }], baseElementSelector: [{ type: Input }], ariaLabel: [{ type: Input }], opened: [{ type: Output }], popupToggle: [{ type: ContentChild, args: [PopupToggleDirective] }], popupAreaContainer: [{ type: ViewChild, args: ["popupAreaContainer"] }], popupAreaContent: [{ type: ViewChild, args: ["popupArea", { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popup.component.js","sourceRoot":"","sources":["../../../../src/lib/popup/popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport {\n    AfterContentInit,\n    ApplicationRef,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ContentChild,\n    ElementRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport _isUndefined from \"lodash/isUndefined\";\nimport { filter, Subject, Subscription } from \"rxjs\";\n\nimport { PopupContainerComponent } from \"./popup-container.component\";\nimport { PopupContainerService } from \"./popup-container.service\";\nimport { PopupToggleDirective } from \"./popup-toggle.directive\";\nimport { DOCUMENT_CLICK_EVENT } from \"../../constants/event.constants\";\nimport { EdgeDetectionService } from \"../../services/edge-detection.service\";\nimport { EventBusService } from \"../../services/event-bus.service\";\nimport { LoggerService } from \"../../services/log-service\";\n\nconst isMouseEvent = (event: Event): event is MouseEvent =>\n    event instanceof MouseEvent;\n\n// <example-url>./../examples/index.html#/popup</example-url>\n/**\n * @deprecated in v11 - Use PopupComponent instead - Removal: NUI-5796\n */\n/**\n * __Name :__\n * NUI Pop-up component.\n *\n * __Usage :__\n * Component represents basic functionality for dropdowns, popups, etc.\n * May be used directly. Use \"nuiPopupToggle\" attribute inside any layer of content\n * to define element that will toggle popover. Use \"popupAreaContent\" attribute inside\n * 1st layer of content to define \"popup area\". DO NOT USE \"opened\" WITH \"nuiPopupToggle\".\n * IT IS NEEDED TO CHOOSE ONE.\n */\n@Component({\n    selector: \"nui-popup-deprecated\",\n    host: {\n        class: \"nui-popup\",\n        role: \"dialog\",\n        \"[attr.aria-label]\": \"ariaLabel\",\n    },\n    template: `\n        <div\n            class=\"nui-popup-container\"\n            [class.nui-popup--opened]=\"isOpen\"\n            nuiClickInterceptor\n        >\n            <div class=\"nui-popup__content\">\n                <ng-content></ng-content>\n            </div>\n            <div\n                #popupArea\n                class=\"nui-popup__area {{ contextClass }}\"\n                [style.width]=\"width\"\n                [class.nui-popup__area--visible]=\"visible\"\n                [class.nui-popup__area--top]=\"_directionTop && !appendToBody\"\n                [class.nui-popup__area--right]=\"\n                    _directionRight && !appendToBody\n                \"\n            >\n                <div\n                    #popupAreaContainer\n                    tabindex=\"-1\"\n                    class=\"nui-popup__area--container\"\n                >\n                    <ng-content select=\"[popupAreaContent]\"></ng-content>\n                </div>\n            </div>\n        </div>\n    `,\n    styleUrls: [\"./popup.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class PopupDeprecatedComponent\n    implements AfterContentInit, OnDestroy, OnInit\n{\n    @Input() width: string;\n    /**\n     * If additional styles should be applied to popup\n     */\n    @Input() contextClass: string;\n    /**\n     * Allows popup box to be attached to document.body\n     */\n    @Input()\n    public appendToBody: boolean;\n    @Input()\n    public isOpen = false;\n    @Input()\n    public manualOpenControl: Subject<MouseEvent>;\n    /**\n     * Defines in which direction popup area will be opened.\n     */\n    @Input()\n    public directionTop: boolean;\n    /**\n     * Parent css element class used determining of popup direction to top.\n     */\n    @Input()\n    public directionRight: boolean;\n    /**\n     * Parent css element class used determining of popup direction to right.\n     */\n    @Input()\n    public baseElementSelector: string;\n\n    @Input()\n    public ariaLabel: string = \"Popup\";\n\n    @Output()\n    public opened = new EventEmitter<boolean>();\n\n    @ContentChild(PopupToggleDirective)\n    public popupToggle: PopupToggleDirective;\n    @ViewChild(\"popupAreaContainer\")\n    public popupAreaContainer: ElementRef;\n\n    @ViewChild(\"popupArea\", { static: true })\n    public popupAreaContent: ElementRef;\n\n    private popupSubscriptions: Subscription[] = [];\n    private lastEventType: string;\n    private _popupInstance?: ComponentRef<PopupContainerComponent>;\n\n    public get popupInstance():\n        | ComponentRef<PopupContainerComponent>\n        | undefined {\n        return this._popupInstance;\n    }\n    /** @ignore */\n    public _directionRight: boolean;\n    /** @ignore */\n    public _directionTop: boolean;\n    /**\n     * switches visibility of popup area\n     */\n    public visible = false;\n\n    constructor(\n        private elementRef: ElementRef,\n        private edgeDetector: EdgeDetectionService,\n        private changeDetectorRef: ChangeDetectorRef,\n        private eventBusService: EventBusService,\n        private componentFactoryResolver: ComponentFactoryResolver,\n        private injector: Injector,\n        private appRef: ApplicationRef,\n        private logger: LoggerService,\n        @Optional() private popupContainer: PopupContainerService\n    ) {\n        this.logger.warn(\n            \"<nui-popup-deprecated> is deprecated as of Nova v11. Please use <nui-popup> instead.\"\n        );\n    }\n\n    public ngOnInit(): void {\n        if (this.manualOpenControl) {\n            this.popupSubscriptions.push(\n                this.manualOpenControl.subscribe((event) => {\n                    this.toggleOpened(event);\n                })\n            );\n        }\n        this.popupSubscriptions.push(\n            this.eventBusService\n                .getStream(DOCUMENT_CLICK_EVENT)\n                .pipe(filter(isMouseEvent))\n                .subscribe((event: MouseEvent) => {\n                    if (this.isOpen) {\n                        this.closePopup(event);\n                    }\n                })\n        );\n\n        // This is needed to make the isOpen @Input work.\n        this.visible = this.isOpen;\n    }\n\n    public ngAfterContentInit(): void {\n        this.setPopupPosition();\n\n        if (!this.popupToggle) {\n            return;\n        }\n\n        this.popupSubscriptions.push(\n            this.popupToggle.toggle.subscribe((event: Event) => {\n                this.toggleOpened(event);\n            })\n        );\n    }\n\n    public toggleOpened(event: Event): void {\n        this.visible = false;\n        let emit = true;\n        if (event) {\n            // since click triggers focusin event, we need to prevent popup from closing\n            // when focus on the input is gained via click\n            if (this.lastEventType === \"focusin\" && event.type === \"click\") {\n                emit = false;\n            }\n\n            // if popup is already closed, prevent it from opening on focusout\n            if (event.type === \"focusout\" && !this.isOpen) {\n                emit = false;\n            }\n\n            this.lastEventType = event.type;\n        }\n        if (emit) {\n            this.isOpen = !this.isOpen;\n            this.changeDetectorRef.detectChanges();\n            this.changeDetectorRef.detach();\n            if (this.isOpen) {\n                if (!this._popupInstance && this.appendToBody) {\n                    const popupContainerFactory =\n                        this.componentFactoryResolver.resolveComponentFactory(\n                            PopupContainerComponent\n                        );\n                    this._popupInstance = popupContainerFactory.create(\n                        this.injector,\n                        [[this.popupAreaContent.nativeElement]]\n                    );\n                    this._popupInstance.instance.hostElement =\n                        this.popupToggle.host.nativeElement;\n                    this.appRef.attachView(this._popupInstance.hostView);\n                    const hostElement = (\n                        this._popupInstance.hostView as EmbeddedViewRef<any>\n                    ).rootNodes[0] as HTMLElement;\n                    if (this.popupContainer?.parent) {\n                        hostElement.setAttribute(\n                            \"parent\",\n                            this.popupContainer.parent.constructor.name\n                        );\n                    }\n                    document.body.appendChild(hostElement);\n                } else {\n                    this.setPopupPosition();\n                }\n\n                this.visible = true;\n                this.changeDetectorRef.detectChanges();\n                this.changeDetectorRef.detach();\n                // If closed, remove popup instance from DOM if there's one\n            } else if (this._popupInstance && this.appendToBody) {\n                this.deletePopupInstance();\n            }\n\n            this.opened.emit(this.isOpen);\n        }\n    }\n\n    public closePopup(event?: MouseEvent): void {\n        const isToggle =\n            this.popupToggle && event\n                ? (this.popupToggle.host.nativeElement as HTMLElement).contains(\n                      event.target as HTMLElement\n                  )\n                : false;\n\n        if (!isToggle) {\n            this.deletePopupInstance();\n            this.isOpen = false;\n            this.visible = false;\n            this.opened.emit(this.isOpen);\n            this.changeDetectorRef.detectChanges();\n            this.changeDetectorRef.detach();\n        }\n    }\n\n    private setPopupPosition() {\n        let parentEl: HTMLElement | undefined;\n        if (!this.baseElementSelector && !this.popupToggle) {\n            return;\n        }\n\n        if (this.popupToggle) {\n            parentEl = this.popupToggle.host.nativeElement;\n        } else {\n            parentEl =\n                document.querySelector<HTMLElement>(this.baseElementSelector) ??\n                undefined;\n        }\n\n        if (!parentEl) {\n            return;\n        }\n\n        const canBe = this.edgeDetector.canBe(\n            <HTMLElement>parentEl,\n            this.popupAreaContent.nativeElement\n        );\n        this._directionTop = _isUndefined(this.directionTop)\n            ? !canBe?.placed.bottom\n            : this.directionTop;\n        this._directionRight = _isUndefined(this.directionRight)\n            ? !canBe?.aligned.left\n            : this.directionRight;\n    }\n\n    private deletePopupInstance() {\n        if (this._popupInstance) {\n            this.appRef.detachView(this._popupInstance.hostView);\n            this._popupInstance.destroy();\n            this._popupInstance = undefined;\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.popupSubscriptions.forEach((subscription) =>\n            subscription.unsubscribe()\n        );\n        this.deletePopupInstance();\n    }\n}\n"]}