@dbg-riskit/angular-view
Version:
76 lines • 14.8 kB
JavaScript
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/material/card";
import * as i2 from "@angular/material/progress-spinner";
import * as i3 from "@angular/common";
export const RISK_ERROR_SELECTOR = 'risk-error';
export const RISK_GOOD_SELECTOR = 'risk-good';
export const RISK_INFO_SELECTOR = 'risk-info';
export const RISK_MESSAGE_SELECTOR = 'risk-message';
export const RISK_WARN_SELECTOR = 'risk-warn';
export const RISK_INITIAL_LOAD_SELECTOR = 'risk-initial-load';
export const RISK_NO_DATA_SELECTOR = 'risk-no-data';
export const RISK_UPDATE_FAILED_SELECTOR = 'risk-update-failed';
export const COMPONENT_SELECTOR = RISK_ERROR_SELECTOR + ', ' + RISK_GOOD_SELECTOR + ', ' + RISK_INFO_SELECTOR + ', '
+ RISK_MESSAGE_SELECTOR + ', ' + RISK_WARN_SELECTOR + ', '
+ RISK_INITIAL_LOAD_SELECTOR + ', ' + RISK_NO_DATA_SELECTOR + ', '
+ RISK_UPDATE_FAILED_SELECTOR;
const COLOR_EQUALS = 'color === "';
export class MessageComponent {
constructor(elementRef) {
const tagName = elementRef.nativeElement.tagName.toLowerCase();
this._initialLoad = tagName === RISK_INITIAL_LOAD_SELECTOR;
this._noData = tagName === RISK_NO_DATA_SELECTOR;
this._updateError = tagName === RISK_UPDATE_FAILED_SELECTOR;
switch (tagName) {
case RISK_INFO_SELECTOR:
case RISK_NO_DATA_SELECTOR:
this._color = RISK_INFO_SELECTOR;
break;
case RISK_WARN_SELECTOR:
case RISK_INITIAL_LOAD_SELECTOR:
this._color = RISK_WARN_SELECTOR;
break;
case RISK_ERROR_SELECTOR:
case RISK_UPDATE_FAILED_SELECTOR:
this._color = RISK_ERROR_SELECTOR;
break;
case RISK_GOOD_SELECTOR:
this._color = RISK_GOOD_SELECTOR;
break;
default:
this._color = null;
}
}
get color() {
return this._color;
}
get initialLoad() {
return this._initialLoad;
}
get noData() {
return this._noData;
}
get updateError() {
return this._updateError;
}
}
MessageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: MessageComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
MessageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.6", type: MessageComponent, selector: "risk-error, risk-good, risk-info, risk-message, risk-warn, risk-initial-load, risk-no-data, risk-update-failed", inputs: { message: "message" }, host: { properties: { "class.risk-message": "true", "class.risk-message-error": "color === \"risk-error\"", "class.risk-message-warn": "color === \"risk-warn\"", "class.risk-message-good": "color === \"risk-good\"", "class.risk-message-info": "color === \"risk-info\"", "class.risk-message-initial-load": "initialLoad", "class.risk-message-no-data": "noData", "class.risk-message-update-error": "updateError" } }, ngImport: i0, template: "<mat-card [ngClass]=\"color\">\n <ng-template [ngIf]=\"initialLoad\">\n <mat-spinner [diameter]=\"50\"></mat-spinner>\n Loading...\n </ng-template>\n <ng-template [ngIf]=\"noData\">No data available.</ng-template>\n <ng-template [ngIf]=\"updateError\">Failed to update the data: {{message}}.</ng-template>\n <ng-template [ngIf]=\"!initialLoad && !noData && !updateError\">{{message}}</ng-template>\n <ng-content></ng-content>\n</mat-card>", styles: [":host{display:block;padding:0;margin:0}:host>*{vertical-align:bottom}\n", ":host(.risk-message-initial-load) .mat-card{display:-webkit-flex;display:flex;line-height:50px;padding:15px 24px}:host(.risk-message-initial-load) .mat-card .mat-spinner{margin-right:15px}\n"], components: [{ type: i1.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i2.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: MessageComponent, decorators: [{
type: Component,
args: [{ selector: COMPONENT_SELECTOR, host: {
'[class.risk-message]': 'true',
'[class.risk-message-error]': COLOR_EQUALS + RISK_ERROR_SELECTOR + '"',
'[class.risk-message-warn]': COLOR_EQUALS + RISK_WARN_SELECTOR + '"',
'[class.risk-message-good]': COLOR_EQUALS + RISK_GOOD_SELECTOR + '"',
'[class.risk-message-info]': COLOR_EQUALS + RISK_INFO_SELECTOR + '"',
'[class.risk-message-initial-load]': 'initialLoad',
'[class.risk-message-no-data]': 'noData',
'[class.risk-message-update-error]': 'updateError'
}, changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, template: "<mat-card [ngClass]=\"color\">\n <ng-template [ngIf]=\"initialLoad\">\n <mat-spinner [diameter]=\"50\"></mat-spinner>\n Loading...\n </ng-template>\n <ng-template [ngIf]=\"noData\">No data available.</ng-template>\n <ng-template [ngIf]=\"updateError\">Failed to update the data: {{message}}.</ng-template>\n <ng-template [ngIf]=\"!initialLoad && !noData && !updateError\">{{message}}</ng-template>\n <ng-content></ng-content>\n</mat-card>", styles: [":host{display:block;padding:0;margin:0}:host>*{vertical-align:bottom}\n", ":host(.risk-message-initial-load) .mat-card{display:-webkit-flex;display:flex;line-height:50px;padding:15px 24px}:host(.risk-message-initial-load) .mat-card .mat-spinner{margin-right:15px}\n"] }]
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { message: [{
type: Input,
args: ['message']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.component.js","sourceRoot":"","sources":["../../../../../pkg/dbg-riskit/angular-view/src/lib/message.component.ts","../../../../../pkg/dbg-riskit/angular-view/src/lib/message.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAc,KAAK,EAAC,MAAM,eAAe,CAAC;;;;;AAEpF,MAAM,CAAC,MAAM,mBAAmB,GAAG,YAAY,CAAC;AAChD,MAAM,CAAC,MAAM,kBAAkB,GAAG,WAAW,CAAC;AAC9C,MAAM,CAAC,MAAM,kBAAkB,GAAG,WAAW,CAAC;AAC9C,MAAM,CAAC,MAAM,qBAAqB,GAAG,cAAc,CAAC;AACpD,MAAM,CAAC,MAAM,kBAAkB,GAAG,WAAW,CAAC;AAE9C,MAAM,CAAC,MAAM,0BAA0B,GAAG,mBAAmB,CAAC;AAC9D,MAAM,CAAC,MAAM,qBAAqB,GAAG,cAAc,CAAC;AACpD,MAAM,CAAC,MAAM,2BAA2B,GAAG,oBAAoB,CAAC;AAEhE,MAAM,CAAC,MAAM,kBAAkB,GAAG,mBAAmB,GAAG,IAAI,GAAG,kBAAkB,GAAG,IAAI,GAAG,kBAAkB,GAAG,IAAI;MAChF,qBAAqB,GAAG,IAAI,GAAG,kBAAkB,GAAG,IAAI;MACxD,0BAA0B,GAAG,IAAI,GAAG,qBAAqB,GAAG,IAAI;MAChE,2BAA2B,CAAC;AAEhE,MAAM,YAAY,GAAG,aAAa,CAAC;AAsBnC,MAAM,OAAO,gBAAgB;IAczB,YAAmB,UAAsB;QACrC,MAAM,OAAO,GAAG,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QAC/D,IAAI,CAAC,YAAY,GAAG,OAAO,KAAK,0BAA0B,CAAC;QAC3D,IAAI,CAAC,OAAO,GAAG,OAAO,KAAK,qBAAqB,CAAC;QACjD,IAAI,CAAC,YAAY,GAAG,OAAO,KAAK,2BAA2B,CAAC;QAC5D,QAAQ,OAAO,EAAE;YACb,KAAK,kBAAkB,CAAC;YACxB,KAAK,qBAAqB;gBACtB,IAAI,CAAC,MAAM,GAAG,kBAAkB,CAAC;gBACjC,MAAM;YACV,KAAK,kBAAkB,CAAC;YACxB,KAAK,0BAA0B;gBAC3B,IAAI,CAAC,MAAM,GAAG,kBAAkB,CAAC;gBACjC,MAAM;YACV,KAAK,mBAAmB,CAAC;YACzB,KAAK,2BAA2B;gBAC5B,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC;gBAClC,MAAM;YACV,KAAK,kBAAkB;gBACnB,IAAI,CAAC,MAAM,GAAG,kBAAkB,CAAC;gBACjC,MAAM;YACV;gBACI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SAC1B;IACL,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;;6GAtDQ,gBAAgB;iGAAhB,gBAAgB,olBCvC7B,wdASW;2FD8BE,gBAAgB;kBApB5B,SAAS;+BACe,kBAAkB,QAMlB;wBACjB,sBAAsB,EAAe,MAAM;wBAC3C,4BAA4B,EAAS,YAAY,GAAG,mBAAmB,GAAG,GAAG;wBAC7E,2BAA2B,EAAU,YAAY,GAAG,kBAAkB,GAAG,GAAG;wBAC5E,2BAA2B,EAAU,YAAY,GAAG,kBAAkB,GAAG,GAAG;wBAC5E,2BAA2B,EAAU,YAAY,GAAG,kBAAkB,GAAG,GAAG;wBAC5E,mCAAmC,EAAE,aAAa;wBAClD,8BAA8B,EAAO,QAAQ;wBAC7C,mCAAmC,EAAE,aAAa;qBACrD,mBACoB,uBAAuB,CAAC,MAAM,uBAC9B,KAAK;iGAcnB,OAAO;sBADb,KAAK;uBAAC,SAAS","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, Input} from '@angular/core';\n\nexport const RISK_ERROR_SELECTOR = 'risk-error';\nexport const RISK_GOOD_SELECTOR = 'risk-good';\nexport const RISK_INFO_SELECTOR = 'risk-info';\nexport const RISK_MESSAGE_SELECTOR = 'risk-message';\nexport const RISK_WARN_SELECTOR = 'risk-warn';\n\nexport const RISK_INITIAL_LOAD_SELECTOR = 'risk-initial-load';\nexport const RISK_NO_DATA_SELECTOR = 'risk-no-data';\nexport const RISK_UPDATE_FAILED_SELECTOR = 'risk-update-failed';\n\nexport const COMPONENT_SELECTOR = RISK_ERROR_SELECTOR + ', ' + RISK_GOOD_SELECTOR + ', ' + RISK_INFO_SELECTOR + ', '\n                                  + RISK_MESSAGE_SELECTOR + ', ' + RISK_WARN_SELECTOR + ', '\n                                  + RISK_INITIAL_LOAD_SELECTOR + ', ' + RISK_NO_DATA_SELECTOR + ', '\n                                  + RISK_UPDATE_FAILED_SELECTOR;\n\nconst COLOR_EQUALS = 'color === \"';\n\n@Component({\n    selector           : COMPONENT_SELECTOR,\n    templateUrl        : 'message.component.html',\n    styleUrls          : [\n        '../../../component.scss',\n        'message.component.scss'\n    ],\n    host               : {\n        '[class.risk-message]'             : 'true',\n        '[class.risk-message-error]'       : COLOR_EQUALS + RISK_ERROR_SELECTOR + '\"',\n        '[class.risk-message-warn]'        : COLOR_EQUALS + RISK_WARN_SELECTOR + '\"',\n        '[class.risk-message-good]'        : COLOR_EQUALS + RISK_GOOD_SELECTOR + '\"',\n        '[class.risk-message-info]'        : COLOR_EQUALS + RISK_INFO_SELECTOR + '\"',\n        '[class.risk-message-initial-load]': 'initialLoad',\n        '[class.risk-message-no-data]'     : 'noData',\n        '[class.risk-message-update-error]': 'updateError'\n    },\n    changeDetection    : ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false\n})\nexport class MessageComponent {\n\n    private readonly _initialLoad: boolean;\n    private readonly _noData: boolean;\n    private readonly _updateError: boolean;\n    private readonly _color: typeof RISK_GOOD_SELECTOR\n        | typeof RISK_INFO_SELECTOR\n        | typeof RISK_ERROR_SELECTOR\n        | typeof RISK_WARN_SELECTOR\n        | null;\n\n    @Input('message')\n    public message?: string;\n\n    public constructor(elementRef: ElementRef) {\n        const tagName = elementRef.nativeElement.tagName.toLowerCase();\n        this._initialLoad = tagName === RISK_INITIAL_LOAD_SELECTOR;\n        this._noData = tagName === RISK_NO_DATA_SELECTOR;\n        this._updateError = tagName === RISK_UPDATE_FAILED_SELECTOR;\n        switch (tagName) {\n            case RISK_INFO_SELECTOR:\n            case RISK_NO_DATA_SELECTOR:\n                this._color = RISK_INFO_SELECTOR;\n                break;\n            case RISK_WARN_SELECTOR:\n            case RISK_INITIAL_LOAD_SELECTOR:\n                this._color = RISK_WARN_SELECTOR;\n                break;\n            case RISK_ERROR_SELECTOR:\n            case RISK_UPDATE_FAILED_SELECTOR:\n                this._color = RISK_ERROR_SELECTOR;\n                break;\n            case RISK_GOOD_SELECTOR:\n                this._color = RISK_GOOD_SELECTOR;\n                break;\n            default:\n                this._color = null;\n        }\n    }\n\n    public get color(): string | null {\n        return this._color;\n    }\n\n    public get initialLoad(): boolean {\n        return this._initialLoad;\n    }\n\n    public get noData(): boolean {\n        return this._noData;\n    }\n\n    public get updateError(): boolean {\n        return this._updateError;\n    }\n}\n","<mat-card [ngClass]=\"color\">\n    <ng-template [ngIf]=\"initialLoad\">\n        <mat-spinner [diameter]=\"50\"></mat-spinner>\n        Loading...\n    </ng-template>\n    <ng-template [ngIf]=\"noData\">No data available.</ng-template>\n    <ng-template [ngIf]=\"updateError\">Failed to update the data: {{message}}.</ng-template>\n    <ng-template [ngIf]=\"!initialLoad && !noData && !updateError\">{{message}}</ng-template>\n    <ng-content></ng-content>\n</mat-card>"]}