@nova-ui/bits
Version:
SolarWinds Nova Framework
123 lines • 22.6 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 { animate, state, style, transition, trigger, } from "@angular/animations";
import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, ViewEncapsulation, } from "@angular/core";
import { Subject } from "rxjs";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../icon/icon.component";
import * as i3 from "../button/button.component";
// <example-url>./../examples/index.html#/message</example-url>
export class MessageComponent {
static { this.ICON_MAP = {
ok: "severity_ok",
warning: "severity_warning",
critical: "severity_critical",
info: "severity_info",
}; }
static { this.UNKNOWN_ICON = "severity_unknown"; }
get role() {
return this.type === "ok" || this.type === "info" ? "status" : "alert";
}
constructor(element, renderer) {
this.element = element;
this.renderer = renderer;
this.isHidden = false;
this.allowDismiss = true;
/**
* emits value when user closed message by clicking (x) button
*/
this.dismiss = new EventEmitter();
this.dismissState = "initial";
}
ngOnInit() {
if (this.manualControl) {
this.dismissSubscription = this.manualControl.subscribe((shown) => {
this.dismissState = shown ? "initial" : "dismissed";
});
}
}
ngOnDestroy() {
this.dismiss.complete();
if (this.dismissSubscription) {
this.dismissSubscription.unsubscribe();
}
}
dismissMessage() {
this.dismissState = "dismissed";
this.dismiss.emit();
}
animationFinished(event) {
if (event.toState === "dismissed") {
if (this.manualControl) {
this.isHidden = true;
}
else {
this.renderer.removeChild(this.element.nativeElement.parentNode, this.element.nativeElement);
}
}
}
animationStart(event) {
if (event.fromState === "dismissed") {
this.isHidden = false;
}
}
get messageClass() {
return this.type ? `nui-message-${this.type.toLowerCase()}` : "";
}
get icon() {
return (MessageComponent.ICON_MAP[this.type ?? ""] ||
MessageComponent.UNKNOWN_ICON);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MessageComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MessageComponent, selector: "nui-message", inputs: { type: "type", allowDismiss: "allowDismiss", manualControl: "manualControl" }, outputs: { dismiss: "dismiss" }, host: { properties: { "attr.role": "role", "class.d-none": "this.isHidden" } }, ngImport: i0, template: "<div\n [@dismiss]=\"dismissState\"\n (@dismiss.done)=\"animationFinished($event)\"\n (@dismiss.start)=\"animationStart($event)\"\n class=\"nui-flex-container nui-flex--nowrap nui-message {{ messageClass }}\"\n [ngClass]=\"{ 'nui-message-allow-dismiss': allowDismiss }\"\n>\n <nui-icon class=\"nui-message-icon\" [icon]=\"icon\"></nui-icon>\n\n <div class=\"nui-message-content\">\n <span class=\"nui-message-content-text\">\n <ng-content></ng-content>\n </span>\n </div>\n\n <div class=\"nui-message-dismiss-button\" *ngIf=\"allowDismiss\">\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n size=\"default\"\n icon=\"close\"\n (click)=\"dismissMessage()\"\n ></button>\n </div>\n</div>\n", styles: [".nui .nui-message{align-items:flex-start;border-radius:0;border:solid 1px;font-size:13px;justify-content:flex-start;margin-bottom:10px;padding:10px;position:relative}.nui .nui-message-critical{background-color:var(--nui-color-semantic-critical-bg,#fceae6);border-color:var(--nui-color-line-critical,#dd2c00);color:var(--nui-color-text-default,#111)}.nui .nui-message-warning{background-color:var(--nui-color-semantic-warning-bg,#fff9e6);border-color:var(--nui-color-line-warning,#fec405);color:var(--nui-color-text-default,#111)}.nui .nui-message-ok{background-color:var(--nui-color-semantic-ok-bg,#e6f6ee);border-color:var(--nui-color-line-ok,#00a753);color:var(--nui-color-text-default,#111)}.nui .nui-message-info{background-color:var(--nui-color-semantic-info-bg,#e8f4f7);border-color:var(--nui-color-line-info,#1c8eb1);color:var(--nui-color-text-default,#111)}.nui .nui-message-content{margin-left:10px}.nui .nui-message-content-text{vertical-align:middle}.nui .nui-message-icon{align-items:center;display:flex;height:calc(1em * 1.66666667);min-width:16px}.nui .nui-message-allow-dismiss .nui-message-content{margin-right:31px}.nui .nui-message-dismiss-button{border:none;display:block;padding:0;position:absolute;right:5px;top:calc(((1em * 1.66666667) + (10px * 2) - 16px - (1px * 2) - (6px * 2)) / 2)}.nui .nui-message-dismiss-button:hover,.nui .nui-message-dismiss-button:active,.nui .nui-message-dismiss-button:focus{background-color:var(--nui-color-bg-transparent,transparent)}.nui .nui-message .nui-icon{display:block;float:left;margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "component", type: i3.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }], animations: [
trigger("dismiss", [
state("initial", style({})),
state("dismissed", style({
opacity: 0,
})),
transition("initial <=> dismissed", animate(`0.3s linear`)),
]),
], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MessageComponent, decorators: [{
type: Component,
args: [{ selector: "nui-message", animations: [
trigger("dismiss", [
state("initial", style({})),
state("dismissed", style({
opacity: 0,
})),
transition("initial <=> dismissed", animate(`0.3s linear`)),
]),
], encapsulation: ViewEncapsulation.None, host: { "[attr.role]": "role" }, template: "<div\n [@dismiss]=\"dismissState\"\n (@dismiss.done)=\"animationFinished($event)\"\n (@dismiss.start)=\"animationStart($event)\"\n class=\"nui-flex-container nui-flex--nowrap nui-message {{ messageClass }}\"\n [ngClass]=\"{ 'nui-message-allow-dismiss': allowDismiss }\"\n>\n <nui-icon class=\"nui-message-icon\" [icon]=\"icon\"></nui-icon>\n\n <div class=\"nui-message-content\">\n <span class=\"nui-message-content-text\">\n <ng-content></ng-content>\n </span>\n </div>\n\n <div class=\"nui-message-dismiss-button\" *ngIf=\"allowDismiss\">\n <button\n nui-button\n type=\"button\"\n displayStyle=\"action\"\n size=\"default\"\n icon=\"close\"\n (click)=\"dismissMessage()\"\n ></button>\n </div>\n</div>\n", styles: [".nui .nui-message{align-items:flex-start;border-radius:0;border:solid 1px;font-size:13px;justify-content:flex-start;margin-bottom:10px;padding:10px;position:relative}.nui .nui-message-critical{background-color:var(--nui-color-semantic-critical-bg,#fceae6);border-color:var(--nui-color-line-critical,#dd2c00);color:var(--nui-color-text-default,#111)}.nui .nui-message-warning{background-color:var(--nui-color-semantic-warning-bg,#fff9e6);border-color:var(--nui-color-line-warning,#fec405);color:var(--nui-color-text-default,#111)}.nui .nui-message-ok{background-color:var(--nui-color-semantic-ok-bg,#e6f6ee);border-color:var(--nui-color-line-ok,#00a753);color:var(--nui-color-text-default,#111)}.nui .nui-message-info{background-color:var(--nui-color-semantic-info-bg,#e8f4f7);border-color:var(--nui-color-line-info,#1c8eb1);color:var(--nui-color-text-default,#111)}.nui .nui-message-content{margin-left:10px}.nui .nui-message-content-text{vertical-align:middle}.nui .nui-message-icon{align-items:center;display:flex;height:calc(1em * 1.66666667);min-width:16px}.nui .nui-message-allow-dismiss .nui-message-content{margin-right:31px}.nui .nui-message-dismiss-button{border:none;display:block;padding:0;position:absolute;right:5px;top:calc(((1em * 1.66666667) + (10px * 2) - 16px - (1px * 2) - (6px * 2)) / 2)}.nui .nui-message-dismiss-button:hover,.nui .nui-message-dismiss-button:active,.nui .nui-message-dismiss-button:focus{background-color:var(--nui-color-bg-transparent,transparent)}.nui .nui-message .nui-icon{display:block;float:left;margin:0}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { isHidden: [{
type: HostBinding,
args: ["class.d-none"]
}], type: [{
type: Input
}], allowDismiss: [{
type: Input
}], manualControl: [{
type: Input
}], dismiss: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.component.js","sourceRoot":"","sources":["../../../../src/lib/message/message.component.ts","../../../../src/lib/message/message.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 {\n    animate,\n    AnimationEvent,\n    state,\n    style,\n    transition,\n    trigger,\n} from \"@angular/animations\";\nimport {\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { Subject, Subscription } from \"rxjs\";\n\n// <example-url>./../examples/index.html#/message</example-url>\n@Component({\n    selector: \"nui-message\",\n    templateUrl: \"./message.component.html\",\n    animations: [\n        trigger(\"dismiss\", [\n            state(\"initial\", style({})),\n            state(\n                \"dismissed\",\n                style({\n                    opacity: 0,\n                })\n            ),\n            transition(\"initial <=> dismissed\", animate(`0.3s linear`)),\n        ]),\n    ],\n    styleUrls: [\"./message.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n    host: { \"[attr.role]\": \"role\" },\n})\nexport class MessageComponent implements OnInit, OnDestroy {\n    public static ICON_MAP: { [id: string]: string } = {\n        ok: \"severity_ok\",\n        warning: \"severity_warning\",\n        critical: \"severity_critical\",\n        info: \"severity_info\",\n    };\n    public static UNKNOWN_ICON = \"severity_unknown\";\n\n    @HostBinding(\"class.d-none\") isHidden: boolean = false;\n\n    @Input() public type: null | \"ok\" | \"info\" | \"critical\" | \"warning\";\n    @Input() public allowDismiss: boolean = true;\n    @Input() public manualControl: Subject<boolean>;\n\n    /**\n     * emits value when user closed message by clicking (x) button\n     */\n    @Output() public dismiss = new EventEmitter();\n\n    public dismissState: \"initial\" | \"dismissed\" = \"initial\";\n    private dismissSubscription: Subscription;\n\n    get role(): string {\n        return this.type === \"ok\" || this.type === \"info\" ? \"status\" : \"alert\";\n    }\n\n    constructor(private element: ElementRef, private renderer: Renderer2) {}\n\n    public ngOnInit(): void {\n        if (this.manualControl) {\n            this.dismissSubscription = this.manualControl.subscribe(\n                (shown: boolean) => {\n                    this.dismissState = shown ? \"initial\" : \"dismissed\";\n                }\n            );\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.dismiss.complete();\n        if (this.dismissSubscription) {\n            this.dismissSubscription.unsubscribe();\n        }\n    }\n\n    public dismissMessage(): void {\n        this.dismissState = \"dismissed\";\n        this.dismiss.emit();\n    }\n\n    public animationFinished(event: AnimationEvent): void {\n        if (event.toState === \"dismissed\") {\n            if (this.manualControl) {\n                this.isHidden = true;\n            } else {\n                this.renderer.removeChild(\n                    this.element.nativeElement.parentNode,\n                    this.element.nativeElement\n                );\n            }\n        }\n    }\n\n    public animationStart(event: AnimationEvent): void {\n        if (event.fromState === \"dismissed\") {\n            this.isHidden = false;\n        }\n    }\n\n    public get messageClass(): string {\n        return this.type ? `nui-message-${this.type.toLowerCase()}` : \"\";\n    }\n\n    public get icon(): string {\n        return (\n            MessageComponent.ICON_MAP[this.type ?? \"\"] ||\n            MessageComponent.UNKNOWN_ICON\n        );\n    }\n}\n","<div\n    [@dismiss]=\"dismissState\"\n    (@dismiss.done)=\"animationFinished($event)\"\n    (@dismiss.start)=\"animationStart($event)\"\n    class=\"nui-flex-container nui-flex--nowrap nui-message {{ messageClass }}\"\n    [ngClass]=\"{ 'nui-message-allow-dismiss': allowDismiss }\"\n>\n    <nui-icon class=\"nui-message-icon\" [icon]=\"icon\"></nui-icon>\n\n    <div class=\"nui-message-content\">\n        <span class=\"nui-message-content-text\">\n            <ng-content></ng-content>\n        </span>\n    </div>\n\n    <div class=\"nui-message-dismiss-button\" *ngIf=\"allowDismiss\">\n        <button\n            nui-button\n            type=\"button\"\n            displayStyle=\"action\"\n            size=\"default\"\n            icon=\"close\"\n            (click)=\"dismissMessage()\"\n        ></button>\n    </div>\n</div>\n"]}