@nova-ui/bits
Version:
SolarWinds Nova Framework
156 lines • 28.2 kB
JavaScript
// © 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 { CdkScrollable, ScrollDispatcher } from "@angular/cdk/scrolling";
import { DOCUMENT } from "@angular/common";
import { Component, ElementRef, EventEmitter, HostListener, Inject, Input, NgZone, Output, Renderer2, ViewEncapsulation, } from "@angular/core";
import { NavigationEnd, Router } from "@angular/router";
import { filter, take } from "rxjs/operators";
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/scrolling";
import * as i2 from "@angular/router";
import * as i3 from "@angular/cdk/a11y";
const FOCUSABLE_SELECTOR = "a, button, input, textarea, select, details, [tabindex]:not([tabindex='-1'])";
/*
* <example-url>./../examples/index.html#/dialog</example-url><br />
*
* @dynamic
*/
export class DialogComponent {
constructor(document, elRef, renderer, ngZone, scrollDispatcher, router) {
this.document = document;
this.elRef = elRef;
this.renderer = renderer;
this.ngZone = ngZone;
this.scrollDispatcher = scrollDispatcher;
this.router = router;
/**
* Whether a backdrop element should be created for a given dialog (true by default).
* Alternatively, specify 'static' for a backdrop which doesn't close the dialog on click.
*/
this.backdrop = true;
/**
* Whether to close the dialog when escape key is pressed (true by default).
*/
this.keyboard = true;
/**
* Event fired on dismiss of the dialog window
*/
this.dismissEvent = new EventEmitter();
}
onShiftTab(event) {
if (this.elRef.nativeElement === this.document.activeElement ||
!this.elRef.nativeElement.contains(this.document.activeElement)) {
this.handleFocus(event);
}
}
onTab(event) {
if (!this.elRef.nativeElement.contains(this.document.activeElement)) {
this.handleFocus(event);
}
}
backdropMouseDown($event) {
this.mouseDownOrigin = $event.target;
}
backdropMouseUp($event) {
if (this.backdrop === true) {
if (this.mouseDownOrigin !== this.elRef.nativeElement) {
return;
}
else if (this.elRef.nativeElement === $event.target) {
this.dismiss("BACKDROP_CLICK");
}
}
}
escKey($event) {
if (this.keyboard && !$event.defaultPrevented) {
this.dismiss("ESC");
}
}
dismiss(reason) {
this.dismissEvent.emit(reason);
}
ngOnInit() {
this.elWithFocus = this.document.activeElement;
this.renderer.addClass(this.document.body, "dialog-open");
this.scrollableElement = new CdkScrollable(this.elRef, this.scrollDispatcher, this.ngZone);
this.scrollDispatcher.register(this.scrollableElement);
this.router.events
.pipe(filter((e) => e instanceof NavigationEnd), take(1))
.subscribe(() => this.dismiss("ROUTE_CHANGED"));
}
ngAfterViewInit() {
if (!this.elRef.nativeElement.contains(document.activeElement)) {
this.elRef.nativeElement["focus"].apply(this.elRef.nativeElement, []);
}
}
ngOnDestroy() {
const body = this.document.body;
const elWithFocus = this.elWithFocus;
let elementToFocus;
if (elWithFocus && elWithFocus["focus"] && body.contains(elWithFocus)) {
elementToFocus = elWithFocus;
}
else {
elementToFocus = body;
}
elementToFocus["focus"].apply(elementToFocus, []);
this.elWithFocus = null;
this.renderer.removeClass(body, "dialog-open");
this.scrollDispatcher.deregister(this.scrollableElement);
}
handleFocus(event) {
event.preventDefault();
this.elRef.nativeElement.querySelector(FOCUSABLE_SELECTOR).focus();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DialogComponent, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }, { token: i1.ScrollDispatcher }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DialogComponent, selector: "nui-dialog-window", inputs: { backdrop: "backdrop", keyboard: "keyboard", size: "size", windowClass: "windowClass" }, outputs: { dismissEvent: "dismissEvent" }, host: { attributes: { "role": "dialog", "aria-modal": "true", "tabindex": "-1" }, listeners: { "keyup.esc": "escKey($event)", "mousedown": "backdropMouseDown($event)", "mouseup": "backdropMouseUp($event)", "window:keydown.shift.tab": "onShiftTab($event)", "window:keydown.tab": "onTab($event)" }, properties: { "class": "\"nui-dialog fade in show\" + (windowClass ? \" \" + windowClass : \"\")" } }, ngImport: i0, template: "<div [class]=\"'modal-dialog' + (size ? ' dialog-' + size : '')\" cdkTrapFocus>\n <div class=\"dialog-content\"><ng-content></ng-content></div>\n</div>\n", styles: [".nui .dialog-open{overflow:hidden}.nui .dialog-open .nui-dialog{overflow-x:hidden;overflow-y:auto}.nui .nui-dialog{display:none;overflow:hidden;position:fixed;inset:0;z-index:1050;pointer-events:auto;-webkit-overflow-scrolling:touch;outline:0}.nui .nui-dialog .modal-dialog{position:relative;width:auto;max-width:80%;margin:10px}.nui .nui-dialog .modal-dialog .dialog-content{position:relative;background-color:var(--nui-color-bg-content_popover,#fff);box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3));background-clip:padding-box;outline:0;min-width:400px;word-wrap:break-word}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid;border-bottom-color:var(--nui-color-line-default,#d9d9d9);min-height:39px;background:none}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text{display:inline-flex;align-items:center;overflow:hidden}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text .dialog-title{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;display:inline-block;margin:0;padding:0;line-height:24px;text-transform:none}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text .nui-icon{margin-right:5px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .btn-group{margin-left:15px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-info{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-info,#1c8eb1)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-warning{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-warning,#fec405)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-critical{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-critical,#dd2c00)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body{position:relative;padding:15px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body.compact-mode{padding:0}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body.responsive-mode{overflow:auto;max-height:71vh}.nui .dialog-backdrop{position:fixed;inset:0;z-index:1040;background-color:var(--nui-color-overlay-modal,rgba(17, 17, 17, .5))}.nui .nui-overlay-container.cdk-overlay-container .dialog-backdrop,.nui .nui-overlay-container.cdk-overlay-container .nui-dialog{z-index:1000}@media (min-width: 768px){.nui .nui-dialog .modal-dialog{width:600px;margin:80px auto}.nui .nui-dialog .modal-dialog .dialog-content{box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3))}.nui-dialog .modal-dialog.dialog-sm{width:400px}}@media (min-width: 992px){.nui-dialog .modal-dialog.dialog-lg{width:900px}}\n"], dependencies: [{ kind: "directive", type: i3.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DialogComponent, decorators: [{
type: Component,
args: [{ selector: "nui-dialog-window", host: {
"[class]": `"nui-dialog fade in show" + (windowClass ? " " + windowClass : "")`,
role: "dialog",
"aria-modal": "true",
tabindex: "-1",
"(keyup.esc)": "escKey($event)",
"(mousedown)": "backdropMouseDown($event)",
"(mouseup)": "backdropMouseUp($event)",
}, encapsulation: ViewEncapsulation.None, template: "<div [class]=\"'modal-dialog' + (size ? ' dialog-' + size : '')\" cdkTrapFocus>\n <div class=\"dialog-content\"><ng-content></ng-content></div>\n</div>\n", styles: [".nui .dialog-open{overflow:hidden}.nui .dialog-open .nui-dialog{overflow-x:hidden;overflow-y:auto}.nui .nui-dialog{display:none;overflow:hidden;position:fixed;inset:0;z-index:1050;pointer-events:auto;-webkit-overflow-scrolling:touch;outline:0}.nui .nui-dialog .modal-dialog{position:relative;width:auto;max-width:80%;margin:10px}.nui .nui-dialog .modal-dialog .dialog-content{position:relative;background-color:var(--nui-color-bg-content_popover,#fff);box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3));background-clip:padding-box;outline:0;min-width:400px;word-wrap:break-word}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid;border-bottom-color:var(--nui-color-line-default,#d9d9d9);min-height:39px;background:none}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text{display:inline-flex;align-items:center;overflow:hidden}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text .dialog-title{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;display:inline-block;margin:0;padding:0;line-height:24px;text-transform:none}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .severity-text .nui-icon{margin-right:5px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header .btn-group{margin-left:15px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-info{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-info,#1c8eb1)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-warning{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-warning,#fec405)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-header.dialog-header-critical{border-bottom:3px solid;border-bottom-color:var(--nui-color-line-critical,#dd2c00)}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body{position:relative;padding:15px}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body.compact-mode{padding:0}.nui .nui-dialog .modal-dialog .dialog-content .dialog-body.responsive-mode{overflow:auto;max-height:71vh}.nui .dialog-backdrop{position:fixed;inset:0;z-index:1040;background-color:var(--nui-color-overlay-modal,rgba(17, 17, 17, .5))}.nui .nui-overlay-container.cdk-overlay-container .dialog-backdrop,.nui .nui-overlay-container.cdk-overlay-container .nui-dialog{z-index:1000}@media (min-width: 768px){.nui .nui-dialog .modal-dialog{width:600px;margin:80px auto}.nui .nui-dialog .modal-dialog .dialog-content{box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3))}.nui-dialog .modal-dialog.dialog-sm{width:400px}}@media (min-width: 992px){.nui-dialog .modal-dialog.dialog-lg{width:900px}}\n"] }]
}], ctorParameters: () => [{ type: Document, decorators: [{
type: Inject,
args: [DOCUMENT]
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }, { type: i1.ScrollDispatcher }, { type: i2.Router }], propDecorators: { backdrop: [{
type: Input
}], keyboard: [{
type: Input
}], size: [{
type: Input
}], windowClass: [{
type: Input
}], dismissEvent: [{
type: Output
}], onShiftTab: [{
type: HostListener,
args: ["window:keydown.shift.tab", ["$event"]]
}], onTab: [{
type: HostListener,
args: ["window:keydown.tab", ["$event"]]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../src/lib/dialog/dialog.component.ts","../../../../src/lib/dialog/dialog.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 { CdkScrollable, ScrollDispatcher } from \"@angular/cdk/scrolling\";\nimport { DOCUMENT } from \"@angular/common\";\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { NavigationEnd, Router } from \"@angular/router\";\nimport { filter, take } from \"rxjs/operators\";\n\nconst FOCUSABLE_SELECTOR =\n    \"a, button, input, textarea, select, details, [tabindex]:not([tabindex='-1'])\";\n\n/*\n * <example-url>./../examples/index.html#/dialog</example-url><br />\n *\n * @dynamic\n */\n@Component({\n    selector: \"nui-dialog-window\",\n    host: {\n        \"[class]\": `\"nui-dialog fade in show\" + (windowClass ? \" \" + windowClass : \"\")`,\n        role: \"dialog\",\n        \"aria-modal\": \"true\",\n        tabindex: \"-1\",\n        \"(keyup.esc)\": \"escKey($event)\",\n        \"(mousedown)\": \"backdropMouseDown($event)\",\n        \"(mouseup)\": \"backdropMouseUp($event)\",\n    },\n    templateUrl: \"./dialog.component.html\",\n    styleUrls: [\"./dialog.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class DialogComponent implements OnInit, AfterViewInit, OnDestroy {\n    private elWithFocus: any;\n    /**\n     * Whether a backdrop element should be created for a given dialog (true by default).\n     * Alternatively, specify 'static' for a backdrop which doesn't close the dialog on click.\n     */\n    @Input() backdrop: boolean | string = true;\n\n    /**\n     * Whether to close the dialog when escape key is pressed (true by default).\n     */\n    @Input() keyboard = true;\n\n    /**\n     * Size of a new dialog window.\n     */\n    @Input() size: string;\n\n    /**\n     * Custom class to append to the dialog window\n     */\n    @Input() windowClass: string;\n\n    /**\n     * Event fired on dismiss of the dialog window\n     */\n    @Output() dismissEvent = new EventEmitter();\n\n    private scrollableElement: CdkScrollable;\n    private mouseDownOrigin: MouseEvent;\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        private elRef: ElementRef,\n        private renderer: Renderer2,\n        private ngZone: NgZone,\n        private scrollDispatcher: ScrollDispatcher,\n        private router: Router\n    ) {}\n\n    @HostListener(\"window:keydown.shift.tab\", [\"$event\"])\n    onShiftTab(event: KeyboardEvent): void {\n        if (\n            this.elRef.nativeElement === this.document.activeElement ||\n            !this.elRef.nativeElement.contains(this.document.activeElement)\n        ) {\n            this.handleFocus(event);\n        }\n    }\n\n    @HostListener(\"window:keydown.tab\", [\"$event\"])\n    onTab(event: KeyboardEvent): void {\n        if (!this.elRef.nativeElement.contains(this.document.activeElement)) {\n            this.handleFocus(event);\n        }\n    }\n\n    backdropMouseDown($event: any): void {\n        this.mouseDownOrigin = $event.target;\n    }\n\n    backdropMouseUp($event: any): void {\n        if (this.backdrop === true) {\n            if (this.mouseDownOrigin !== this.elRef.nativeElement) {\n                return;\n            } else if (this.elRef.nativeElement === $event.target) {\n                this.dismiss(\"BACKDROP_CLICK\");\n            }\n        }\n    }\n\n    escKey($event: any): void {\n        if (this.keyboard && !$event.defaultPrevented) {\n            this.dismiss(\"ESC\");\n        }\n    }\n\n    dismiss(reason: any): void {\n        this.dismissEvent.emit(reason);\n    }\n\n    public ngOnInit(): void {\n        this.elWithFocus = this.document.activeElement;\n        this.renderer.addClass(this.document.body, \"dialog-open\");\n        this.scrollableElement = new CdkScrollable(\n            this.elRef,\n            this.scrollDispatcher,\n            this.ngZone\n        );\n        this.scrollDispatcher.register(this.scrollableElement);\n\n        this.router.events\n            .pipe(\n                filter((e) => e instanceof NavigationEnd),\n                take(1)\n            )\n            .subscribe(() => this.dismiss(\"ROUTE_CHANGED\"));\n    }\n\n    public ngAfterViewInit(): void {\n        if (!this.elRef.nativeElement.contains(document.activeElement)) {\n            this.elRef.nativeElement[\"focus\"].apply(\n                this.elRef.nativeElement,\n                []\n            );\n        }\n    }\n\n    public ngOnDestroy(): void {\n        const body = this.document.body;\n        const elWithFocus = this.elWithFocus;\n\n        let elementToFocus;\n        if (elWithFocus && elWithFocus[\"focus\"] && body.contains(elWithFocus)) {\n            elementToFocus = elWithFocus;\n        } else {\n            elementToFocus = body;\n        }\n        elementToFocus[\"focus\"].apply(elementToFocus, []);\n\n        this.elWithFocus = null;\n        this.renderer.removeClass(body, \"dialog-open\");\n        this.scrollDispatcher.deregister(this.scrollableElement);\n    }\n\n    private handleFocus(event: KeyboardEvent): void {\n        event.preventDefault();\n        this.elRef.nativeElement.querySelector(FOCUSABLE_SELECTOR).focus();\n    }\n}\n","<div [class]=\"'modal-dialog' + (size ? ' dialog-' + size : '')\" cdkTrapFocus>\n    <div class=\"dialog-content\"><ng-content></ng-content></div>\n</div>\n"]}