UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

102 lines 16.2 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 { Component } from "@angular/core"; import { Router, RoutesRecognized } from "@angular/router"; import defaults from "lodash/defaults"; import { filter, map } from "rxjs/operators"; import { SrlcStage } from "./public-api"; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@angular/common"; import * as i3 from "../../message/message.component"; /** @ignore */ export class SrlcIndicatorComponent { constructor(router) { this.router = router; this.globalSrlc = { stage: SrlcStage.preAlpha, eolDate: new Date("1/1/2100"), hideIndicator: false, }; this.getMessageType = () => { switch (this.componentSrlc.stage) { case SrlcStage.preAlpha: return "critical"; case SrlcStage.alpha: return "warning"; case SrlcStage.beta: return "info"; case SrlcStage.ga: return "ok"; case SrlcStage.support: return "hint"; case SrlcStage.eol: return "error"; default: return "error"; } }; this.getMessageText = () => { switch (this.componentSrlc.stage) { case SrlcStage.preAlpha: return `<strong>Under Development</strong> DO NOT USE. This component is under active development and significant, API breaking changes are still expected. Its use will not be supported.`; case SrlcStage.alpha: // eslint-disable-next-line max-len return `<strong>Alpha</strong> USE AT YOUR OWN RISK. This component may be unstable, include defects and is still subject to API breaking changes. We encourage prototypical use and feedback - but won't support production use.`; case SrlcStage.beta: return `<strong>Beta</strong> This component is in the final testing stage. It should be quite stable, but some defects may still exist. Keep an eye on it!`; case SrlcStage.ga: return `<strong>Production Ready</strong> Available for production use - see documented examples below.`; case SrlcStage.support: return `<strong>Deprecated</strong> Sorry, but we no longer recommend using this component. Only critical issues are going to be fixed. End Of Life is scheduled to <strong>${this.componentSrlc.eolDate?.toDateString()}</strong>.`; case SrlcStage.eol: return `<strong>Not Supported</strong> Sorry, but this component is not supported any more!`; default: return `Current state of this component is unknown. Please, contact Nova team for more details.`; } }; } ngOnInit() { this.router.events .pipe(filter((event) => event instanceof RoutesRecognized), map((event) => { let route = event.state.root; while (route.firstChild) { route = route.firstChild; } return route; })) .subscribe((route) => { const routeDataSrlc = (route.data || {}).srlc; this.componentSrlc = defaults(routeDataSrlc || {}, this.globalSrlc); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SrlcIndicatorComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SrlcIndicatorComponent, selector: "nui-srlc-indicator", ngImport: i0, template: "<nui-message\n [type]=\"getMessageType()\"\n [allowDismiss]=\"false\"\n *ngIf=\"!!componentSrlc && !componentSrlc.hideIndicator\"\n>\n <span [innerHTML]=\"getMessageText()\"></span>\n</nui-message>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MessageComponent, selector: "nui-message", inputs: ["type", "allowDismiss", "manualControl"], outputs: ["dismiss"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SrlcIndicatorComponent, decorators: [{ type: Component, args: [{ selector: "nui-srlc-indicator", template: "<nui-message\n [type]=\"getMessageType()\"\n [allowDismiss]=\"false\"\n *ngIf=\"!!componentSrlc && !componentSrlc.hideIndicator\"\n>\n <span [innerHTML]=\"getMessageText()\"></span>\n</nui-message>\n" }] }], ctorParameters: () => [{ type: i1.Router }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"srlc-indicator.component.js","sourceRoot":"","sources":["../../../../../src/lib/docs/srlc-indicator/srlc-indicator.component.ts","../../../../../src/lib/docs/srlc-indicator/srlc-indicator.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 { Component, OnInit } from \"@angular/core\";\nimport { Router, RoutesRecognized } from \"@angular/router\";\nimport defaults from \"lodash/defaults\";\nimport { filter, map } from \"rxjs/operators\";\n\nimport { ISrlcDetails, SrlcStage } from \"./public-api\";\n\n/** @ignore */\n@Component({\n    selector: \"nui-srlc-indicator\",\n    templateUrl: \"./srlc-indicator.component.html\",\n})\nexport class SrlcIndicatorComponent implements OnInit {\n    constructor(private router: Router) {}\n\n    public globalSrlc: ISrlcDetails = {\n        stage: SrlcStage.preAlpha,\n        eolDate: new Date(\"1/1/2100\"),\n        hideIndicator: false,\n    };\n\n    public componentSrlc: ISrlcDetails;\n\n    public ngOnInit(): void {\n        this.router.events\n            .pipe(\n                filter((event) => event instanceof RoutesRecognized),\n                map((event) => {\n                    let route = (<RoutesRecognized>event).state.root;\n                    while (route.firstChild) {\n                        route = route.firstChild;\n                    }\n                    return route;\n                })\n            )\n            .subscribe((route) => {\n                const routeDataSrlc = (route.data || {}).srlc;\n                this.componentSrlc = defaults(\n                    routeDataSrlc || {},\n                    this.globalSrlc\n                );\n            });\n    }\n\n    public getMessageType = (): string => {\n        switch (this.componentSrlc.stage) {\n            case SrlcStage.preAlpha:\n                return \"critical\";\n            case SrlcStage.alpha:\n                return \"warning\";\n            case SrlcStage.beta:\n                return \"info\";\n            case SrlcStage.ga:\n                return \"ok\";\n            case SrlcStage.support:\n                return \"hint\";\n            case SrlcStage.eol:\n                return \"error\";\n            default:\n                return \"error\";\n        }\n    };\n\n    public getMessageText = (): string => {\n        switch (this.componentSrlc.stage) {\n            case SrlcStage.preAlpha:\n                return `<strong>Under Development</strong> DO NOT USE. This component is under active development and significant,\n                    API breaking changes are still expected. Its use will not be supported.`;\n            case SrlcStage.alpha:\n                // eslint-disable-next-line max-len\n                return `<strong>Alpha</strong> USE AT YOUR OWN RISK. This component may be unstable, include defects and is still subject to API breaking changes.\n                    We encourage prototypical use and feedback - but won't support production use.`;\n            case SrlcStage.beta:\n                return `<strong>Beta</strong> This component is in the final testing stage. It should be quite stable,\n                    but some defects may still exist. Keep an eye on it!`;\n            case SrlcStage.ga:\n                return `<strong>Production Ready</strong> Available for production use - see documented examples below.`;\n            case SrlcStage.support:\n                return `<strong>Deprecated</strong> Sorry, but we no longer recommend using this component.\n                    Only critical issues are going to be fixed.\n                    End Of Life is scheduled to <strong>${this.componentSrlc.eolDate?.toDateString()}</strong>.`;\n            case SrlcStage.eol:\n                return `<strong>Not Supported</strong> Sorry, but this component is not supported any more!`;\n            default:\n                return `Current state of this component is unknown. Please, contact Nova team for more details.`;\n        }\n    };\n}\n","<nui-message\n    [type]=\"getMessageType()\"\n    [allowDismiss]=\"false\"\n    *ngIf=\"!!componentSrlc && !componentSrlc.hideIndicator\"\n>\n    <span [innerHTML]=\"getMessageText()\"></span>\n</nui-message>\n"]}