@testgorilla/tgo-ui 2.0.7 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/accordion/accordion.component.module.d.ts +1 -1
- package/components/dialog/dialog.component.d.ts +17 -1
- package/components/dialog/dialog.service.d.ts +1 -1
- package/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.d.ts +22 -0
- package/components/navbar/navbar.component.d.ts +34 -4
- package/components/navbar/navbar.component.module.d.ts +4 -1
- package/components/side-sheet/side-sheet.component.d.ts +1 -0
- package/components/side-sheet/side-sheet.component.module.d.ts +2 -1
- package/components/side-sheet/side-sheet.model.d.ts +4 -1
- package/components/side-sheet/side-sheet.service.d.ts +1 -1
- package/components/stepper/stepper.model.d.ts +0 -3
- package/esm2022/components/accordion/accordion.component.module.mjs +5 -2
- package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +1 -1
- package/esm2022/components/dialog/dialog.component.mjs +23 -3
- package/esm2022/components/dialog/dialog.service.mjs +5 -3
- package/esm2022/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.mjs +75 -0
- package/esm2022/components/navbar/navbar.component.mjs +81 -17
- package/esm2022/components/navbar/navbar.component.module.mjs +15 -3
- package/esm2022/components/page-header/page-header.component.mjs +2 -2
- package/esm2022/components/side-sheet/side-sheet.component.mjs +13 -5
- package/esm2022/components/side-sheet/side-sheet.component.module.mjs +7 -3
- package/esm2022/components/side-sheet/side-sheet.model.mjs +1 -1
- package/esm2022/components/side-sheet/side-sheet.service.mjs +2 -1
- package/esm2022/components/stepper/stepper.component.mjs +2 -2
- package/esm2022/components/stepper/stepper.model.mjs +2 -5
- package/esm2022/models/screen-breakpoints.model.mjs +5 -0
- package/esm2022/providers/is-mobile.mjs +11 -0
- package/fesm2022/testgorilla-tgo-ui.mjs +507 -343
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/models/screen-breakpoints.model.d.ts +3 -0
- package/package.json +1 -1
- package/esm2022/components/stepper/providers/is-mobile.mjs +0 -11
- /package/{components/stepper/providers → providers}/is-mobile.d.ts +0 -0
|
@@ -11,6 +11,7 @@ export class SideSheetService {
|
|
|
11
11
|
const rootViewContainerRef = this.applicationRef.components[0].injector.get(ViewContainerRef);
|
|
12
12
|
const componentReference = rootViewContainerRef.createComponent(config.componentRef);
|
|
13
13
|
this.componentRef$.next({ ...configFields, componentRef: componentReference });
|
|
14
|
+
return componentReference.instance;
|
|
14
15
|
}
|
|
15
16
|
close() {
|
|
16
17
|
this.componentRef$.next(null);
|
|
@@ -27,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
27
28
|
providedIn: 'root',
|
|
28
29
|
}]
|
|
29
30
|
}], ctorParameters: function () { return [{ type: i0.ApplicationRef }]; } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1zaGVldC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvc2lkZS1zaGVldC9zaWRlLXNoZWV0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFrQixVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFN0UsT0FBTyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUczQixZQUFvQixjQUE4QjtRQUE5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFGMUMsa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBMEIsQ0FBQztJQUVULENBQUM7SUFFdEQsSUFBSSxDQUFJLE1BQXVCO1FBQzdCLE1BQU0sRUFBRSxZQUFZLEVBQUUsR0FBRyxZQUFZLEVBQUUsR0FBRyxNQUFNLENBQUM7UUFDakQsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDOUYsTUFBTSxrQkFBa0IsR0FBRyxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JGLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxZQUFZLEVBQUUsWUFBWSxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQztRQUMvRSxPQUFPLGtCQUFrQixDQUFDLFFBQWEsQ0FBQztJQUMxQyxDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxlQUFlO1FBQ2IsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzNDLENBQUM7K0dBbkJVLGdCQUFnQjttSEFBaEIsZ0JBQWdCLGNBRmYsTUFBTTs7NEZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcGxpY2F0aW9uUmVmLCBJbmplY3RhYmxlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTaWRlU2hlZXRDb25maWcgfSBmcm9tICcuL3NpZGUtc2hlZXQubW9kZWwnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgU2lkZVNoZWV0U2VydmljZSB7XG4gIHByaXZhdGUgY29tcG9uZW50UmVmJCA9IG5ldyBTdWJqZWN0PFNpZGVTaGVldENvbmZpZyB8IG51bGw+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhcHBsaWNhdGlvblJlZjogQXBwbGljYXRpb25SZWYpIHt9XG5cbiAgb3BlbjxUPihjb25maWc6IFNpZGVTaGVldENvbmZpZyk6IFQge1xuICAgIGNvbnN0IHsgY29tcG9uZW50UmVmLCAuLi5jb25maWdGaWVsZHMgfSA9IGNvbmZpZztcbiAgICBjb25zdCByb290Vmlld0NvbnRhaW5lclJlZiA9IHRoaXMuYXBwbGljYXRpb25SZWYuY29tcG9uZW50c1swXS5pbmplY3Rvci5nZXQoVmlld0NvbnRhaW5lclJlZik7XG4gICAgY29uc3QgY29tcG9uZW50UmVmZXJlbmNlID0gcm9vdFZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50KGNvbmZpZy5jb21wb25lbnRSZWYpO1xuICAgIHRoaXMuY29tcG9uZW50UmVmJC5uZXh0KHsgLi4uY29uZmlnRmllbGRzLCBjb21wb25lbnRSZWY6IGNvbXBvbmVudFJlZmVyZW5jZSB9KTtcbiAgICByZXR1cm4gY29tcG9uZW50UmVmZXJlbmNlLmluc3RhbmNlIGFzIFQ7XG4gIH1cblxuICBjbG9zZSgpOiB2b2lkIHtcbiAgICB0aGlzLmNvbXBvbmVudFJlZiQubmV4dChudWxsKTtcbiAgfVxuXG4gIGdldENvbXBvbmVudFJlZigpOiBPYnNlcnZhYmxlPFNpZGVTaGVldENvbmZpZyB8IG51bGw+IHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYkLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
|
|
2
|
-
import { IS_MOBILE_TOKEN } from '
|
|
2
|
+
import { IS_MOBILE_TOKEN } from '../../providers/is-mobile';
|
|
3
3
|
import { LanguageService } from '../../utils/localization/language.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
121
121
|
}], selectionChange: [{
|
|
122
122
|
type: Output
|
|
123
123
|
}] } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../src/components/stepper/stepper.component.ts","../../../../../src/components/stepper/stepper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGlH,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;;AAS5E,MAAM,OAAO,gBAAgB;IAC3B;;;;;OAKG;IACH,IAAa,KAAK,CAAC,SAAiB;QAClC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,MAAM,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,GAAG,SAAS,CAAC;QACpC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,CAAC;IACrC,CAAC;IA0DD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,MAAM,CAAC,KAAc;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,YAC6E,eAAiC,EAChE,SAA8B;QADC,oBAAe,GAAf,eAAe,CAAkB;QAChE,cAAS,GAAT,SAAS,CAAqB;QAlE5E;;;;;WAKG;QACM,kBAAa,GAAG,CAAC,CAAC;QAE3B;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAEnC;;;;;WAKG;QACM,aAAQ,GAAG,eAAe,CAAC,eAAe,CAAC;QAEpD;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAEpB,oBAAe,GAAG,IAAI,YAAY,EAAgE,CAAC;QAErG,aAAQ,GAAG,KAAK,CAAC;QACf,cAAS,GAAW,EAAE,CAAC;QACvB,kBAAa,GAAG,CAAC,CAAC;QAClB,uBAAkB,GAAG,UAAU,CAAC;QAcxC,IAAI,eAAe,EAAE;YACnB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;SACzC;IACH,CAAC;IAES,QAAQ,CAAC,YAAoB,EAAE,IAAU;QACjD,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,KAAK,YAAY,EAAE;YAC1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAEpG,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;IAC7B,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;+GAvGU,gBAAgB,kBA+EL,oCAAoC,6BAChD,eAAe;mGAhFd,gBAAgB,yTCb7B,q9GA+EA;;4FDlEa,gBAAgB;kBAN5B,SAAS;+BACE,YAAY,mBAGL,uBAAuB,CAAC,MAAM;;0BAiF5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BACvD,MAAM;2BAAC,eAAe;4CAzEZ,KAAK;sBAAjB,KAAK;gBAaG,aAAa;sBAArB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBASG,gBAAgB;sBAAxB,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBAEI,eAAe;sBAAxB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';\nimport { Step } from './stepper.model';\nimport { Observable } from 'rxjs';\nimport { IS_MOBILE_TOKEN } from './providers/is-mobile';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-stepper',\n  templateUrl: './stepper.component.html',\n  styleUrls: ['./stepper.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class StepperComponent {\n  /**\n   * Input property to set the steps for the stepper.\n   * The first step will be marked as visited automatically.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() set steps(itemSteps: Step[]) {\n    this.itemSteps = itemSteps;\n    const [first, ...other] = itemSteps;\n    first.isVisited = true;\n    this.itemSteps = [first, ...other];\n  }\n\n  /**\n   * Input property to set the selected index of the stepper.\n   * Default value is 0.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() selectedIndex = 0;\n\n  /**\n   * Input property indicating whether the final icon should be displayed.\n   * Default value is false.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() lastStepFinalIcon = false;\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof StepperComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof StepperComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof StepperComponent\n   */\n  @Input() ariaLabel: string;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used to indicate whether an input field is required for form submission.\n   * @type {boolean}\n   * @memberof StepperComponent\n   */\n  @Input() ariaRequired = false;\n\n  @Output() selectionChange = new EventEmitter<{ selectedIndex: number; previousIndex: number; step: Step }>();\n\n  private isOpened = false;\n  protected itemSteps: Step[] = [];\n  protected progressValue = 0;\n  protected translationContext = 'STEPPER.';\n\n  get isOpen(): boolean {\n    return this.isOpened;\n  }\n\n  set isOpen(value: boolean) {\n    this.isOpened = value;\n  }\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  protected onSelect(changedIndex: number, step: Step): void {\n    if (!step.isVisited && this.selectedIndex !== changedIndex) {\n      step.isVisited = true;\n    }\n    this.selectionChange.emit({ selectedIndex: changedIndex, previousIndex: this.selectedIndex, step });\n\n    this.selectedIndex = changedIndex;\n    this.onCloseStepList();\n  }\n\n  protected showStepsToggle(): void {\n    this.isOpen = !this.isOpen;\n  }\n\n  protected onCloseStepList(): void {\n    this.isOpen = false;\n  }\n}\n","<ng-container>\n  <div class=\"stepper-wrapper\" [attr.theme]=\"applicationTheme\" *ngIf=\"!(isMobile$ | async); else mobile\">\n    <ng-container *ngFor=\"let step of itemSteps; index as i, last as isLast\">\n      <div class=\"step\" #stepElement>\n        <ui-step\n          [label]=\"step.label\"\n          [isVisited]=\"step.isVisited!\"\n          [icon]=\"step.iconName\"\n          [index]=\"i\"\n          [selected]=\"i === selectedIndex\"\n          [selectedIndex]=\"selectedIndex\"\n          [isLast]=\"isLast\"\n          [disabled]=\"step.disabled ?? (i > selectedIndex + 1 && !step.isVisited)\"\n          [prevStepIsVisited]=\"itemSteps[i - 1]?.isVisited && step.isVisited\"\n          [finalIcon]=\"isLast ? lastStepFinalIcon : false\"\n          [showIconWhenSelected]=\"!!step.showIconWhenSelected\"\n          (stepSelected)=\"onSelect($event, step)\"\n          [applicationTheme]=\"applicationTheme\"\n          [attr.aria-label]=\"ariaLabel + '--' + step.label\"\n        ></ui-step>\n      </div>\n      <div *ngIf=\"!isLast\" class=\"separator-line\" [ngClass]=\"{ visited: step.isVisited && !!this.itemSteps[i + 1]?.isVisited }\">\n        <div [stepLineWidth]=\"stepElement\" class=\"line\"></div>\n      </div>\n    </ng-container>\n  </div>\n\n  <ng-template #mobile>\n    <div class=\"mobile-stepper-wrapper\">\n      <div class=\"stepper\">\n        <div class=\"progress-step\">\n          <ui-radial-progress [applicationTheme]=\"applicationTheme\" [value]=\"selectedIndex + 1\" [total]=\"itemSteps.length\"></ui-radial-progress>\n        </div>\n\n        <div class=\"step-info\">\n          <div class=\"current-step\">\n            <span>{{ selectedIndex + 1 }}/{{ itemSteps.length }} </span>\n            <span>{{ itemSteps[selectedIndex].label }}</span>\n          </div>\n          <div class=\"next-step\">\n            <span *ngIf=\"itemSteps.length !== selectedIndex + 1 else finalStep\">{{ (('COMMON.NEXT') | uiTranslate : language) + ':'}} {{ itemSteps[selectedIndex + 1].label }}</span>\n            <ng-template #finalStep>\n              <span>{{ (translationContext + 'FINAL_STEP') | uiTranslate : language }}</span>\n            </ng-template>\n          </div>\n        </div>\n\n        <div class=\"open-steps\" (click)=\"showStepsToggle()\" [ngClass]=\"{ opened: isOpen }\">\n          <ui-icon [size]=\"'24'\" [name]=\"'Arrow_down'\"></ui-icon>\n        </div>\n      </div>\n\n      <div *ngIf=\"isOpen\">\n        <div class=\"step-list\">\n          <div class=\"step\" *ngFor=\"let step of itemSteps; index as i, last as isLast\">\n            <ui-step\n              [label]=\"step.label\"\n              [isVisited]=\"step.isVisited!\"\n              [icon]=\"step.iconName\"\n              [index]=\"i\"\n              [selected]=\"i === selectedIndex\"\n              [selectedIndex]=\"selectedIndex\"\n              [isLast]=\"isLast\"\n              [disabled]=\"step.disabled ?? ( i > selectedIndex + 1 && !step.isVisited)\"\n              [mobileMode]=\"true\"\n              [finalIcon]=\"isLast ? lastStepFinalIcon : false\"\n              [showIconWhenSelected]=\"!!step.showIconWhenSelected\"\n              (stepSelected)=\"onSelect($event, step)\"\n              [applicationTheme]=\"applicationTheme\"\n              [attr.aria-label]=\"ariaLabel + '--' + step.label\"\n            ></ui-step>\n          </div>\n        </div>\n        <div class=\"overlay\" (click)=\"onCloseStepList()\"></div>\n      </div>\n    </div>\n  </ng-template>\n\n</ng-container>\n"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../src/components/stepper/stepper.component.ts","../../../../../src/components/stepper/stepper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGlH,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;;AAS5E,MAAM,OAAO,gBAAgB;IAC3B;;;;;OAKG;IACH,IAAa,KAAK,CAAC,SAAiB;QAClC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,MAAM,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,GAAG,SAAS,CAAC;QACpC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,CAAC;IACrC,CAAC;IA0DD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,MAAM,CAAC,KAAc;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,YAC6E,eAAiC,EAChE,SAA8B;QADC,oBAAe,GAAf,eAAe,CAAkB;QAChE,cAAS,GAAT,SAAS,CAAqB;QAlE5E;;;;;WAKG;QACM,kBAAa,GAAG,CAAC,CAAC;QAE3B;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAEnC;;;;;WAKG;QACM,aAAQ,GAAG,eAAe,CAAC,eAAe,CAAC;QAEpD;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAEpB,oBAAe,GAAG,IAAI,YAAY,EAAgE,CAAC;QAErG,aAAQ,GAAG,KAAK,CAAC;QACf,cAAS,GAAW,EAAE,CAAC;QACvB,kBAAa,GAAG,CAAC,CAAC;QAClB,uBAAkB,GAAG,UAAU,CAAC;QAcxC,IAAI,eAAe,EAAE;YACnB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;SACzC;IACH,CAAC;IAES,QAAQ,CAAC,YAAoB,EAAE,IAAU;QACjD,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,KAAK,YAAY,EAAE;YAC1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAEpG,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;IAC7B,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;+GAvGU,gBAAgB,kBA+EL,oCAAoC,6BAChD,eAAe;mGAhFd,gBAAgB,yTCb7B,q9GA+EA;;4FDlEa,gBAAgB;kBAN5B,SAAS;+BACE,YAAY,mBAGL,uBAAuB,CAAC,MAAM;;0BAiF5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BACvD,MAAM;2BAAC,eAAe;4CAzEZ,KAAK;sBAAjB,KAAK;gBAaG,aAAa;sBAArB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBASG,gBAAgB;sBAAxB,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBAEI,eAAe;sBAAxB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';\nimport { Step } from './stepper.model';\nimport { Observable } from 'rxjs';\nimport { IS_MOBILE_TOKEN } from '../../providers/is-mobile';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-stepper',\n  templateUrl: './stepper.component.html',\n  styleUrls: ['./stepper.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class StepperComponent {\n  /**\n   * Input property to set the steps for the stepper.\n   * The first step will be marked as visited automatically.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() set steps(itemSteps: Step[]) {\n    this.itemSteps = itemSteps;\n    const [first, ...other] = itemSteps;\n    first.isVisited = true;\n    this.itemSteps = [first, ...other];\n  }\n\n  /**\n   * Input property to set the selected index of the stepper.\n   * Default value is 0.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() selectedIndex = 0;\n\n  /**\n   * Input property indicating whether the final icon should be displayed.\n   * Default value is false.\n   *\n   * @memberof StepperComponent\n   */\n  @Input() lastStepFinalIcon = false;\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof StepperComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof StepperComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof StepperComponent\n   */\n  @Input() ariaLabel: string;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used to indicate whether an input field is required for form submission.\n   * @type {boolean}\n   * @memberof StepperComponent\n   */\n  @Input() ariaRequired = false;\n\n  @Output() selectionChange = new EventEmitter<{ selectedIndex: number; previousIndex: number; step: Step }>();\n\n  private isOpened = false;\n  protected itemSteps: Step[] = [];\n  protected progressValue = 0;\n  protected translationContext = 'STEPPER.';\n\n  get isOpen(): boolean {\n    return this.isOpened;\n  }\n\n  set isOpen(value: boolean) {\n    this.isOpened = value;\n  }\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  protected onSelect(changedIndex: number, step: Step): void {\n    if (!step.isVisited && this.selectedIndex !== changedIndex) {\n      step.isVisited = true;\n    }\n    this.selectionChange.emit({ selectedIndex: changedIndex, previousIndex: this.selectedIndex, step });\n\n    this.selectedIndex = changedIndex;\n    this.onCloseStepList();\n  }\n\n  protected showStepsToggle(): void {\n    this.isOpen = !this.isOpen;\n  }\n\n  protected onCloseStepList(): void {\n    this.isOpen = false;\n  }\n}\n","<ng-container>\n  <div class=\"stepper-wrapper\" [attr.theme]=\"applicationTheme\" *ngIf=\"!(isMobile$ | async); else mobile\">\n    <ng-container *ngFor=\"let step of itemSteps; index as i, last as isLast\">\n      <div class=\"step\" #stepElement>\n        <ui-step\n          [label]=\"step.label\"\n          [isVisited]=\"step.isVisited!\"\n          [icon]=\"step.iconName\"\n          [index]=\"i\"\n          [selected]=\"i === selectedIndex\"\n          [selectedIndex]=\"selectedIndex\"\n          [isLast]=\"isLast\"\n          [disabled]=\"step.disabled ?? (i > selectedIndex + 1 && !step.isVisited)\"\n          [prevStepIsVisited]=\"itemSteps[i - 1]?.isVisited && step.isVisited\"\n          [finalIcon]=\"isLast ? lastStepFinalIcon : false\"\n          [showIconWhenSelected]=\"!!step.showIconWhenSelected\"\n          (stepSelected)=\"onSelect($event, step)\"\n          [applicationTheme]=\"applicationTheme\"\n          [attr.aria-label]=\"ariaLabel + '--' + step.label\"\n        ></ui-step>\n      </div>\n      <div *ngIf=\"!isLast\" class=\"separator-line\" [ngClass]=\"{ visited: step.isVisited && !!this.itemSteps[i + 1]?.isVisited }\">\n        <div [stepLineWidth]=\"stepElement\" class=\"line\"></div>\n      </div>\n    </ng-container>\n  </div>\n\n  <ng-template #mobile>\n    <div class=\"mobile-stepper-wrapper\">\n      <div class=\"stepper\">\n        <div class=\"progress-step\">\n          <ui-radial-progress [applicationTheme]=\"applicationTheme\" [value]=\"selectedIndex + 1\" [total]=\"itemSteps.length\"></ui-radial-progress>\n        </div>\n\n        <div class=\"step-info\">\n          <div class=\"current-step\">\n            <span>{{ selectedIndex + 1 }}/{{ itemSteps.length }} </span>\n            <span>{{ itemSteps[selectedIndex].label }}</span>\n          </div>\n          <div class=\"next-step\">\n            <span *ngIf=\"itemSteps.length !== selectedIndex + 1 else finalStep\">{{ (('COMMON.NEXT') | uiTranslate : language) + ':'}} {{ itemSteps[selectedIndex + 1].label }}</span>\n            <ng-template #finalStep>\n              <span>{{ (translationContext + 'FINAL_STEP') | uiTranslate : language }}</span>\n            </ng-template>\n          </div>\n        </div>\n\n        <div class=\"open-steps\" (click)=\"showStepsToggle()\" [ngClass]=\"{ opened: isOpen }\">\n          <ui-icon [size]=\"'24'\" [name]=\"'Arrow_down'\"></ui-icon>\n        </div>\n      </div>\n\n      <div *ngIf=\"isOpen\">\n        <div class=\"step-list\">\n          <div class=\"step\" *ngFor=\"let step of itemSteps; index as i, last as isLast\">\n            <ui-step\n              [label]=\"step.label\"\n              [isVisited]=\"step.isVisited!\"\n              [icon]=\"step.iconName\"\n              [index]=\"i\"\n              [selected]=\"i === selectedIndex\"\n              [selectedIndex]=\"selectedIndex\"\n              [isLast]=\"isLast\"\n              [disabled]=\"step.disabled ?? ( i > selectedIndex + 1 && !step.isVisited)\"\n              [mobileMode]=\"true\"\n              [finalIcon]=\"isLast ? lastStepFinalIcon : false\"\n              [showIconWhenSelected]=\"!!step.showIconWhenSelected\"\n              (stepSelected)=\"onSelect($event, step)\"\n              [applicationTheme]=\"applicationTheme\"\n              [attr.aria-label]=\"ariaLabel + '--' + step.label\"\n            ></ui-step>\n          </div>\n        </div>\n        <div class=\"overlay\" (click)=\"onCloseStepList()\"></div>\n      </div>\n    </div>\n  </ng-template>\n\n</ng-container>\n"]}
|
|
@@ -1,5 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
3
|
-
ScreenBreakpoints[ScreenBreakpoints["MOBILE"] = 600] = "MOBILE";
|
|
4
|
-
})(ScreenBreakpoints || (ScreenBreakpoints = {}));
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3N0ZXBwZXIvc3RlcHBlci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXQSxNQUFNLENBQU4sSUFBWSxpQkFFWDtBQUZELFdBQVksaUJBQWlCO0lBQzNCLCtEQUFZLENBQUE7QUFDZCxDQUFDLEVBRlcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQUU1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBTdGVwIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgaXNWaXNpdGVkPzogYm9vbGVhbjtcbiAgaWNvbk5hbWU/OiBJY29uTmFtZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBzdWJtaXR0ZWQ/OiBib29sZWFuO1xuICBzaG93SWNvbldoZW5TZWxlY3RlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBlbnVtIFNjcmVlbkJyZWFrcG9pbnRzIHtcbiAgTU9CSUxFID0gNjAwLFxufVxuIl19
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3N0ZXBwZXIvc3RlcHBlci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbk5hbWUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kZWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0ZXAge1xuICBsYWJlbDogc3RyaW5nO1xuICBpc1Zpc2l0ZWQ/OiBib29sZWFuO1xuICBpY29uTmFtZT86IEljb25OYW1lO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG4gIHN1Ym1pdHRlZD86IGJvb2xlYW47XG4gIHNob3dJY29uV2hlblNlbGVjdGVkPzogYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export var ScreenBreakpoints;
|
|
2
|
+
(function (ScreenBreakpoints) {
|
|
3
|
+
ScreenBreakpoints[ScreenBreakpoints["MOBILE"] = 600] = "MOBILE";
|
|
4
|
+
})(ScreenBreakpoints || (ScreenBreakpoints = {}));
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLWJyZWFrcG9pbnRzLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL21vZGVscy9zY3JlZW4tYnJlYWtwb2ludHMubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksaUJBRVg7QUFGRCxXQUFZLGlCQUFpQjtJQUMzQiwrREFBWSxDQUFBO0FBQ2QsQ0FBQyxFQUZXLGlCQUFpQixLQUFqQixpQkFBaUIsUUFFNUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBTY3JlZW5CcmVha3BvaW50cyB7XG4gIE1PQklMRSA9IDYwMCxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { inject, InjectionToken } from '@angular/core';
|
|
2
|
+
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
3
|
+
import { map } from 'rxjs';
|
|
4
|
+
import { ScreenBreakpoints } from '../models/screen-breakpoints.model';
|
|
5
|
+
export const IS_MOBILE_TOKEN = new InjectionToken('Is mobile', {
|
|
6
|
+
factory: () => {
|
|
7
|
+
const breakpointObserver = inject(BreakpointObserver);
|
|
8
|
+
return breakpointObserver.observe(`(max-width: ${ScreenBreakpoints.MOBILE}px)`).pipe(map(v => v.matches));
|
|
9
|
+
},
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtbW9iaWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3Byb3ZpZGVycy9pcy1tb2JpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMzQixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUV2RSxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsSUFBSSxjQUFjLENBQUMsV0FBVyxFQUFFO0lBQzdELE9BQU8sRUFBRSxHQUFHLEVBQUU7UUFDWixNQUFNLGtCQUFrQixHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3RELE9BQU8sa0JBQWtCLENBQUMsT0FBTyxDQUFDLGVBQWUsaUJBQWlCLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDNUcsQ0FBQztDQUNGLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJyZWFrcG9pbnRPYnNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9sYXlvdXQnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBTY3JlZW5CcmVha3BvaW50cyB9IGZyb20gJy4uL21vZGVscy9zY3JlZW4tYnJlYWtwb2ludHMubW9kZWwnO1xuXG5leHBvcnQgY29uc3QgSVNfTU9CSUxFX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuKCdJcyBtb2JpbGUnLCB7XG4gIGZhY3Rvcnk6ICgpID0+IHtcbiAgICBjb25zdCBicmVha3BvaW50T2JzZXJ2ZXIgPSBpbmplY3QoQnJlYWtwb2ludE9ic2VydmVyKTtcbiAgICByZXR1cm4gYnJlYWtwb2ludE9ic2VydmVyLm9ic2VydmUoYChtYXgtd2lkdGg6ICR7U2NyZWVuQnJlYWtwb2ludHMuTU9CSUxFfXB4KWApLnBpcGUobWFwKHYgPT4gdi5tYXRjaGVzKSk7XG4gIH0sXG59KTtcbiJdfQ==
|