UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

132 lines 17 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, EventEmitter, Input, Output, TemplateRef, } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../busy/busy.component"; import * as i3 from "../spinner/spinner.component"; /** * Component that provides wizard step functionality. */ export class WizardStepComponent { constructor() { /** * Hide step */ this.hidden = false; /** * Evaluated when the step is entered. */ this.enter = new EventEmitter(); /** * Evaluated when validity of the step is changed. */ this.valid = new EventEmitter(); /** * Evaluated when the step is exited. */ this.exit = new EventEmitter(); /** * Evaluated when trying to go to the next step. */ this.next = new EventEmitter(); /** * * Options for busy state. Default: no busy state, with clear empty busy component when set to true */ this.busyConfig = { busy: false, }; this.visited = false; this.active = false; this.complete = false; this.icon = "step"; this.iconColor = ""; this.inputsList = []; /** * Set flags for step entering and emits enter event */ this.enterStep = (event) => { this.enter.emit(event); }; /** * Set flags for step exiting and emits exit event */ this.exitStep = (event) => { this.exit.emit(event); }; this.nextStep = (event) => { this.next.emit(event); }; this.applyEnteringStep = () => { this.active = true; this.icon = "step-active"; this.iconColor = "black"; }; this.applyExitingStep = () => { this.active = false; this.visited = true; this.icon = "step-complete"; this.iconColor = ""; }; } ngOnInit() { this.nextText = this.nextText || $localize `Next`; } ngOnChanges(changes) { if (this.inputsList.length === 0) { this.inputsList = Object.keys(changes); } if (changes["stepControl"]) { this.valid.emit(this.stepControl); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardStepComponent, selector: "nui-wizard-step", inputs: { stepTemplate: "stepTemplate", stepControl: "stepControl", title: "title", shortTitle: "shortTitle", description: "description", nextText: "nextText", hidden: "hidden", disabled: "disabled" }, outputs: { enter: "enter", valid: "valid", exit: "exit", next: "next" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"nui-wizard__step animated\"\n [ngClass]=\"{ 'nui-wizard__step--active': active }\"\n nui-busy\n [busy]=\"busyConfig.busy\"\n>\n <div>\n <h2 class=\"nui-wizard__step-title\">{{ title }}</h2>\n <ng-container *ngTemplateOutlet=\"stepTemplate\"></ng-container>\n </div>\n <nui-spinner\n [percent]=\"busyConfig.percent\"\n [allowCancel]=\"busyConfig.allowCancel\"\n [message]=\"busyConfig.message\"\n >\n </nui-spinner>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.BusyComponent, selector: "[nui-busy]", inputs: ["busy", "disableTabNavigation"] }, { kind: "component", type: i3.SpinnerComponent, selector: "nui-spinner", inputs: ["percent", "show", "delay", "allowCancel", "message", "helpText", "ariaLabel", "size"], outputs: ["cancel"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepComponent, decorators: [{ type: Component, args: [{ selector: "nui-wizard-step", template: "<div\n class=\"nui-wizard__step animated\"\n [ngClass]=\"{ 'nui-wizard__step--active': active }\"\n nui-busy\n [busy]=\"busyConfig.busy\"\n>\n <div>\n <h2 class=\"nui-wizard__step-title\">{{ title }}</h2>\n <ng-container *ngTemplateOutlet=\"stepTemplate\"></ng-container>\n </div>\n <nui-spinner\n [percent]=\"busyConfig.percent\"\n [allowCancel]=\"busyConfig.allowCancel\"\n [message]=\"busyConfig.message\"\n >\n </nui-spinner>\n</div>\n" }] }], ctorParameters: () => [], propDecorators: { stepTemplate: [{ type: Input }], stepControl: [{ type: Input }], title: [{ type: Input }], shortTitle: [{ type: Input }], description: [{ type: Input }], nextText: [{ type: Input }], hidden: [{ type: Input }], disabled: [{ type: Input }], enter: [{ type: Output }], valid: [{ type: Output }], exit: [{ type: Output }], next: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard-step.component.js","sourceRoot":"","sources":["../../../../src/lib/wizard/wizard-step.component.ts","../../../../src/lib/wizard/wizard-step.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 {\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n} from \"@angular/core\";\n\nimport { IWizardSelectionEvent, IWizardStepComponent } from \"./public-api\";\nimport { IBusyConfig } from \"../busy/public-api\";\n\n/**\n * Component that provides wizard step functionality.\n */\n@Component({\n    selector: \"nui-wizard-step\",\n    templateUrl: \"./wizard-step.component.html\",\n})\nexport class WizardStepComponent\n    implements IWizardStepComponent, OnInit, OnChanges\n{\n    /**\n     * Template for step.\n     */\n    @Input() public stepTemplate: TemplateRef<any>;\n    /**\n     * Check is form inside step valid.\n     */\n    @Input() public stepControl?: boolean;\n\n    /**\n     * The title of the step.\n     */\n    @Input() public title: string;\n\n    /**\n     * A more compact form of the title (ex: \"EULA\").\n     */\n    @Input() public shortTitle?: string;\n\n    /**\n     * The description of the step.\n     */\n    @Input() public description?: string;\n\n    /**\n     * Default:'Next'. Text for the Next button.\n     */\n    @Input() public nextText: string;\n    /**\n     * Hide step\n     */\n    @Input() public hidden = false;\n    /**\n     * Disables step\n     */\n    @Input() public disabled?: boolean;\n    /**\n     * Evaluated when the step is entered.\n     */\n    @Output() public enter = new EventEmitter<IWizardSelectionEvent | void>();\n    /**\n     * Evaluated when validity of the step is changed.\n     */\n    @Output() public valid = new EventEmitter<boolean>();\n\n    /**\n     * Evaluated when the step is exited.\n     */\n    @Output() public exit = new EventEmitter<IWizardSelectionEvent | void>();\n    /**\n     * Evaluated when trying to go to the next step.\n     */\n    @Output() public next = new EventEmitter<IWizardSelectionEvent | void>();\n\n    /**\n     *\n     * Options for busy state. Default: no busy state, with clear empty busy component when set to true\n     */\n    public busyConfig: IBusyConfig = {\n        busy: false,\n    };\n\n    public visited = false;\n    public active = false;\n    public complete = false;\n    public icon = \"step\";\n    public iconColor = \"\";\n    public inputsList: string[] = [];\n\n    constructor() {}\n\n    public ngOnInit(): void {\n        this.nextText = this.nextText || $localize`Next`;\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (this.inputsList.length === 0) {\n            this.inputsList = Object.keys(changes);\n        }\n        if (changes[\"stepControl\"]) {\n            this.valid.emit(this.stepControl);\n        }\n    }\n\n    /**\n     * Set flags for step entering and emits enter event\n     */\n    public enterStep = (event?: IWizardSelectionEvent): void => {\n        this.enter.emit(event);\n    };\n\n    /**\n     * Set flags for step exiting and emits exit event\n     */\n    public exitStep = (event?: IWizardSelectionEvent): void => {\n        this.exit.emit(event);\n    };\n\n    public nextStep = (event?: IWizardSelectionEvent): void => {\n        this.next.emit(event);\n    };\n\n    public applyEnteringStep = (): void => {\n        this.active = true;\n        this.icon = \"step-active\";\n        this.iconColor = \"black\";\n    };\n\n    public applyExitingStep = (): void => {\n        this.active = false;\n        this.visited = true;\n        this.icon = \"step-complete\";\n        this.iconColor = \"\";\n    };\n}\n","<div\n    class=\"nui-wizard__step animated\"\n    [ngClass]=\"{ 'nui-wizard__step--active': active }\"\n    nui-busy\n    [busy]=\"busyConfig.busy\"\n>\n    <div>\n        <h2 class=\"nui-wizard__step-title\">{{ title }}</h2>\n        <ng-container *ngTemplateOutlet=\"stepTemplate\"></ng-container>\n    </div>\n    <nui-spinner\n        [percent]=\"busyConfig.percent\"\n        [allowCancel]=\"busyConfig.allowCancel\"\n        [message]=\"busyConfig.message\"\n    >\n    </nui-spinner>\n</div>\n"]}