@nova-ui/bits
Version:
SolarWinds Nova Framework
132 lines • 17 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, } 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"]}