@nova-ui/bits
Version:
SolarWinds Nova Framework
92 lines • 20 kB
JavaScript
import { ChangeDetectorRef, Component, ElementRef, HostListener, Input, NgZone, TemplateRef, } from "@angular/core";
import _isBoolean from "lodash/isBoolean";
import { Subject } from "rxjs";
import { take } from "rxjs/operators";
import { fadeIn } from "../../animations/fadeIn";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../icon/icon.component";
import * as i3 from "../overlay/arrow-component/overlay-arrow.component";
/**
* @ignore
*/
export class PopoverModalComponent {
onClick(event) {
event.stopPropagation();
}
onMouseEnter() {
this.popoverModalEventSubject.next("mouse-enter");
}
onMouseLeave() {
this.popoverModalEventSubject.next("mouse-leave");
}
constructor(elRef, zone, cdRef) {
this.elRef = elRef;
this.zone = zone;
this.cdRef = cdRef;
this.placement = "right";
this.fadeIn = false;
this.popoverModalSubscriptions = [];
}
ngOnInit() {
const displayChangeSubscription = this.displayChange.subscribe((show) => {
if (!show) {
this.popoverBeforeHiddenSubject.next();
this.fadeIn = false;
this.cdRef.markForCheck();
}
});
this.popoverModalSubscriptions.push(displayChangeSubscription);
}
ngAfterViewInit() {
// To prevent from exception 'expression was changed after check'
const zoneSubscription = this.zone.onStable
.asObservable()
.pipe(take(1))
.subscribe(() => {
// To be sure, that change detection mechanism was invoked and placement was updated
this.zone.run(() => (this.fadeIn = true));
});
this.popoverModalSubscriptions.push(zoneSubscription);
}
onAnimationEnd(event) {
if (_isBoolean(event.fromState) && event.fromState) {
this.popoverAfterHiddenSubject.next();
}
}
ngOnDestroy() {
this.popoverModalSubscriptions.forEach((sub) => {
sub.unsubscribe();
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopoverModalComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopoverModalComponent, selector: "nui-popover-modal", inputs: { backdrop: "backdrop", context: "context", template: "template", displayChange: "displayChange", hostElement: "hostElement", hasPadding: "hasPadding", unlimited: "unlimited" }, host: { attributes: { "role": "dialog" }, listeners: { "click": "onClick($event)", "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, ngImport: i0, template: "<div\n class=\"nui-popover-container-animation fade\"\n [@fadeIn]=\"fadeIn\"\n (@fadeIn.done)=\"onAnimationEnd($event)\"\n>\n <div\n class=\"nui-popover-container\"\n [ngClass]=\"['nui-popover-container--' + placement]\"\n [class.unlimited]=\"unlimited\"\n >\n <div class=\"nui-popover-container__arrow arrow\"></div>\n <div class=\"nui-popover-container__frame\">\n <div\n *ngIf=\"context.icon || context.title\"\n class=\"nui-popover-container__header\"\n [class.nui-popover-container__header--with-border]=\"\n context.title\n \"\n >\n <div class=\"nui-popover-container__icon\" *ngIf=\"context.icon\">\n <nui-icon [icon]=\"context.icon\"></nui-icon>\n </div>\n <div\n *ngIf=\"context.title\"\n class=\"nui-popover-container__title\"\n [class.nui-popover-container__title--with-icon]=\"\n context.icon\n \"\n title=\"{{ context.title }}\"\n >\n <span>{{ context.title }}</span>\n </div>\n </div>\n <div\n class=\"nui-popover-container__content\"\n [class.noPadding]=\"!hasPadding\"\n >\n <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n </div>\n </div>\n </div>\n <nui-overlay-arrow></nui-overlay-arrow>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "component", type: i3.OverlayArrowComponent, selector: "nui-overlay-arrow" }], animations: [fadeIn] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopoverModalComponent, decorators: [{
type: Component,
args: [{ selector: "nui-popover-modal", animations: [fadeIn], host: { role: "dialog" }, template: "<div\n class=\"nui-popover-container-animation fade\"\n [@fadeIn]=\"fadeIn\"\n (@fadeIn.done)=\"onAnimationEnd($event)\"\n>\n <div\n class=\"nui-popover-container\"\n [ngClass]=\"['nui-popover-container--' + placement]\"\n [class.unlimited]=\"unlimited\"\n >\n <div class=\"nui-popover-container__arrow arrow\"></div>\n <div class=\"nui-popover-container__frame\">\n <div\n *ngIf=\"context.icon || context.title\"\n class=\"nui-popover-container__header\"\n [class.nui-popover-container__header--with-border]=\"\n context.title\n \"\n >\n <div class=\"nui-popover-container__icon\" *ngIf=\"context.icon\">\n <nui-icon [icon]=\"context.icon\"></nui-icon>\n </div>\n <div\n *ngIf=\"context.title\"\n class=\"nui-popover-container__title\"\n [class.nui-popover-container__title--with-icon]=\"\n context.icon\n \"\n title=\"{{ context.title }}\"\n >\n <span>{{ context.title }}</span>\n </div>\n </div>\n <div\n class=\"nui-popover-container__content\"\n [class.noPadding]=\"!hasPadding\"\n >\n <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n </div>\n </div>\n </div>\n <nui-overlay-arrow></nui-overlay-arrow>\n</div>\n" }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }], propDecorators: { backdrop: [{
type: Input
}], context: [{
type: Input
}], template: [{
type: Input
}], displayChange: [{
type: Input
}], hostElement: [{
type: Input
}], hasPadding: [{
type: Input
}], unlimited: [{
type: Input
}], onClick: [{
type: HostListener,
args: ["click", ["$event"]]
}], onMouseEnter: [{
type: HostListener,
args: ["mouseenter"]
}], onMouseLeave: [{
type: HostListener,
args: ["mouseleave"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-modal.component.js","sourceRoot":"","sources":["../../../../src/lib/popover/popover-modal.component.ts","../../../../src/lib/popover/popover-modal.component.html"],"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 { AnimationEvent } from \"@angular/animations\";\nimport {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostListener,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    TemplateRef,\n} from \"@angular/core\";\nimport _isBoolean from \"lodash/isBoolean\";\nimport { Subject, Subscription } from \"rxjs\";\nimport { take } from \"rxjs/operators\";\n\nimport { IPopoverModalContext } from \"./popover-modal.service\";\nimport { PopoverPlacement } from \"./public-api\";\nimport { fadeIn } from \"../../animations/fadeIn\";\n\n/**\n * @ignore\n */\nexport type PopoverModalEvents =\n    | \"mouse-enter\"\n    | \"mouse-leave\"\n    | \"backdrop-click\"\n    | \"outside-click\";\n\n/**\n * @ignore\n */\n@Component({\n    selector: \"nui-popover-modal\",\n    templateUrl: \"./popover-modal.component.html\",\n    animations: [fadeIn],\n    host: { role: \"dialog\" },\n})\nexport class PopoverModalComponent implements AfterViewInit, OnInit, OnDestroy {\n    /**\n     * Is backdrop used\n     */\n    @Input() backdrop: boolean;\n\n    /**\n     * Defines settings for popover\n     */\n    @Input() context: IPopoverModalContext;\n\n    /**\n     * Defines popover content\n     */\n    @Input() template: TemplateRef<string>;\n\n    /**\n     * Updates fadeIn property\n     */\n    @Input() displayChange: Subject<boolean>;\n\n    /**\n     * Popover hostElement\n     */\n    @Input() hostElement: any;\n\n    /**\n     * Defines if container has padding.\n     */\n    @Input() hasPadding: boolean;\n\n    /**\n     * Specifies whether the default width and height constraints are in effect for the popover\n     */\n    @Input() unlimited: boolean;\n\n    public placement: PopoverPlacement = \"right\";\n    public fadeIn = false;\n    public popoverBeforeHiddenSubject: Subject<void>;\n    public popoverAfterHiddenSubject: Subject<void>;\n    public popoverModalEventSubject: Subject<PopoverModalEvents>;\n\n    private popoverModalSubscriptions: Subscription[] = [];\n\n    @HostListener(\"click\", [\"$event\"])\n    onClick(event: MouseEvent): void {\n        event.stopPropagation();\n    }\n\n    @HostListener(\"mouseenter\")\n    onMouseEnter(): void {\n        this.popoverModalEventSubject.next(\"mouse-enter\");\n    }\n\n    @HostListener(\"mouseleave\")\n    onMouseLeave(): void {\n        this.popoverModalEventSubject.next(\"mouse-leave\");\n    }\n\n    constructor(\n        public elRef: ElementRef,\n        private zone: NgZone,\n        private cdRef: ChangeDetectorRef\n    ) {}\n\n    public ngOnInit(): void {\n        const displayChangeSubscription = this.displayChange.subscribe(\n            (show: boolean) => {\n                if (!show) {\n                    this.popoverBeforeHiddenSubject.next();\n                    this.fadeIn = false;\n                    this.cdRef.markForCheck();\n                }\n            }\n        );\n\n        this.popoverModalSubscriptions.push(displayChangeSubscription);\n    }\n\n    public ngAfterViewInit(): void {\n        // To prevent from exception 'expression was changed after check'\n        const zoneSubscription = this.zone.onStable\n            .asObservable()\n            .pipe(take(1))\n            .subscribe(() => {\n                // To be sure, that change detection mechanism was invoked and placement was updated\n                this.zone.run(() => (this.fadeIn = true));\n            });\n        this.popoverModalSubscriptions.push(zoneSubscription);\n    }\n\n    public onAnimationEnd(event: AnimationEvent): void {\n        if (_isBoolean(event.fromState) && event.fromState) {\n            this.popoverAfterHiddenSubject.next();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.popoverModalSubscriptions.forEach((sub) => {\n            sub.unsubscribe();\n        });\n    }\n}\n","<div\n    class=\"nui-popover-container-animation fade\"\n    [@fadeIn]=\"fadeIn\"\n    (@fadeIn.done)=\"onAnimationEnd($event)\"\n>\n    <div\n        class=\"nui-popover-container\"\n        [ngClass]=\"['nui-popover-container--' + placement]\"\n        [class.unlimited]=\"unlimited\"\n    >\n        <div class=\"nui-popover-container__arrow arrow\"></div>\n        <div class=\"nui-popover-container__frame\">\n            <div\n                *ngIf=\"context.icon || context.title\"\n                class=\"nui-popover-container__header\"\n                [class.nui-popover-container__header--with-border]=\"\n                    context.title\n                \"\n            >\n                <div class=\"nui-popover-container__icon\" *ngIf=\"context.icon\">\n                    <nui-icon [icon]=\"context.icon\"></nui-icon>\n                </div>\n                <div\n                    *ngIf=\"context.title\"\n                    class=\"nui-popover-container__title\"\n                    [class.nui-popover-container__title--with-icon]=\"\n                        context.icon\n                    \"\n                    title=\"{{ context.title }}\"\n                >\n                    <span>{{ context.title }}</span>\n                </div>\n            </div>\n            <div\n                class=\"nui-popover-container__content\"\n                [class.noPadding]=\"!hasPadding\"\n            >\n                <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n            </div>\n        </div>\n    </div>\n    <nui-overlay-arrow></nui-overlay-arrow>\n</div>\n"]}