@nova-ui/bits
Version:
SolarWinds Nova Framework
124 lines • 17.5 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 { 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"]}