UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

124 lines 17.5 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 { CdkStep, CdkStepper, STEPPER_GLOBAL_OPTIONS, } from "@angular/cdk/stepper"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, forwardRef, Inject, Input, Optional, SkipSelf, TemplateRef, ViewEncapsulation, } from "@angular/core"; import { Subject } from "rxjs"; import { takeUntil } from "rxjs/operators"; import { ErrorStateMatcher } from "../error-state-matcher.provider"; import { WizardStepFooterDirective } from "../wizard-step-footer.directive"; import { WizardStepLabelDirective } from "../wizard-step-label.directive"; import * as i0 from "@angular/core"; import * as i1 from "../error-state-matcher.provider"; import * as i2 from "@angular/common"; /** @ignore */ export class WizardStepV2Component extends CdkStep { constructor(changeDetectorRef, stepper, _errorStateMatcher, stepperOptions) { super(stepper, stepperOptions); this.changeDetectorRef = changeDetectorRef; this._errorStateMatcher = _errorStateMatcher; this.destroy$ = new Subject(); } ngOnInit() { this.onControlStatusChanges(); } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } /** Custom error state matcher that additionally checks for validity of interacted form. */ isErrorState(control, form) { const originalErrorState = this._errorStateMatcher.isErrorState(control, form); // Custom error state checks for the validity of form that is not submitted or touched // since user can trigger a form change by calling for another step without directly // interacting with the current form. const customErrorState = !!(control?.invalid && this.interacted); return originalErrorState || customErrorState; } onControlStatusChanges() { if (this.stepControl) { this.stepControl.statusChanges .pipe(takeUntil(this.destroy$)) .subscribe((status) => { if (status === "INVALID") { this.completed = false; } if (status === "VALID") { this.completed = true; } }); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepV2Component, deps: [{ token: i0.ChangeDetectorRef }, { token: forwardRef(() => CdkStepper) }, { token: i1.ErrorStateMatcher, skipSelf: true }, { token: STEPPER_GLOBAL_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardStepV2Component, selector: "nui-wizard-step-v2", inputs: { template: "template", stepStateConfig: "stepStateConfig", stepIndex: "stepIndex" }, providers: [ { provide: ErrorStateMatcher, useExisting: WizardStepV2Component }, { provide: CdkStep, useExisting: WizardStepV2Component }, ], queries: [{ propertyName: "stepLabel", first: true, predicate: WizardStepLabelDirective, descendants: true }, { propertyName: "stepFooter", first: true, predicate: WizardStepFooterDirective, descendants: true }], exportAs: ["nuiWizardStep"], usesInheritance: true, ngImport: i0, template: ` <ng-template> <ng-content *ngIf="!template"></ng-content> <ng-container *ngIf="template"> <ng-container *ngTemplateOutlet="template"></ng-container> </ng-container> </ng-template> `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardStepV2Component, decorators: [{ type: Component, args: [{ selector: "nui-wizard-step-v2", exportAs: "nuiWizardStep", template: ` <ng-template> <ng-content *ngIf="!template"></ng-content> <ng-container *ngIf="template"> <ng-container *ngTemplateOutlet="template"></ng-container> </ng-container> </ng-template> `, providers: [ { provide: ErrorStateMatcher, useExisting: WizardStepV2Component }, { provide: CdkStep, useExisting: WizardStepV2Component }, ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{ type: Inject, args: [forwardRef(() => CdkStepper)] }] }, { type: i1.ErrorStateMatcher, decorators: [{ type: SkipSelf }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [STEPPER_GLOBAL_OPTIONS] }] }], propDecorators: { template: [{ type: Input }], stepStateConfig: [{ type: Input }], stepIndex: [{ type: Input }], stepLabel: [{ type: ContentChild, args: [WizardStepLabelDirective] }], stepFooter: [{ type: ContentChild, args: [WizardStepFooterDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard-step.component.js","sourceRoot":"","sources":["../../../../../src/lib/wizard-v2/wizard-step/wizard-step.component.ts"],"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    CdkStep,\n    CdkStepper,\n    StepperOptions,\n    STEPPER_GLOBAL_OPTIONS,\n} from \"@angular/cdk/stepper\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    forwardRef,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    SkipSelf,\n    TemplateRef,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { FormControl, FormGroupDirective, NgForm } from \"@angular/forms\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\nimport { ErrorStateMatcher } from \"../error-state-matcher.provider\";\nimport { WizardStepStateConfig } from \"../types\";\nimport { WizardStepFooterDirective } from \"../wizard-step-footer.directive\";\nimport { WizardStepLabelDirective } from \"../wizard-step-label.directive\";\n\n/** @ignore */\n@Component({\n    selector: \"nui-wizard-step-v2\",\n    exportAs: \"nuiWizardStep\",\n    template: `\n        <ng-template>\n            <ng-content *ngIf=\"!template\"></ng-content>\n            <ng-container *ngIf=\"template\">\n                <ng-container *ngTemplateOutlet=\"template\"></ng-container>\n            </ng-container>\n        </ng-template>\n    `,\n    providers: [\n        { provide: ErrorStateMatcher, useExisting: WizardStepV2Component },\n        { provide: CdkStep, useExisting: WizardStepV2Component },\n    ],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WizardStepV2Component\n    extends CdkStep\n    implements OnInit, OnDestroy, ErrorStateMatcher\n{\n    @Input() template?: TemplateRef<any>;\n\n    @Input() stepStateConfig: Partial<WizardStepStateConfig>;\n\n    @Input() stepIndex: number;\n\n    /** Content for step label given by `<ng-template wizardStepLabel>`. */\n    @ContentChild(WizardStepLabelDirective)\n    declare stepLabel: WizardStepLabelDirective;\n\n    /** Content for footer given by `<ng-template wizardStepFooter>`. */\n    @ContentChild(WizardStepFooterDirective)\n    stepFooter: WizardStepFooterDirective;\n\n    private readonly destroy$ = new Subject<void>();\n\n    constructor(\n        private changeDetectorRef: ChangeDetectorRef,\n        @Inject(forwardRef(() => CdkStepper)) stepper: any,\n        @SkipSelf() private _errorStateMatcher: ErrorStateMatcher,\n        @Optional()\n        @Inject(STEPPER_GLOBAL_OPTIONS)\n        stepperOptions?: StepperOptions\n    ) {\n        super(stepper, stepperOptions);\n    }\n\n    public ngOnInit(): void {\n        this.onControlStatusChanges();\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    /** Custom error state matcher that additionally checks for validity of interacted form. */\n    public isErrorState(\n        control?: FormControl,\n        form?: FormGroupDirective | NgForm\n    ): boolean {\n        const originalErrorState = this._errorStateMatcher.isErrorState(\n            control,\n            form\n        );\n\n        // Custom error state checks for the validity of form that is not submitted or touched\n        // since user can trigger a form change by calling for another step without directly\n        // interacting with the current form.\n        const customErrorState = !!(control?.invalid && this.interacted);\n\n        return originalErrorState || customErrorState;\n    }\n\n    private onControlStatusChanges(): void {\n        if (this.stepControl) {\n            this.stepControl.statusChanges\n                .pipe(takeUntil(this.destroy$))\n                .subscribe((status) => {\n                    if (status === \"INVALID\") {\n                        this.completed = false;\n                    }\n\n                    if (status === \"VALID\") {\n                        this.completed = true;\n                    }\n                });\n        }\n    }\n}\n"]}