UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

153 lines 30.9 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 { animate, style, transition, trigger } from "@angular/animations"; import { ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, NgZone, Output, ViewEncapsulation, } from "@angular/core"; import { ButtonIcon, SpinnerSize } from "./public-api"; import { LoggerService } from "../../services/log-service"; import * as i0 from "@angular/core"; import * as i1 from "../../services/log-service"; import * as i2 from "@angular/common"; import * as i3 from "../button/button.component"; import * as i4 from "../tooltip/tooltip.directive"; /** * <example-url>./../examples/index.html#/spinner</example-url> */ export class SpinnerComponent { static { this.defaultSize = SpinnerSize.Small; } set size(val) { const sizes = Object.values(SpinnerSize); if (sizes.includes(val)) { this._size = val; return; } this.logger.warn(`Allowed sizes for nui-spinner are ${sizes.join(", ")}. ` + `Default is ${SpinnerComponent.defaultSize}.`); this._size = SpinnerComponent.defaultSize; } get size() { return this._size || SpinnerComponent.defaultSize; } get icon() { return ButtonIcon[this.size]; } get showText() { return this.size !== SpinnerSize.Small; } constructor(logger, changeDetector, ngZone) { this.logger = logger; this.changeDetector = changeDetector; this.ngZone = ngZone; this.tooltipText = $localize `Cancel`; this.showSpinner = false; this.isDeterminate = false; this.show = false; this.delay = 250; /** * Input to set aria label text */ this.ariaLabel = "Spinner"; this.cancel = new EventEmitter(); } ngOnChanges(changes) { if (changes?.percent) { this.ariaValueNow = this.percent ? String(this.percent) : undefined; } if (!changes["show"]) { return; } this.isDeterminate = this.percent !== undefined; this.cancelShowTimer(); if (this.delay && this.show) { this.ngZone.runOutsideAngular(() => { this.showTimer = setTimeout(() => { this.ngZone.run(() => { this.showSpinner = this.show; this.changeDetector.detectChanges(); }); }, this.delay); }); } else { this.showSpinner = this.show; } } cancelShowTimer() { if (this.showTimer) { clearTimeout(this.showTimer); } } cancelProgress() { this.cancel.emit(); } ngOnDestroy() { this.cancelShowTimer(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpinnerComponent, deps: [{ token: i1.LoggerService }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SpinnerComponent, selector: "nui-spinner", inputs: { percent: "percent", show: "show", delay: "delay", allowCancel: "allowCancel", message: "message", helpText: "helpText", ariaLabel: "ariaLabel", size: "size" }, outputs: { cancel: "cancel" }, host: { attributes: { "role": "progressbar", "aria-valuemin": "0", "aria-valuemax": "100" }, properties: { "attr.aria-label": "ariaLabel", "attr.aria-valuenow": "this.ariaValueNow" } }, usesOnChanges: true, ngImport: i0, template: "<span\n class=\"nui-icon-busy-circular nui-spinner nui-spinner__container--{{\n size\n }}\"\n *ngIf=\"showSpinner\"\n [ngClass]=\"{ 'nui-spinner--determinate': isDeterminate }\"\n [@spinnerAppear]\n>\n <div class=\"nui-spinner__container\">\n <svg\n class=\"nui-spinner__circular\"\n viewBox=\"25 25 50 50\"\n *ngIf=\"!isDeterminate\"\n >\n <circle\n class=\"nui-spinner__path-under\"\n cx=\"50\"\n cy=\"50\"\n r=\"22\"\n fill=\"none\"\n stroke-width=\"5\"\n stroke-miterlimit=\"10\"\n />\n <circle\n class=\"nui-spinner__path\"\n cx=\"50\"\n cy=\"50\"\n r=\"22\"\n fill=\"none\"\n stroke-width=\"5\"\n stroke-miterlimit=\"10\"\n />\n </svg>\n <svg\n class=\"nui-spinner__circular\"\n viewBox=\"0 0 36 36\"\n *ngIf=\"isDeterminate\"\n >\n <circle\n class=\"nui-spinner__path-under\"\n cx=\"18\"\n cy=\"18\"\n r=\"15.9155\"\n fill=\"none\"\n stroke-width=\"4\"\n stroke-miterlimit=\"10\"\n />\n <circle\n class=\"nui-spinner__path\"\n cx=\"18\"\n cy=\"18\"\n r=\"15.9155\"\n fill=\"none\"\n stroke-width=\"4\"\n stroke-miterlimit=\"10\"\n [ngStyle]=\"{ 'stroke-dasharray': percent + ', 100' }\"\n />\n </svg>\n\n <button\n nui-button\n type=\"button\"\n class=\"nui-spinner__cancel\"\n icon=\"close\"\n *ngIf=\"allowCancel\"\n (click)=\"cancelProgress()\"\n displayStyle=\"action\"\n [nuiTooltip]=\"tooltipText\"\n ></button>\n </div>\n\n <div class=\"nui-spinner__text-content\" *ngIf=\"showText\">\n <div class=\"nui-spinner__label\" *ngIf=\"message !== undefined\">\n <span class=\"nui-text-label nui-spinner__label-item\">{{\n message\n }}</span>\n </div>\n <span\n class=\"nui-spinner__hint nui-help-hint\"\n *ngIf=\"helpText !== undefined\"\n >\n {{ helpText }}\n </span>\n </div>\n</span>\n", styles: [".nui-spinner{display:inline-flex;align-items:center;position:relative;margin:0 auto;box-sizing:border-box;vertical-align:middle}.nui-spinner__container{display:inline-flex;align-items:center;justify-content:center;position:relative;box-sizing:border-box}.nui-spinner__container--small .nui-spinner__container{width:20px;height:20px}.nui-spinner__container--small .nui-spinner__cancel.nui-button{border-radius:50%;min-height:10px;min-width:10px;padding:0}.nui-spinner__container--large .nui-spinner__container{width:50px;height:50px}.nui-spinner__container--large .nui-spinner__cancel.nui-button{border-radius:50%;min-height:10px;min-width:10px;padding:3px}.nui-spinner__label{margin-left:10px}.nui-spinner__hint{display:block;margin-left:10px}.nui-spinner__circular{position:absolute;width:100%;height:100%;animation:rotate 2s linear infinite;transform-origin:center center;inset:0;margin:auto}.nui-spinner__path-under{stroke:var(--nui-color-line-default,#d9d9d9)}.nui-spinner__path{stroke-dashoffset:0px;animation:dash 1.5s ease-in-out infinite;stroke-linecap:square;stroke:var(--nui-color-progress,#00c4d2)}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:67,200;stroke-dashoffset:-35px}to{stroke-dasharray:134,200;stroke-dashoffset:-134px}}.nui-spinner--determinate .nui-spinner__circular{animation:none}.nui-spinner--determinate .nui-spinner__path{transition:.5s linear;animation:none}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }, { kind: "directive", type: i4.TooltipDirective, selector: "[nuiTooltip]", inputs: ["tooltipPlacement", "nuiTooltipDisabled", "nuiTooltipEllipsis", "nuiTooltip"], exportAs: ["nuiTooltip"] }], animations: [ trigger("spinnerAppear", [ transition(":enter", [ animate(".2s ease-in-out", style({ opacity: 1 })), ]), transition(":leave", [ animate(".2s ease-in-out", style({ opacity: 0 })), ]), ]), ], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SpinnerComponent, decorators: [{ type: Component, args: [{ selector: "nui-spinner", encapsulation: ViewEncapsulation.None, animations: [ trigger("spinnerAppear", [ transition(":enter", [ animate(".2s ease-in-out", style({ opacity: 1 })), ]), transition(":leave", [ animate(".2s ease-in-out", style({ opacity: 0 })), ]), ]), ], host: { role: "progressbar", "aria-valuemin": "0", "aria-valuemax": "100", "[attr.aria-label]": "ariaLabel", }, template: "<span\n class=\"nui-icon-busy-circular nui-spinner nui-spinner__container--{{\n size\n }}\"\n *ngIf=\"showSpinner\"\n [ngClass]=\"{ 'nui-spinner--determinate': isDeterminate }\"\n [@spinnerAppear]\n>\n <div class=\"nui-spinner__container\">\n <svg\n class=\"nui-spinner__circular\"\n viewBox=\"25 25 50 50\"\n *ngIf=\"!isDeterminate\"\n >\n <circle\n class=\"nui-spinner__path-under\"\n cx=\"50\"\n cy=\"50\"\n r=\"22\"\n fill=\"none\"\n stroke-width=\"5\"\n stroke-miterlimit=\"10\"\n />\n <circle\n class=\"nui-spinner__path\"\n cx=\"50\"\n cy=\"50\"\n r=\"22\"\n fill=\"none\"\n stroke-width=\"5\"\n stroke-miterlimit=\"10\"\n />\n </svg>\n <svg\n class=\"nui-spinner__circular\"\n viewBox=\"0 0 36 36\"\n *ngIf=\"isDeterminate\"\n >\n <circle\n class=\"nui-spinner__path-under\"\n cx=\"18\"\n cy=\"18\"\n r=\"15.9155\"\n fill=\"none\"\n stroke-width=\"4\"\n stroke-miterlimit=\"10\"\n />\n <circle\n class=\"nui-spinner__path\"\n cx=\"18\"\n cy=\"18\"\n r=\"15.9155\"\n fill=\"none\"\n stroke-width=\"4\"\n stroke-miterlimit=\"10\"\n [ngStyle]=\"{ 'stroke-dasharray': percent + ', 100' }\"\n />\n </svg>\n\n <button\n nui-button\n type=\"button\"\n class=\"nui-spinner__cancel\"\n icon=\"close\"\n *ngIf=\"allowCancel\"\n (click)=\"cancelProgress()\"\n displayStyle=\"action\"\n [nuiTooltip]=\"tooltipText\"\n ></button>\n </div>\n\n <div class=\"nui-spinner__text-content\" *ngIf=\"showText\">\n <div class=\"nui-spinner__label\" *ngIf=\"message !== undefined\">\n <span class=\"nui-text-label nui-spinner__label-item\">{{\n message\n }}</span>\n </div>\n <span\n class=\"nui-spinner__hint nui-help-hint\"\n *ngIf=\"helpText !== undefined\"\n >\n {{ helpText }}\n </span>\n </div>\n</span>\n", styles: [".nui-spinner{display:inline-flex;align-items:center;position:relative;margin:0 auto;box-sizing:border-box;vertical-align:middle}.nui-spinner__container{display:inline-flex;align-items:center;justify-content:center;position:relative;box-sizing:border-box}.nui-spinner__container--small .nui-spinner__container{width:20px;height:20px}.nui-spinner__container--small .nui-spinner__cancel.nui-button{border-radius:50%;min-height:10px;min-width:10px;padding:0}.nui-spinner__container--large .nui-spinner__container{width:50px;height:50px}.nui-spinner__container--large .nui-spinner__cancel.nui-button{border-radius:50%;min-height:10px;min-width:10px;padding:3px}.nui-spinner__label{margin-left:10px}.nui-spinner__hint{display:block;margin-left:10px}.nui-spinner__circular{position:absolute;width:100%;height:100%;animation:rotate 2s linear infinite;transform-origin:center center;inset:0;margin:auto}.nui-spinner__path-under{stroke:var(--nui-color-line-default,#d9d9d9)}.nui-spinner__path{stroke-dashoffset:0px;animation:dash 1.5s ease-in-out infinite;stroke-linecap:square;stroke:var(--nui-color-progress,#00c4d2)}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:67,200;stroke-dashoffset:-35px}to{stroke-dasharray:134,200;stroke-dashoffset:-134px}}.nui-spinner--determinate .nui-spinner__circular{animation:none}.nui-spinner--determinate .nui-spinner__path{transition:.5s linear;animation:none}\n"] }] }], ctorParameters: () => [{ type: i1.LoggerService }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }], propDecorators: { ariaValueNow: [{ type: HostBinding, args: ["attr.aria-valuenow"] }], percent: [{ type: Input }], show: [{ type: Input }], delay: [{ type: Input }], allowCancel: [{ type: Input }], message: [{ type: Input }], helpText: [{ type: Input }], ariaLabel: [{ type: Input }], cancel: [{ type: Output }], size: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spinner.component.js","sourceRoot":"","sources":["../../../../src/lib/spinner/spinner.component.ts","../../../../src/lib/spinner/spinner.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,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EACH,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EAGN,MAAM,EAEN,iBAAiB,GACpB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;;;;;;AAE3D;;GAEG;AAuBH,MAAM,OAAO,gBAAgB;aACV,gBAAW,GAAgB,WAAW,CAAC,KAAK,AAAjC,CAAkC;IAwB5D,IAAoB,IAAI,CAAC,GAAgB;QACrC,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QAEzC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;YACjB,OAAO;SACV;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CACZ,qCAAqC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI;YACrD,cAAc,gBAAgB,CAAC,WAAW,GAAG,CACpD,CAAC;QAEF,IAAI,CAAC,KAAK,GAAG,gBAAgB,CAAC,WAAW,CAAC;IAC9C,CAAC;IAED,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,KAAK,IAAI,gBAAgB,CAAC,WAAW,CAAC;IACtD,CAAC;IAED,IAAW,IAAI;QACX,OAAO,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,KAAK,CAAC;IAC3C,CAAC;IAED,YACY,MAAqB,EACrB,cAAiC,EACjC,MAAc;QAFd,WAAM,GAAN,MAAM,CAAe;QACrB,mBAAc,GAAd,cAAc,CAAmB;QACjC,WAAM,GAAN,MAAM,CAAQ;QApDnB,gBAAW,GAAG,SAAS,CAAA,QAAQ,CAAC;QAEhC,gBAAW,GAAG,KAAK,CAAC;QACpB,kBAAa,GAAG,KAAK,CAAC;QAKb,SAAI,GAAG,KAAK,CAAC;QACb,UAAK,GAAG,GAAG,CAAC;QAK5B;;WAEG;QACa,cAAS,GAAW,SAAS,CAAC;QAE7B,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAkC1C,CAAC;IAEG,WAAW,CAAC,OAAsB;QACrC,IAAI,OAAO,EAAE,OAAO,EAAE;YAClB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;SACvE;QAED,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAClB,OAAO;SACV;QAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;QAEhD,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,EAAE;YACzB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC/B,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;oBAC7B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;wBACjB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC;wBAC7B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;oBACxC,CAAC,CAAC,CAAC;gBACP,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACnB,CAAC,CAAC,CAAC;SACN;aAAM;YACH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC;SAChC;IACL,CAAC;IAEM,eAAe;QAClB,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAChC;IACL,CAAC;IAEM,cAAc;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;+GAlGQ,gBAAgB;mGAAhB,gBAAgB,2cC/D7B,0gFAqFA,8nEDvCgB;YACR,OAAO,CAAC,eAAe,EAAE;gBACrB,UAAU,CAAC,QAAQ,EAAE;oBACjB,OAAO,CAAC,iBAAiB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;iBACpD,CAAC;gBACF,UAAU,CAAC,QAAQ,EAAE;oBACjB,OAAO,CAAC,iBAAiB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;iBACpD,CAAC;aACL,CAAC;SACL;;4FAQQ,gBAAgB;kBAtB5B,SAAS;+BACI,aAAa,iBAGR,iBAAiB,CAAC,IAAI,cACzB;wBACR,OAAO,CAAC,eAAe,EAAE;4BACrB,UAAU,CAAC,QAAQ,EAAE;gCACjB,OAAO,CAAC,iBAAiB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;6BACpD,CAAC;4BACF,UAAU,CAAC,QAAQ,EAAE;gCACjB,OAAO,CAAC,iBAAiB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;6BACpD,CAAC;yBACL,CAAC;qBACL,QACK;wBACF,IAAI,EAAE,aAAa;wBACnB,eAAe,EAAE,GAAG;wBACpB,eAAe,EAAE,KAAK;wBACtB,mBAAmB,EAAE,WAAW;qBACnC;uIAWkC,YAAY;sBAA9C,WAAW;uBAAC,oBAAoB;gBAEjB,OAAO;sBAAtB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBAKU,SAAS;sBAAxB,KAAK;gBAEW,MAAM;sBAAtB,MAAM;gBAEa,IAAI;sBAAvB,KAAK","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 { animate, style, transition, trigger } from \"@angular/animations\";\nimport {\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    Output,\n    SimpleChanges,\n    ViewEncapsulation,\n} from \"@angular/core\";\n\nimport { ButtonIcon, SpinnerSize } from \"./public-api\";\nimport { LoggerService } from \"../../services/log-service\";\n\n/**\n * <example-url>./../examples/index.html#/spinner</example-url>\n */\n@Component({\n    selector: \"nui-spinner\",\n    templateUrl: \"./spinner.component.html\",\n    styleUrls: [\"./spinner.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n    animations: [\n        trigger(\"spinnerAppear\", [\n            transition(\":enter\", [\n                animate(\".2s ease-in-out\", style({ opacity: 1 })),\n            ]),\n            transition(\":leave\", [\n                animate(\".2s ease-in-out\", style({ opacity: 0 })),\n            ]),\n        ]),\n    ],\n    host: {\n        role: \"progressbar\",\n        \"aria-valuemin\": \"0\",\n        \"aria-valuemax\": \"100\",\n        \"[attr.aria-label]\": \"ariaLabel\",\n    },\n})\nexport class SpinnerComponent implements OnChanges, OnDestroy {\n    private static defaultSize: SpinnerSize = SpinnerSize.Small;\n    private showTimer: any;\n    private _size: SpinnerSize;\n    public tooltipText = $localize`Cancel`;\n\n    public showSpinner = false;\n    public isDeterminate = false;\n\n    @HostBinding(\"attr.aria-valuenow\") ariaValueNow: string | undefined;\n\n    @Input() public percent?: number;\n    @Input() public show = false;\n    @Input() public delay = 250;\n    @Input() public allowCancel?: boolean;\n    @Input() public message?: string;\n    @Input() public helpText?: string;\n\n    /**\n     * Input to set aria label text\n     */\n    @Input() public ariaLabel: string = \"Spinner\";\n\n    @Output() public cancel = new EventEmitter();\n\n    @Input() public set size(val: SpinnerSize) {\n        const sizes = Object.values(SpinnerSize);\n\n        if (sizes.includes(val)) {\n            this._size = val;\n            return;\n        }\n\n        this.logger.warn(\n            `Allowed sizes for nui-spinner are ${sizes.join(\", \")}. ` +\n                `Default is ${SpinnerComponent.defaultSize}.`\n        );\n\n        this._size = SpinnerComponent.defaultSize;\n    }\n\n    public get size(): SpinnerSize {\n        return this._size || SpinnerComponent.defaultSize;\n    }\n\n    public get icon(): ButtonIcon {\n        return ButtonIcon[this.size];\n    }\n\n    public get showText(): boolean {\n        return this.size !== SpinnerSize.Small;\n    }\n\n    constructor(\n        private logger: LoggerService,\n        private changeDetector: ChangeDetectorRef,\n        private ngZone: NgZone\n    ) {}\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes?.percent) {\n            this.ariaValueNow = this.percent ? String(this.percent) : undefined;\n        }\n\n        if (!changes[\"show\"]) {\n            return;\n        }\n\n        this.isDeterminate = this.percent !== undefined;\n\n        this.cancelShowTimer();\n\n        if (this.delay && this.show) {\n            this.ngZone.runOutsideAngular(() => {\n                this.showTimer = setTimeout(() => {\n                    this.ngZone.run(() => {\n                        this.showSpinner = this.show;\n                        this.changeDetector.detectChanges();\n                    });\n                }, this.delay);\n            });\n        } else {\n            this.showSpinner = this.show;\n        }\n    }\n\n    public cancelShowTimer(): void {\n        if (this.showTimer) {\n            clearTimeout(this.showTimer);\n        }\n    }\n\n    public cancelProgress(): void {\n        this.cancel.emit();\n    }\n\n    public ngOnDestroy(): void {\n        this.cancelShowTimer();\n    }\n}\n","<span\n    class=\"nui-icon-busy-circular nui-spinner nui-spinner__container--{{\n        size\n    }}\"\n    *ngIf=\"showSpinner\"\n    [ngClass]=\"{ 'nui-spinner--determinate': isDeterminate }\"\n    [@spinnerAppear]\n>\n    <div class=\"nui-spinner__container\">\n        <svg\n            class=\"nui-spinner__circular\"\n            viewBox=\"25 25 50 50\"\n            *ngIf=\"!isDeterminate\"\n        >\n            <circle\n                class=\"nui-spinner__path-under\"\n                cx=\"50\"\n                cy=\"50\"\n                r=\"22\"\n                fill=\"none\"\n                stroke-width=\"5\"\n                stroke-miterlimit=\"10\"\n            />\n            <circle\n                class=\"nui-spinner__path\"\n                cx=\"50\"\n                cy=\"50\"\n                r=\"22\"\n                fill=\"none\"\n                stroke-width=\"5\"\n                stroke-miterlimit=\"10\"\n            />\n        </svg>\n        <svg\n            class=\"nui-spinner__circular\"\n            viewBox=\"0 0 36 36\"\n            *ngIf=\"isDeterminate\"\n        >\n            <circle\n                class=\"nui-spinner__path-under\"\n                cx=\"18\"\n                cy=\"18\"\n                r=\"15.9155\"\n                fill=\"none\"\n                stroke-width=\"4\"\n                stroke-miterlimit=\"10\"\n            />\n            <circle\n                class=\"nui-spinner__path\"\n                cx=\"18\"\n                cy=\"18\"\n                r=\"15.9155\"\n                fill=\"none\"\n                stroke-width=\"4\"\n                stroke-miterlimit=\"10\"\n                [ngStyle]=\"{ 'stroke-dasharray': percent + ', 100' }\"\n            />\n        </svg>\n\n        <button\n            nui-button\n            type=\"button\"\n            class=\"nui-spinner__cancel\"\n            icon=\"close\"\n            *ngIf=\"allowCancel\"\n            (click)=\"cancelProgress()\"\n            displayStyle=\"action\"\n            [nuiTooltip]=\"tooltipText\"\n        ></button>\n    </div>\n\n    <div class=\"nui-spinner__text-content\" *ngIf=\"showText\">\n        <div class=\"nui-spinner__label\" *ngIf=\"message !== undefined\">\n            <span class=\"nui-text-label nui-spinner__label-item\">{{\n                message\n            }}</span>\n        </div>\n        <span\n            class=\"nui-spinner__hint nui-help-hint\"\n            *ngIf=\"helpText !== undefined\"\n        >\n            {{ helpText }}\n        </span>\n    </div>\n</span>\n"]}