UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

133 lines 28.6 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 { FocusMonitor } from "@angular/cdk/a11y"; import { CdkStepHeader, STEP_STATE } from "@angular/cdk/stepper"; import { ChangeDetectionStrategy, Component, ElementRef, Inject, Input, Optional, ViewEncapsulation, } from "@angular/core"; import assign from "lodash/assign"; import { WIZARD_CONFIG, WIZARD_CONFIG_DEFAULT, } from "../../../constants/wizard.constants"; import { WizardStepV2Component } from "../wizard-step/wizard-step.component"; import { WizardStepLabelDirective } from "../wizard-step-label.directive"; import * as i0 from "@angular/core"; import * as i1 from "@angular/cdk/a11y"; import * as i2 from "@angular/common"; import * as i3 from "../../icon/icon.component"; import * as i4 from "../../tooltip/tooltip.directive"; /** @ignore */ export class WizardStepHeaderComponent extends CdkStepHeader { constructor(_focusMonitor, _elementRef, config) { super(_elementRef); this._focusMonitor = _focusMonitor; this.config = config; /** Label that is rendered below optional steps. */ this.optionalLabel = $localize `Optional`; this.wizardConfig = { ...WIZARD_CONFIG_DEFAULT }; if (this.config) { this.updateStepStateConfig(this.config.stepState); } this.createStepStateConfigMap(); } ngOnChanges(changes) { if (changes?.stepStateConfig?.currentValue) { this.updateStepStateConfig(changes?.stepStateConfig?.currentValue); this.createStepStateConfigMap(); } this.stepState = this.getStepState(this.step); } ngAfterViewInit() { this._focusMonitor.monitor(this._elementRef, true); } ngOnDestroy() { this._focusMonitor.stopMonitoring(this._elementRef); } /** Focuses the step header. */ focus() { this._focusMonitor.focusVia(this._elementRef, "program"); } /** Returns string label of given step if it is a text label. */ get stringLabel() { return this.label instanceof WizardStepLabelDirective ? null : this.label; } /** Returns WizardStepLabel if the label of given step is a template label. */ get templateLabel() { return this.label instanceof WizardStepLabelDirective ? this.label : null; } updateStepStateConfig(stepStateConfig) { this.wizardConfig.stepState = assign({ ...this.wizardConfig.stepState }, stepStateConfig); } createStepStateConfigMap() { this.stepStateConfigMap = { [STEP_STATE.NUMBER]: this.wizardConfig.stepState?.initial, [STEP_STATE.DONE]: this.wizardConfig.stepState?.visited, [STEP_STATE.EDIT]: this.wizardConfig.stepState?.active, [STEP_STATE.ERROR]: this.wizardConfig.stepState?.error, }; } getStepState(step) { const isSelected = this.selected; if (step.hasError && isSelected) { return STEP_STATE.ERROR; } if (isSelected) { return STEP_STATE.EDIT; } if (step.completed) { return STEP_STATE.DONE; } return STEP_STATE.NUMBER; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepHeaderComponent, deps: [{ token: i1.FocusMonitor }, { token: i0.ElementRef }, { token: WIZARD_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardStepHeaderComponent, selector: "nui-wizard-step-header", inputs: { stepStateConfig: "stepStateConfig", label: "label", optionalLabel: "optionalLabel", errorMessage: "errorMessage", index: "index", selected: "selected", active: "active", step: "step" }, host: { attributes: { "role": "tab" }, properties: { "class.nui-wizard-step-header--selected": "selected", "class.nui-wizard-step-header--optional": "step.optional", "class.nui-wizard-step-header--completed": "stepState === 'done'" }, classAttribute: "nui-wizard-step-header" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"nui-wizard-step-header__label\"\n [nuiTooltip]=\"stringLabel ? stringLabel : ''\"\n [class.nui-wizard-step-header__label--active]=\"step.completed\"\n [class.nui-wizard-step-header__label--selected]=\"selected\"\n [class.nui-wizard-step-header__label--error]=\"stepState === 'error'\"\n>\n <!-- If there is a label template, use it. -->\n <ng-container\n *ngIf=\"templateLabel\"\n [ngTemplateOutlet]=\"templateLabel?.template\"\n ></ng-container>\n\n <!-- If there is no label template, fall back to the text label. -->\n <div class=\"nui-wizard-step-header__text-label\" *ngIf=\"stringLabel\">\n {{ label }}\n </div>\n\n <div\n class=\"nui-wizard-step-header__label--optional\"\n *ngIf=\"step.optional && stepState !== 'error'\"\n >\n {{ optionalLabel }}\n </div>\n <div\n class=\"nui-wizard-step-header__label--error\"\n *ngIf=\"stepState === 'error'\"\n >\n {{ errorMessage }}\n </div>\n</div>\n\n<div\n class=\"nui-wizard-step-header-icon nui-step-header-icon-state--{{\n stepState\n }}\"\n>\n <div class=\"nui-wizard-step-header-icon-container\">\n <span class=\"nui-wizard-step-header-icon-content\">\n <ng-container>\n <nui-icon\n [icon]=\"stepStateConfigMap[stepState].icon\"\n [iconColor]=\"stepStateConfigMap[stepState].iconColor\"\n ></nui-icon>\n </ng-container>\n </span>\n </div>\n</div>\n", styles: [".nui-wizard-step-header{overflow:hidden;outline:none;cursor:pointer;position:relative;color:var(--nui-color-text-default,#111);width:145px}.nui-wizard-step-header--completed{color:var(--nui-color-text-link,#0079aa)}.nui-wizard-step-header:focus{outline:none;box-shadow:inset 0 0 0 2px #00c4d280;border-radius:3px}.nui-wizard-step-header:focus:not(:focus-visible){box-shadow:unset;border-radius:unset}.nui-wizard-step-header-icon{height:16px;width:16px;position:relative}.nui-popover-container__content .nui-wizard-step-header-icon{display:flex;align-self:flex-end}.nui-wizard-step-header-icon-content{font-size:16px;height:16px;width:16px;position:relative;top:4px}.nui-wizard-step-header-icon-container .nui-icon{position:relative;top:50%;left:50%;transform:translate(-50%,-50%)}.nui-wizard-step-header__label{display:inline-block;min-width:50px;max-width:130px;vertical-align:middle;padding-bottom:5px;line-height:14px;font-size:11px;white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui-wizard-step-header__label--active{color:var(--nui-color-text-link,#0079aa)}.nui-wizard-step-header__label--selected{color:var(--nui-color-text-default,#111)}.nui-popover-container__content .nui-wizard-step-header__label{padding:0}.nui-wizard-step-header__text-label{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "directive", type: i4.TooltipDirective, selector: "[nuiTooltip]", inputs: ["tooltipPlacement", "nuiTooltipDisabled", "nuiTooltipEllipsis", "nuiTooltip"], exportAs: ["nuiTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepHeaderComponent, decorators: [{ type: Component, args: [{ selector: "nui-wizard-step-header", host: { class: "nui-wizard-step-header", "[class.nui-wizard-step-header--selected]": "selected", "[class.nui-wizard-step-header--optional]": "step.optional", "[class.nui-wizard-step-header--completed]": "stepState === 'done'", role: "tab", }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"nui-wizard-step-header__label\"\n [nuiTooltip]=\"stringLabel ? stringLabel : ''\"\n [class.nui-wizard-step-header__label--active]=\"step.completed\"\n [class.nui-wizard-step-header__label--selected]=\"selected\"\n [class.nui-wizard-step-header__label--error]=\"stepState === 'error'\"\n>\n <!-- If there is a label template, use it. -->\n <ng-container\n *ngIf=\"templateLabel\"\n [ngTemplateOutlet]=\"templateLabel?.template\"\n ></ng-container>\n\n <!-- If there is no label template, fall back to the text label. -->\n <div class=\"nui-wizard-step-header__text-label\" *ngIf=\"stringLabel\">\n {{ label }}\n </div>\n\n <div\n class=\"nui-wizard-step-header__label--optional\"\n *ngIf=\"step.optional && stepState !== 'error'\"\n >\n {{ optionalLabel }}\n </div>\n <div\n class=\"nui-wizard-step-header__label--error\"\n *ngIf=\"stepState === 'error'\"\n >\n {{ errorMessage }}\n </div>\n</div>\n\n<div\n class=\"nui-wizard-step-header-icon nui-step-header-icon-state--{{\n stepState\n }}\"\n>\n <div class=\"nui-wizard-step-header-icon-container\">\n <span class=\"nui-wizard-step-header-icon-content\">\n <ng-container>\n <nui-icon\n [icon]=\"stepStateConfigMap[stepState].icon\"\n [iconColor]=\"stepStateConfigMap[stepState].iconColor\"\n ></nui-icon>\n </ng-container>\n </span>\n </div>\n</div>\n", styles: [".nui-wizard-step-header{overflow:hidden;outline:none;cursor:pointer;position:relative;color:var(--nui-color-text-default,#111);width:145px}.nui-wizard-step-header--completed{color:var(--nui-color-text-link,#0079aa)}.nui-wizard-step-header:focus{outline:none;box-shadow:inset 0 0 0 2px #00c4d280;border-radius:3px}.nui-wizard-step-header:focus:not(:focus-visible){box-shadow:unset;border-radius:unset}.nui-wizard-step-header-icon{height:16px;width:16px;position:relative}.nui-popover-container__content .nui-wizard-step-header-icon{display:flex;align-self:flex-end}.nui-wizard-step-header-icon-content{font-size:16px;height:16px;width:16px;position:relative;top:4px}.nui-wizard-step-header-icon-container .nui-icon{position:relative;top:50%;left:50%;transform:translate(-50%,-50%)}.nui-wizard-step-header__label{display:inline-block;min-width:50px;max-width:130px;vertical-align:middle;padding-bottom:5px;line-height:14px;font-size:11px;white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui-wizard-step-header__label--active{color:var(--nui-color-text-link,#0079aa)}.nui-wizard-step-header__label--selected{color:var(--nui-color-text-default,#111)}.nui-popover-container__content .nui-wizard-step-header__label{padding:0}.nui-wizard-step-header__text-label{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis}\n"] }] }], ctorParameters: () => [{ type: i1.FocusMonitor }, { type: i0.ElementRef }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [WIZARD_CONFIG] }] }], propDecorators: { stepStateConfig: [{ type: Input }], label: [{ type: Input }], optionalLabel: [{ type: Input }], errorMessage: [{ type: Input }], index: [{ type: Input }], selected: [{ type: Input }], active: [{ type: Input }], step: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard-step-header.component.js","sourceRoot":"","sources":["../../../../../src/lib/wizard-v2/wizard-step-header/wizard-step-header.component.ts","../../../../../src/lib/wizard-v2/wizard-step-header/wizard-step-header.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 { FocusMonitor } from \"@angular/cdk/a11y\";\nimport { CdkStepHeader, StepState, STEP_STATE } from \"@angular/cdk/stepper\";\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    Inject,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Optional,\n    SimpleChanges,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport assign from \"lodash/assign\";\n\nimport {\n    WIZARD_CONFIG,\n    WIZARD_CONFIG_DEFAULT,\n} from \"../../../constants/wizard.constants\";\nimport { IWizardConfig, WizardStepStateConfig } from \"../types\";\nimport { WizardStepV2Component } from \"../wizard-step/wizard-step.component\";\nimport { WizardStepLabelDirective } from \"../wizard-step-label.directive\";\n\n/** @ignore */\n@Component({\n    selector: \"nui-wizard-step-header\",\n    templateUrl: \"wizard-step-header.component.html\",\n    styleUrls: [\"wizard-step-header.component.less\"],\n    host: {\n        class: \"nui-wizard-step-header\",\n        \"[class.nui-wizard-step-header--selected]\": \"selected\",\n        \"[class.nui-wizard-step-header--optional]\": \"step.optional\",\n        \"[class.nui-wizard-step-header--completed]\": \"stepState === 'done'\",\n        role: \"tab\",\n    },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WizardStepHeaderComponent\n    extends CdkStepHeader\n    implements AfterViewInit, OnDestroy, OnChanges\n{\n    /** State of the given step. */\n    public stepState: StepState;\n\n    /** Custom icon config received from the wizard step. Allows to customize state icons for a particular wizard step */\n    @Input() stepStateConfig: Partial<WizardStepStateConfig>;\n\n    /** Label of the given step. */\n    @Input() label: WizardStepLabelDirective | string;\n\n    /** Label that is rendered below optional steps. */\n    @Input() optionalLabel: string = $localize`Optional`;\n\n    /** Error message to display when there's an error. */\n    @Input() errorMessage: string;\n\n    /** Index of the given step. */\n    @Input() index: number;\n\n    /** Whether the given step is selected. */\n    @Input() selected: boolean;\n\n    /** Whether the given step label is active. */\n    @Input() active: boolean;\n\n    @Input() step: WizardStepV2Component;\n\n    public stepStateConfigMap: WizardStepStateConfig;\n\n    private wizardConfig: IWizardConfig = { ...WIZARD_CONFIG_DEFAULT };\n\n    constructor(\n        private _focusMonitor: FocusMonitor,\n        _elementRef: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(WIZARD_CONFIG)\n        public readonly config?: IWizardConfig\n    ) {\n        super(_elementRef);\n\n        if (this.config) {\n            this.updateStepStateConfig(this.config.stepState);\n        }\n\n        this.createStepStateConfigMap();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes?.stepStateConfig?.currentValue) {\n            this.updateStepStateConfig(changes?.stepStateConfig?.currentValue);\n            this.createStepStateConfigMap();\n        }\n\n        this.stepState = this.getStepState(this.step);\n    }\n\n    public ngAfterViewInit(): void {\n        this._focusMonitor.monitor(this._elementRef, true);\n    }\n\n    public ngOnDestroy(): void {\n        this._focusMonitor.stopMonitoring(this._elementRef);\n    }\n\n    /** Focuses the step header. */\n    public focus(): void {\n        this._focusMonitor.focusVia(this._elementRef, \"program\");\n    }\n\n    /** Returns string label of given step if it is a text label. */\n    public get stringLabel(): string | null {\n        return this.label instanceof WizardStepLabelDirective\n            ? null\n            : this.label;\n    }\n\n    /** Returns WizardStepLabel if the label of given step is a template label. */\n    public get templateLabel(): WizardStepLabelDirective | null {\n        return this.label instanceof WizardStepLabelDirective\n            ? this.label\n            : null;\n    }\n\n    private updateStepStateConfig(stepStateConfig: WizardStepStateConfig) {\n        this.wizardConfig.stepState = assign(\n            { ...this.wizardConfig.stepState },\n            stepStateConfig\n        );\n    }\n\n    private createStepStateConfigMap() {\n        this.stepStateConfigMap = {\n            [STEP_STATE.NUMBER]: this.wizardConfig.stepState?.initial,\n            [STEP_STATE.DONE]: this.wizardConfig.stepState?.visited,\n            [STEP_STATE.EDIT]: this.wizardConfig.stepState?.active,\n            [STEP_STATE.ERROR]: this.wizardConfig.stepState?.error,\n        };\n    }\n\n    private getStepState(step: WizardStepV2Component): StepState {\n        const isSelected = this.selected;\n\n        if (step.hasError && isSelected) {\n            return STEP_STATE.ERROR;\n        }\n\n        if (isSelected) {\n            return STEP_STATE.EDIT;\n        }\n\n        if (step.completed) {\n            return STEP_STATE.DONE;\n        }\n\n        return STEP_STATE.NUMBER;\n    }\n}\n","<div\n    class=\"nui-wizard-step-header__label\"\n    [nuiTooltip]=\"stringLabel ? stringLabel : ''\"\n    [class.nui-wizard-step-header__label--active]=\"step.completed\"\n    [class.nui-wizard-step-header__label--selected]=\"selected\"\n    [class.nui-wizard-step-header__label--error]=\"stepState === 'error'\"\n>\n    <!-- If there is a label template, use it. -->\n    <ng-container\n        *ngIf=\"templateLabel\"\n        [ngTemplateOutlet]=\"templateLabel?.template\"\n    ></ng-container>\n\n    <!-- If there is no label template, fall back to the text label. -->\n    <div class=\"nui-wizard-step-header__text-label\" *ngIf=\"stringLabel\">\n        {{ label }}\n    </div>\n\n    <div\n        class=\"nui-wizard-step-header__label--optional\"\n        *ngIf=\"step.optional && stepState !== 'error'\"\n    >\n        {{ optionalLabel }}\n    </div>\n    <div\n        class=\"nui-wizard-step-header__label--error\"\n        *ngIf=\"stepState === 'error'\"\n    >\n        {{ errorMessage }}\n    </div>\n</div>\n\n<div\n    class=\"nui-wizard-step-header-icon nui-step-header-icon-state--{{\n        stepState\n    }}\"\n>\n    <div class=\"nui-wizard-step-header-icon-container\">\n        <span class=\"nui-wizard-step-header-icon-content\">\n            <ng-container>\n                <nui-icon\n                    [icon]=\"stepStateConfigMap[stepState].icon\"\n                    [iconColor]=\"stepStateConfigMap[stepState].iconColor\"\n                ></nui-icon>\n            </ng-container>\n        </span>\n    </div>\n</div>\n"]}