@nova-ui/bits
Version:
SolarWinds Nova Framework
102 lines • 16.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 { 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":"AAAA,yDAAyD;AACzD,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,8EAA8E;AAC9E,+EAA+E;AAC/E,8EAA8E;AAC9E,4DAA4D;AAC5D,EAAE;AACF,6EAA6E;AAC7E,uDAAuD;AACvD,EAAE;AACF,6EAA6E;AAC7E,4EAA4E;AAC5E,+EAA+E;AAC/E,0EAA0E;AAC1E,iFAAiF;AACjF,6EAA6E;AAC7E,iBAAiB;AAEjB,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,QAAQ,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAgB,SAAS,EAAE,MAAM,cAAc,CAAC;;;;;AAEvD,cAAc;AAKd,MAAM,OAAO,sBAAsB;IAC/B,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAE3B,eAAU,GAAiB;YAC9B,KAAK,EAAE,SAAS,CAAC,QAAQ;YACzB,OAAO,EAAE,IAAI,IAAI,CAAC,UAAU,CAAC;YAC7B,aAAa,EAAE,KAAK;SACvB,CAAC;QAyBK,mBAAc,GAAG,GAAW,EAAE;YACjC,QAAQ,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE;gBAC9B,KAAK,SAAS,CAAC,QAAQ;oBACnB,OAAO,UAAU,CAAC;gBACtB,KAAK,SAAS,CAAC,KAAK;oBAChB,OAAO,SAAS,CAAC;gBACrB,KAAK,SAAS,CAAC,IAAI;oBACf,OAAO,MAAM,CAAC;gBAClB,KAAK,SAAS,CAAC,EAAE;oBACb,OAAO,IAAI,CAAC;gBAChB,KAAK,SAAS,CAAC,OAAO;oBAClB,OAAO,MAAM,CAAC;gBAClB,KAAK,SAAS,CAAC,GAAG;oBACd,OAAO,OAAO,CAAC;gBACnB;oBACI,OAAO,OAAO,CAAC;aACtB;QACL,CAAC,CAAC;QAEK,mBAAc,GAAG,GAAW,EAAE;YACjC,QAAQ,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE;gBAC9B,KAAK,SAAS,CAAC,QAAQ;oBACnB,OAAO;4FACqE,CAAC;gBACjF,KAAK,SAAS,CAAC,KAAK;oBAChB,mCAAmC;oBACnC,OAAO;mGAC4E,CAAC;gBACxF,KAAK,SAAS,CAAC,IAAI;oBACf,OAAO;yEACkD,CAAC;gBAC9D,KAAK,SAAS,CAAC,EAAE;oBACb,OAAO,iGAAiG,CAAC;gBAC7G,KAAK,SAAS,CAAC,OAAO;oBAClB,OAAO;;0DAEmC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,YAAY,EAAE,YAAY,CAAC;gBACrG,KAAK,SAAS,CAAC,GAAG;oBACd,OAAO,qFAAqF,CAAC;gBACjG;oBACI,OAAO,yFAAyF,CAAC;aACxG;QACL,CAAC,CAAC;IAzEmC,CAAC;IAU/B,QAAQ;QACX,IAAI,CAAC,MAAM,CAAC,MAAM;aACb,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,YAAY,gBAAgB,CAAC,EACpD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACV,IAAI,KAAK,GAAsB,KAAM,CAAC,KAAK,CAAC,IAAI,CAAC;YACjD,OAAO,KAAK,CAAC,UAAU,EAAE;gBACrB,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC;aAC5B;YACD,OAAO,KAAK,CAAC;QACjB,CAAC,CAAC,CACL;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,MAAM,aAAa,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC;YAC9C,IAAI,CAAC,aAAa,GAAG,QAAQ,CACzB,aAAa,IAAI,EAAE,EACnB,IAAI,CAAC,UAAU,CAClB,CAAC;QACN,CAAC,CAAC,CAAC;IACX,CAAC;+GA9BQ,sBAAsB;mGAAtB,sBAAsB,0DChCnC,qNAOA;;4FDyBa,sBAAsB;kBAJlC,SAAS;+BACI,oBAAoB","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"]}