@nova-ui/bits
Version:
SolarWinds Nova Framework
74 lines • 20.7 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, EventEmitter, Input, Output, TemplateRef, ViewEncapsulation, } from "@angular/core";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../button/button.component";
import * as i3 from "../tooltip/tooltip.directive";
/**
* <example-url>./../examples/index.html#/progress</example-url>
*/
export class ProgressComponent {
constructor() {
this.showProgress = true;
this.ariaLabel = "Progress bar";
this.cancel = new EventEmitter();
this.isIndeterminate = false;
}
ngOnChanges() {
this.isIndeterminate = this.percent === undefined;
}
cancelProgress() {
this.cancel.emit();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ProgressComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ProgressComponent, selector: "nui-progress", inputs: { show: "show", showProgress: "showProgress", message: "message", showNumber: "showNumber", percent: "percent", allowCancel: "allowCancel", cancelText: "cancelText", helpText: "helpText", stacked: "stacked", compactMode: "compactMode", ariaLabel: "ariaLabel", helpTemplateRef: "helpTemplateRef" }, outputs: { cancel: "cancel" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"nui-progress\" [class.nui-progress--shown]=\"show\">\n <div\n class=\"nui-progress__header\"\n *ngIf=\"message && !compactMode\"\n [ngClass]=\"{ 'nui-progress__header--stacked': stacked }\"\n >\n <span\n class=\"nui-progress__message nui-text-label nui-progress__header-item\"\n >{{ message }}</span\n >\n </div>\n\n <div\n *ngIf=\"show && showProgress\"\n class=\"nui-progress__container\"\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-valuenow]=\"percent || null\"\n >\n <div\n class=\"nui-progress__bar\"\n [ngClass]=\"{\n 'nui-progress--indeterminate': isIndeterminate,\n 'nui-progress__bar--compact': compactMode\n }\"\n >\n <div\n class=\"nui-progress__bar-value\"\n [ngStyle]=\"{ 'width.%': percent }\"\n ></div>\n </div>\n\n <div\n *ngIf=\"showNumber && !compactMode\"\n class=\"nui-progress__number nui-progress__header-item nui-text-small\"\n >\n {{ percent }}%\n </div>\n\n <button\n nui-button\n type=\"button\"\n class=\"nui-progress__cancel\"\n icon=\"close\"\n *ngIf=\"allowCancel && !compactMode\"\n (click)=\"cancelProgress()\"\n displayStyle=\"action\"\n [nuiTooltip]=\"'Cancel'\"\n ></button>\n </div>\n\n <div\n *ngIf=\"!compactMode\"\n class=\"nui-progress__hint\"\n [class.nui-progress__hint--stacked]=\"stacked\"\n >\n <ng-container\n [ngTemplateOutlet]=\"\n helpTemplateRef ? helpTemplateRef : defaultHelpTemplateRef\n \"\n ></ng-container>\n </div>\n</div>\n\n<ng-template #defaultHelpTemplateRef>\n <span class=\"nui-text-small-secondary\">{{ helpText }}</span>\n</ng-template>\n", styles: [".nui-progress{display:none}.nui-progress--shown{display:block}.nui-progress__header{text-align:center}.nui-progress__header--stacked{text-align:left}.nui-progress__bar{width:100%;background-color:var(--nui-color-bg-workspace,#f0f0f0);height:5px;margin:5px 0}.nui-progress__bar-value{width:0;height:100%;background-color:var(--nui-color-progress,#00c4d2);transition:1s linear;position:relative;overflow:hidden}.nui-progress__bar--compact{margin:0}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:before,.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:after{content:\"\";position:absolute;width:5px;height:5px;background-color:var(--nui-progress-ripple-color,rgba(255, 255, 255, .4));opacity:0;transform:scale(1);border-radius:100%;transform-origin:0 50%;transition:all .5s ease-in-out}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:before{animation:progress-bar-ripple 1.2s ease-in-out .2s infinite}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:after{animation:progress-bar-ripple 1.2s ease-in-out .4s infinite}@keyframes progress-bar-ripple{0%{transform:scaleX(0);opacity:.8}30%{opacity:.3}50%{transform:scaleX(200);opacity:0}to{transform:scaleX(200);opacity:0}}.nui-progress__message{display:block}.nui-progress__hint{text-align:center}.nui-progress__hint--stacked{text-align:left}.nui-progress__hint .nui-text-small-secondary{display:block}.nui-progress__number{position:relative;top:-1px;margin-left:5px}.nui-progress__container{max-height:15px;display:flex;align-items:center}.nui-progress--indeterminate .nui-progress__bar-value{animation-name:indeterminate-progress;animation-duration:1.6s;animation-iteration-count:infinite;animation-timing-function:cubic-bezier(.3,.5,.3,.9)}@keyframes indeterminate-progress{50%{margin-left:25%;width:50%}to{margin-left:100%}}.nui-progress__cancel.nui-button{position:relative;top:-1px;margin-left:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }, { kind: "directive", type: i3.TooltipDirective, selector: "[nuiTooltip]", inputs: ["tooltipPlacement", "nuiTooltipDisabled", "nuiTooltipEllipsis", "nuiTooltip"], exportAs: ["nuiTooltip"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ProgressComponent, decorators: [{
type: Component,
args: [{ selector: "nui-progress", encapsulation: ViewEncapsulation.None, template: "<div class=\"nui-progress\" [class.nui-progress--shown]=\"show\">\n <div\n class=\"nui-progress__header\"\n *ngIf=\"message && !compactMode\"\n [ngClass]=\"{ 'nui-progress__header--stacked': stacked }\"\n >\n <span\n class=\"nui-progress__message nui-text-label nui-progress__header-item\"\n >{{ message }}</span\n >\n </div>\n\n <div\n *ngIf=\"show && showProgress\"\n class=\"nui-progress__container\"\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-valuenow]=\"percent || null\"\n >\n <div\n class=\"nui-progress__bar\"\n [ngClass]=\"{\n 'nui-progress--indeterminate': isIndeterminate,\n 'nui-progress__bar--compact': compactMode\n }\"\n >\n <div\n class=\"nui-progress__bar-value\"\n [ngStyle]=\"{ 'width.%': percent }\"\n ></div>\n </div>\n\n <div\n *ngIf=\"showNumber && !compactMode\"\n class=\"nui-progress__number nui-progress__header-item nui-text-small\"\n >\n {{ percent }}%\n </div>\n\n <button\n nui-button\n type=\"button\"\n class=\"nui-progress__cancel\"\n icon=\"close\"\n *ngIf=\"allowCancel && !compactMode\"\n (click)=\"cancelProgress()\"\n displayStyle=\"action\"\n [nuiTooltip]=\"'Cancel'\"\n ></button>\n </div>\n\n <div\n *ngIf=\"!compactMode\"\n class=\"nui-progress__hint\"\n [class.nui-progress__hint--stacked]=\"stacked\"\n >\n <ng-container\n [ngTemplateOutlet]=\"\n helpTemplateRef ? helpTemplateRef : defaultHelpTemplateRef\n \"\n ></ng-container>\n </div>\n</div>\n\n<ng-template #defaultHelpTemplateRef>\n <span class=\"nui-text-small-secondary\">{{ helpText }}</span>\n</ng-template>\n", styles: [".nui-progress{display:none}.nui-progress--shown{display:block}.nui-progress__header{text-align:center}.nui-progress__header--stacked{text-align:left}.nui-progress__bar{width:100%;background-color:var(--nui-color-bg-workspace,#f0f0f0);height:5px;margin:5px 0}.nui-progress__bar-value{width:0;height:100%;background-color:var(--nui-color-progress,#00c4d2);transition:1s linear;position:relative;overflow:hidden}.nui-progress__bar--compact{margin:0}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:before,.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:after{content:\"\";position:absolute;width:5px;height:5px;background-color:var(--nui-progress-ripple-color,rgba(255, 255, 255, .4));opacity:0;transform:scale(1);border-radius:100%;transform-origin:0 50%;transition:all .5s ease-in-out}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:before{animation:progress-bar-ripple 1.2s ease-in-out .2s infinite}.nui-progress__bar:not(.nui-progress--indeterminate) .nui-progress__bar-value:after{animation:progress-bar-ripple 1.2s ease-in-out .4s infinite}@keyframes progress-bar-ripple{0%{transform:scaleX(0);opacity:.8}30%{opacity:.3}50%{transform:scaleX(200);opacity:0}to{transform:scaleX(200);opacity:0}}.nui-progress__message{display:block}.nui-progress__hint{text-align:center}.nui-progress__hint--stacked{text-align:left}.nui-progress__hint .nui-text-small-secondary{display:block}.nui-progress__number{position:relative;top:-1px;margin-left:5px}.nui-progress__container{max-height:15px;display:flex;align-items:center}.nui-progress--indeterminate .nui-progress__bar-value{animation-name:indeterminate-progress;animation-duration:1.6s;animation-iteration-count:infinite;animation-timing-function:cubic-bezier(.3,.5,.3,.9)}@keyframes indeterminate-progress{50%{margin-left:25%;width:50%}to{margin-left:100%}}.nui-progress__cancel.nui-button{position:relative;top:-1px;margin-left:5px}\n"] }]
}], propDecorators: { show: [{
type: Input
}], showProgress: [{
type: Input
}], message: [{
type: Input
}], showNumber: [{
type: Input
}], percent: [{
type: Input
}], allowCancel: [{
type: Input
}], cancelText: [{
type: Input
}], helpText: [{
type: Input
}], stacked: [{
type: Input
}], compactMode: [{
type: Input
}], ariaLabel: [{
type: Input
}], helpTemplateRef: [{
type: Input
}], cancel: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"","sources":["../../../../src/lib/progress/progress.component.ts","../../../../src/lib/progress/progress.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,EACH,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,WAAW,EACX,iBAAiB,GACpB,MAAM,eAAe,CAAC;;;;;AAEvB;;GAEG;AAOH,MAAM,OAAO,iBAAiB;IAN9B;QAQoB,iBAAY,GAAG,IAAI,CAAC;QASpB,cAAS,GAAW,cAAc,CAAC;QASlC,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAEtC,oBAAe,GAAG,KAAK,CAAC;KAUlC;IAPU,WAAW;QACd,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;IACtD,CAAC;IAEM,cAAc;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;+GA/BQ,iBAAiB;mGAAjB,iBAAiB,0ZCvC9B,0iEAqEA;;4FD9Ba,iBAAiB;kBAN7B,SAAS;+BACI,cAAc,iBAGT,iBAAiB,CAAC,IAAI;8BAGrB,IAAI;sBAAnB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAEW,MAAM;sBAAtB,MAAM","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    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    TemplateRef,\n    ViewEncapsulation,\n} from \"@angular/core\";\n\n/**\n * <example-url>./../examples/index.html#/progress</example-url>\n */\n@Component({\n    selector: \"nui-progress\",\n    templateUrl: \"./progress.component.html\",\n    styleUrls: [\"./progress.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class ProgressComponent implements OnChanges {\n    @Input() public show: boolean;\n    @Input() public showProgress = true;\n    @Input() public message: string;\n    @Input() public showNumber: boolean;\n    @Input() public percent: number;\n    @Input() public allowCancel: boolean;\n    @Input() public cancelText: string;\n    @Input() public helpText?: string;\n    @Input() public stacked: boolean;\n    @Input() public compactMode: boolean;\n    @Input() public ariaLabel: string = \"Progress bar\";\n\n    /**\n     * Help template content displayed under the progress bar.\n     * This can be used instead of the helpText string input for custom\n     * help text styling.\n     */\n    @Input() helpTemplateRef: TemplateRef<any>;\n\n    @Output() public cancel = new EventEmitter();\n\n    public isIndeterminate = false;\n    public ariaValueNow: string | undefined;\n\n    public ngOnChanges(): void {\n        this.isIndeterminate = this.percent === undefined;\n    }\n\n    public cancelProgress(): void {\n        this.cancel.emit();\n    }\n}\n","<div class=\"nui-progress\" [class.nui-progress--shown]=\"show\">\n    <div\n        class=\"nui-progress__header\"\n        *ngIf=\"message && !compactMode\"\n        [ngClass]=\"{ 'nui-progress__header--stacked': stacked }\"\n    >\n        <span\n            class=\"nui-progress__message nui-text-label nui-progress__header-item\"\n            >{{ message }}</span\n        >\n    </div>\n\n    <div\n        *ngIf=\"show && showProgress\"\n        class=\"nui-progress__container\"\n        role=\"progressbar\"\n        aria-valuemin=\"0\"\n        aria-valuemax=\"100\"\n        [attr.aria-label]=\"ariaLabel\"\n        [attr.aria-valuenow]=\"percent || null\"\n    >\n        <div\n            class=\"nui-progress__bar\"\n            [ngClass]=\"{\n                'nui-progress--indeterminate': isIndeterminate,\n                'nui-progress__bar--compact': compactMode\n            }\"\n        >\n            <div\n                class=\"nui-progress__bar-value\"\n                [ngStyle]=\"{ 'width.%': percent }\"\n            ></div>\n        </div>\n\n        <div\n            *ngIf=\"showNumber && !compactMode\"\n            class=\"nui-progress__number nui-progress__header-item nui-text-small\"\n        >\n            {{ percent }}%\n        </div>\n\n        <button\n            nui-button\n            type=\"button\"\n            class=\"nui-progress__cancel\"\n            icon=\"close\"\n            *ngIf=\"allowCancel && !compactMode\"\n            (click)=\"cancelProgress()\"\n            displayStyle=\"action\"\n            [nuiTooltip]=\"'Cancel'\"\n        ></button>\n    </div>\n\n    <div\n        *ngIf=\"!compactMode\"\n        class=\"nui-progress__hint\"\n        [class.nui-progress__hint--stacked]=\"stacked\"\n    >\n        <ng-container\n            [ngTemplateOutlet]=\"\n                helpTemplateRef ? helpTemplateRef : defaultHelpTemplateRef\n            \"\n        ></ng-container>\n    </div>\n</div>\n\n<ng-template #defaultHelpTemplateRef>\n    <span class=\"nui-text-small-secondary\">{{ helpText }}</span>\n</ng-template>\n"]}