@testgorilla/tgo-ui 2.23.43 → 2.23.44

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.
Files changed (61) hide show
  1. package/components/alert-banner/alert-banner.component.d.ts +5 -3
  2. package/components/autocomplete/autocomplete.component.d.ts +5 -3
  3. package/components/button/button.component.d.ts +5 -3
  4. package/components/checkbox/checkbox.component.d.ts +5 -3
  5. package/components/datepicker/datepicker.component.d.ts +5 -3
  6. package/components/dialog/dialog.component.d.ts +5 -3
  7. package/components/dropdown/dropdown.component.d.ts +5 -3
  8. package/components/empty-state/empty-state.component.d.ts +6 -4
  9. package/components/field/field.component.d.ts +5 -3
  10. package/components/file-upload/file-upload.component.d.ts +5 -3
  11. package/components/multi-input/multi-input.component.d.ts +5 -3
  12. package/components/navbar/navbar.component.d.ts +5 -3
  13. package/components/overflow-menu/overflow-menu.component.d.ts +5 -3
  14. package/components/page-header/page-header.component.d.ts +5 -3
  15. package/components/password-criteria/password.component.d.ts +5 -3
  16. package/components/password-strength/password-strength.component.d.ts +5 -3
  17. package/components/phone-input/phone-input.component.d.ts +5 -3
  18. package/components/progress-bar/progress-bar.component.d.ts +5 -3
  19. package/components/side-panel/side-panel.component.d.ts +5 -3
  20. package/components/side-sheet/side-sheet.component.d.ts +5 -3
  21. package/components/slider/slider.component.d.ts +5 -3
  22. package/components/snackbar/snackbar.component.d.ts +5 -3
  23. package/components/spinner/spinner.component.d.ts +5 -3
  24. package/components/stepper/stepper.component.d.ts +5 -3
  25. package/components/tag/tag.component.d.ts +5 -3
  26. package/components/toggle/toggle.component.d.ts +5 -3
  27. package/components/validation-error/validation-error.component.d.ts +5 -2
  28. package/esm2022/components/alert-banner/alert-banner.component.mjs +15 -4
  29. package/esm2022/components/autocomplete/autocomplete.component.mjs +15 -4
  30. package/esm2022/components/button/button.component.mjs +14 -3
  31. package/esm2022/components/checkbox/checkbox.component.mjs +15 -4
  32. package/esm2022/components/datepicker/datepicker.component.mjs +15 -4
  33. package/esm2022/components/dialog/dialog.component.mjs +14 -3
  34. package/esm2022/components/dropdown/dropdown.component.mjs +15 -4
  35. package/esm2022/components/empty-state/empty-state.component.mjs +14 -3
  36. package/esm2022/components/field/field.component.mjs +15 -4
  37. package/esm2022/components/file-upload/file-upload.component.mjs +14 -3
  38. package/esm2022/components/multi-input/multi-input.component.mjs +15 -4
  39. package/esm2022/components/navbar/navbar.component.mjs +15 -4
  40. package/esm2022/components/overflow-menu/overflow-menu.component.mjs +15 -4
  41. package/esm2022/components/page-header/page-header.component.mjs +14 -3
  42. package/esm2022/components/password-criteria/password.component.mjs +16 -5
  43. package/esm2022/components/password-strength/password-strength.component.mjs +14 -3
  44. package/esm2022/components/phone-input/phone-input.component.mjs +14 -3
  45. package/esm2022/components/progress-bar/progress-bar.component.mjs +14 -3
  46. package/esm2022/components/side-panel/side-panel.component.mjs +16 -5
  47. package/esm2022/components/side-sheet/side-sheet.component.mjs +15 -4
  48. package/esm2022/components/slider/slider.component.mjs +14 -3
  49. package/esm2022/components/snackbar/snackbar.component.mjs +15 -4
  50. package/esm2022/components/spinner/spinner.component.mjs +14 -3
  51. package/esm2022/components/stepper/stepper.component.mjs +14 -3
  52. package/esm2022/components/tag/tag.component.mjs +14 -3
  53. package/esm2022/components/toggle/toggle.component.mjs +14 -3
  54. package/esm2022/components/validation-error/validation-error.component.mjs +16 -5
  55. package/esm2022/public-api.mjs +3 -1
  56. package/esm2022/tokens/app-lang.token.mjs +3 -0
  57. package/fesm2022/testgorilla-tgo-ui.mjs +315 -70
  58. package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
  59. package/package.json +1 -1
  60. package/public-api.d.ts +1 -0
  61. package/tokens/app-lang.token.d.ts +2 -0
@@ -1,6 +1,7 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { LanguageService } from '../../utils/localization/language.service';
4
+ import { CANOPY_UI_LANG } from '../../tokens/app-lang.token';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common";
6
7
  import * as i2 from "@angular/material/slider";
@@ -9,9 +10,11 @@ import * as i4 from "@angular/material/input";
9
10
  import * as i5 from "@angular/material/form-field";
10
11
  import * as i6 from "../icon/icon.component";
11
12
  import * as i7 from "../../pipes/ui-translate.pipe";
13
+ import * as i8 from "../../utils/localization/language.model";
12
14
  export class SliderComponent {
13
- constructor(defaultAppTheme) {
15
+ constructor(defaultAppTheme, appLang) {
14
16
  this.defaultAppTheme = defaultAppTheme;
17
+ this.appLang = appLang;
15
18
  /**
16
19
  * The maximum value of the slider.
17
20
  *
@@ -107,6 +110,9 @@ export class SliderComponent {
107
110
  if (defaultAppTheme) {
108
111
  this.applicationTheme = defaultAppTheme;
109
112
  }
113
+ if (appLang) {
114
+ this.language = appLang;
115
+ }
110
116
  }
111
117
  registerOnChange(fn) {
112
118
  this.onChange = fn;
@@ -155,7 +161,7 @@ export class SliderComponent {
155
161
  get isBasicSlider() {
156
162
  return this.variant === 'basic';
157
163
  }
158
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SliderComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
164
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SliderComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: CANOPY_UI_LANG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
159
165
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: SliderComponent, selector: "ui-slider", inputs: { max: "max", min: "min", percentage: "percentage", disabled: "disabled", sliderStart: "sliderStart", sliderEnd: "sliderEnd", label: "label", showInputs: "showInputs", step: "step", language: "language", applicationTheme: "applicationTheme", variant: "variant" }, outputs: { sliderValueChange: "sliderValueChange" }, providers: [
160
166
  {
161
167
  provide: NG_VALUE_ACCESSOR,
@@ -178,6 +184,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
178
184
  }, {
179
185
  type: Inject,
180
186
  args: ['CANOPYUI_DEFAULT_APPLICATION_THEME']
187
+ }] }, { type: i8.Language, decorators: [{
188
+ type: Optional
189
+ }, {
190
+ type: Inject,
191
+ args: [CANOPY_UI_LANG]
181
192
  }] }], propDecorators: { max: [{
182
193
  type: Input
183
194
  }], min: [{
@@ -205,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
205
216
  }], sliderValueChange: [{
206
217
  type: Output
207
218
  }] } });
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/slider/slider.component.ts","../../../../../projects/tgo-canopy-ui/components/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  forwardRef, Inject,\n  Input, Optional,\n  Output\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { SliderValue, SliderVariant } from './slider.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-slider',\n  templateUrl: './slider.component.html',\n  styleUrls: ['./slider.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SliderComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SliderComponent {\n  /**\n   * The maximum value of the slider.\n   *\n   * @type {number}\n   * @default 100\n   */\n  @Input() max = 100;\n\n  /**\n   * The minimum value of the slider.\n   *\n   * @type {number}\n   * @default 0\n   */\n  @Input() min = 0;\n\n  /**\n   * A flag indicating whether the slider displays values as percentages.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() percentage = false;\n\n  /**\n   * A flag indicating whether the slider is disabled.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() disabled = false;\n\n  /**\n   * The starting value of the slider.\n   *\n   * @type {number}\n   * @default 0\n   */\n  @Input() sliderStart = 0;\n\n  /**\n   * The ending value of the slider.\n   *\n   * @type {number}\n   * @default 100\n   */\n  @Input() sliderEnd = 100;\n\n  /**\n   * The label for the slider.\n   *\n   * @type {string}\n   * @default ''\n   */\n  @Input() label = '';\n\n  /**\n   * Show slider inputs.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() showInputs = true;\n\n  /**\n   * Step number.\n   *\n   * @type {number}\n   * @default 1\n   */\n  @Input() step = 1;\n\n  /**\n   * The language to be used\n   *\n   * @property language\n   * @type {Language}\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SliderComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * Defines the variant slider\n   *\n   * @type {SliderVariant}\n   * @memberof SliderComponent\n   */\n  @Input() variant: SliderVariant = 'range';\n\n  @Output() sliderValueChange = new EventEmitter<SliderValue>();\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  private value: SliderValue = { start: 0, end: 100 };\n  protected translationContext = 'SLIDER.';\n  protected touchedControlName = '';\n\n  onChange = (_: any): void => {};\n  onTouch = (): void => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.sliderStart = value.start;\n    this.sliderEnd = value.end;\n  }\n\n  protected onValueChange(ev?: number): void {\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\n\n    if (ev) {\n      value.start = ev;\n      value.end = 0;\n    }\n\n    this.value = value;\n    this.onChange(value);\n    this.sliderValueChange.emit(value);\n  }\n\n  protected onInputBlur(inputName: string): void {\n    this.touchedControlName = inputName;\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\n\n    if (!this.hasError && this.isValueChanged(value)) {\n      this.onValueChange();\n    }\n  }\n\n  protected onInputFocus(): void {\n    this.touchedControlName = '';\n  }\n\n  private isValueChanged(value: SliderValue): boolean {\n    return this.value.start !== value.start || this.value.end !== value.end;\n  }\n\n  get hasError(): boolean {\n    return (\n      this.max < +this.sliderEnd ||\n      this.min > +this.sliderStart ||\n      this.min > +this.sliderEnd ||\n      this.max < +this.sliderStart ||\n      +this.sliderEnd < +this.sliderStart\n    );\n  }\n\n  get isBasicSlider(): boolean {\n    return this.variant === 'basic';\n  }\n}\n","<ng-container>\n  <div class=\"slider-container\" [attr.theme]=\"applicationTheme\" [ngClass]=\"{ disabled: disabled, error: hasError && touchedControlName }\">\n    <div class=\"slider-label\" *ngIf=\"label\">{{ label }}</div>\n\n    <div class=\"slider\">\n      <div class=\"min-value\" *ngIf=\"!isBasicSlider\">{{ percentage ? min + '%' : min }}</div>\n      <mat-slider\n        [disableRipple]=\"applicationTheme !== 'classic'\" #sliderElement discrete [disabled]=\"disabled\" [max]=\"max\" [min]=\"min\" [step]=\"step\" (mouseenter)=\"sliderElement.discrete = true\" (mouseleave)=\"sliderElement.discrete = false\">\n        <ng-container *ngIf=\"isBasicSlider; else rangeTemplate\">\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange($event)\"\n            [(ngModel)]=\"sliderStart\"\n            matSliderThumb\n          >\n        </ng-container>\n\n        <ng-template #rangeTemplate>\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange()\"\n            [(ngModel)]=\"sliderStart\"\n            matSliderStartThumb\n          >\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange()\"\n            [(ngModel)]=\"sliderEnd\"\n            matSliderEndThumb\n          >\n\n        </ng-template>\n      </mat-slider>\n      <div class=\"max-value\" *ngIf=\"!isBasicSlider\">{{ percentage ? max + '%' : max }}</div>\n    </div>\n\n    <div class=\"slider-input\" *ngIf=\"showInputs && !this.isBasicSlider\">\n      <mat-form-field [appearance]=\"'outline'\">\n        <mat-label>{{ ('COMMON.MIN') | uiTranslate : language }} <span *ngIf=\"percentage\">%</span></mat-label>\n        <input\n          matInput\n          [type]=\"'number'\"\n          [(ngModel)]=\"sliderStart\"\n          [disabled]=\"disabled\"\n          (focus)=\"onInputFocus()\"\n          (blur)=\"onInputBlur('start')\"\n          (keydown.enter)=\"onInputBlur('start')\"\n        >\n      </mat-form-field>\n\n      <mat-form-field [appearance]=\"'outline'\">\n        <mat-label>{{ ('COMMON.MAX') | uiTranslate : language }} <span *ngIf=\"percentage\">%</span></mat-label>\n        <input\n          matInput\n          [disabled]=\"disabled\"\n          [type]=\"'number'\"\n          [(ngModel)]=\"sliderEnd\"\n          (focus)=\"onInputFocus()\"\n          (blur)=\"onInputBlur('end')\"\n          (keydown.enter)=\"onInputBlur('end')\"\n        >\n      </mat-form-field>\n    </div>\n\n    <mat-error *ngIf=\"hasError && touchedControlName\">\n      <div class=\"validation-error\" *ngIf=\"touchedControlName === 'start' && sliderStart > sliderEnd\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ (translationContext + 'MIN_MORE_THAN_MAX') | uiTranslate : language : { min: sliderStart, max: sliderEnd } }}</span>\n      </div>\n\n      <div class=\"validation-error\" *ngIf=\"touchedControlName === 'end' && sliderStart > sliderEnd\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ (translationContext + 'MAX_LESS_THAN_MIN') | uiTranslate : language : { min: sliderStart, max: sliderEnd } }}</span>\n      </div>\n\n      <div class=\"validation-error\" *ngIf=\"sliderStart < min\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ ('COMMON.MIN') | uiTranslate : language }} {{ min }}</span>\n      </div>\n      <div class=\"validation-error\" *ngIf=\"sliderEnd > max\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ ('COMMON.MAX') | uiTranslate : language }} {{ max }}</span>\n      </div>\n    </mat-error>\n  </div>\n</ng-container>\n\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/slider/slider.component.ts","../../../../../projects/tgo-canopy-ui/components/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  forwardRef, Inject,\n  Input, Optional,\n  Output\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { SliderValue, SliderVariant } from './slider.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from \"../../models/application-theme.model\";\nimport { CANOPY_UI_LANG } from '../../tokens/app-lang.token';\nimport { Language } from '../../utils/localization/language.model';\n\n@Component({\n  selector: 'ui-slider',\n  templateUrl: './slider.component.html',\n  styleUrls: ['./slider.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SliderComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SliderComponent {\n  /**\n   * The maximum value of the slider.\n   *\n   * @type {number}\n   * @default 100\n   */\n  @Input() max = 100;\n\n  /**\n   * The minimum value of the slider.\n   *\n   * @type {number}\n   * @default 0\n   */\n  @Input() min = 0;\n\n  /**\n   * A flag indicating whether the slider displays values as percentages.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() percentage = false;\n\n  /**\n   * A flag indicating whether the slider is disabled.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() disabled = false;\n\n  /**\n   * The starting value of the slider.\n   *\n   * @type {number}\n   * @default 0\n   */\n  @Input() sliderStart = 0;\n\n  /**\n   * The ending value of the slider.\n   *\n   * @type {number}\n   * @default 100\n   */\n  @Input() sliderEnd = 100;\n\n  /**\n   * The label for the slider.\n   *\n   * @type {string}\n   * @default ''\n   */\n  @Input() label = '';\n\n  /**\n   * Show slider inputs.\n   *\n   * @type {boolean}\n   * @default true\n   */\n  @Input() showInputs = true;\n\n  /**\n   * Step number.\n   *\n   * @type {number}\n   * @default 1\n   */\n  @Input() step = 1;\n\n  /**\n   * The language to be used\n   *\n   * @property language\n   * @type {Language}\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SliderComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * Defines the variant slider\n   *\n   * @type {SliderVariant}\n   * @memberof SliderComponent\n   */\n  @Input() variant: SliderVariant = 'range';\n\n  @Output() sliderValueChange = new EventEmitter<SliderValue>();\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Optional() @Inject(CANOPY_UI_LANG) protected readonly appLang: Language,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (appLang) {\n      this.language = appLang;\n    }\n  }\n\n  private value: SliderValue = { start: 0, end: 100 };\n  protected translationContext = 'SLIDER.';\n  protected touchedControlName = '';\n\n  onChange = (_: any): void => {};\n  onTouch = (): void => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.sliderStart = value.start;\n    this.sliderEnd = value.end;\n  }\n\n  protected onValueChange(ev?: number): void {\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\n\n    if (ev) {\n      value.start = ev;\n      value.end = 0;\n    }\n\n    this.value = value;\n    this.onChange(value);\n    this.sliderValueChange.emit(value);\n  }\n\n  protected onInputBlur(inputName: string): void {\n    this.touchedControlName = inputName;\n    const value: SliderValue = { start: +this.sliderStart, end: +this.sliderEnd };\n\n    if (!this.hasError && this.isValueChanged(value)) {\n      this.onValueChange();\n    }\n  }\n\n  protected onInputFocus(): void {\n    this.touchedControlName = '';\n  }\n\n  private isValueChanged(value: SliderValue): boolean {\n    return this.value.start !== value.start || this.value.end !== value.end;\n  }\n\n  get hasError(): boolean {\n    return (\n      this.max < +this.sliderEnd ||\n      this.min > +this.sliderStart ||\n      this.min > +this.sliderEnd ||\n      this.max < +this.sliderStart ||\n      +this.sliderEnd < +this.sliderStart\n    );\n  }\n\n  get isBasicSlider(): boolean {\n    return this.variant === 'basic';\n  }\n}\n","<ng-container>\n  <div class=\"slider-container\" [attr.theme]=\"applicationTheme\" [ngClass]=\"{ disabled: disabled, error: hasError && touchedControlName }\">\n    <div class=\"slider-label\" *ngIf=\"label\">{{ label }}</div>\n\n    <div class=\"slider\">\n      <div class=\"min-value\" *ngIf=\"!isBasicSlider\">{{ percentage ? min + '%' : min }}</div>\n      <mat-slider\n        [disableRipple]=\"applicationTheme !== 'classic'\" #sliderElement discrete [disabled]=\"disabled\" [max]=\"max\" [min]=\"min\" [step]=\"step\" (mouseenter)=\"sliderElement.discrete = true\" (mouseleave)=\"sliderElement.discrete = false\">\n        <ng-container *ngIf=\"isBasicSlider; else rangeTemplate\">\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange($event)\"\n            [(ngModel)]=\"sliderStart\"\n            matSliderThumb\n          >\n        </ng-container>\n\n        <ng-template #rangeTemplate>\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange()\"\n            [(ngModel)]=\"sliderStart\"\n            matSliderStartThumb\n          >\n          <input\n            [disabled]=\"disabled\"\n            (valueChange)=\"onValueChange()\"\n            [(ngModel)]=\"sliderEnd\"\n            matSliderEndThumb\n          >\n\n        </ng-template>\n      </mat-slider>\n      <div class=\"max-value\" *ngIf=\"!isBasicSlider\">{{ percentage ? max + '%' : max }}</div>\n    </div>\n\n    <div class=\"slider-input\" *ngIf=\"showInputs && !this.isBasicSlider\">\n      <mat-form-field [appearance]=\"'outline'\">\n        <mat-label>{{ ('COMMON.MIN') | uiTranslate : language }} <span *ngIf=\"percentage\">%</span></mat-label>\n        <input\n          matInput\n          [type]=\"'number'\"\n          [(ngModel)]=\"sliderStart\"\n          [disabled]=\"disabled\"\n          (focus)=\"onInputFocus()\"\n          (blur)=\"onInputBlur('start')\"\n          (keydown.enter)=\"onInputBlur('start')\"\n        >\n      </mat-form-field>\n\n      <mat-form-field [appearance]=\"'outline'\">\n        <mat-label>{{ ('COMMON.MAX') | uiTranslate : language }} <span *ngIf=\"percentage\">%</span></mat-label>\n        <input\n          matInput\n          [disabled]=\"disabled\"\n          [type]=\"'number'\"\n          [(ngModel)]=\"sliderEnd\"\n          (focus)=\"onInputFocus()\"\n          (blur)=\"onInputBlur('end')\"\n          (keydown.enter)=\"onInputBlur('end')\"\n        >\n      </mat-form-field>\n    </div>\n\n    <mat-error *ngIf=\"hasError && touchedControlName\">\n      <div class=\"validation-error\" *ngIf=\"touchedControlName === 'start' && sliderStart > sliderEnd\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ (translationContext + 'MIN_MORE_THAN_MAX') | uiTranslate : language : { min: sliderStart, max: sliderEnd } }}</span>\n      </div>\n\n      <div class=\"validation-error\" *ngIf=\"touchedControlName === 'end' && sliderStart > sliderEnd\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ (translationContext + 'MAX_LESS_THAN_MIN') | uiTranslate : language : { min: sliderStart, max: sliderEnd } }}</span>\n      </div>\n\n      <div class=\"validation-error\" *ngIf=\"sliderStart < min\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ ('COMMON.MIN') | uiTranslate : language }} {{ min }}</span>\n      </div>\n      <div class=\"validation-error\" *ngIf=\"sliderEnd > max\">\n        <ui-icon [name]=\"'Info'\"></ui-icon>\n        <span>{{ ('COMMON.MAX') | uiTranslate : language }} {{ max }}</span>\n      </div>\n    </mat-error>\n  </div>\n</ng-container>\n\n"]}
@@ -3,6 +3,7 @@ import { Component, Inject, Input, Optional } from '@angular/core';
3
3
  import { MAT_SNACK_BAR_DATA } from '@angular/material/snack-bar';
4
4
  import { alertBarsUtil } from '../../utils/alert-bars.utils';
5
5
  import { LanguageService } from '../../utils/localization/language.service';
6
+ import { CANOPY_UI_LANG } from '../../tokens/app-lang.token';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/material/snack-bar";
8
9
  import * as i2 from "@angular/platform-browser";
@@ -11,6 +12,7 @@ import * as i4 from "../button/button.component";
11
12
  import * as i5 from "../icon/icon.component";
12
13
  import * as i6 from "@angular/material/tooltip";
13
14
  import * as i7 from "../../pipes/ui-translate.pipe";
15
+ import * as i8 from "../../utils/localization/language.model";
14
16
  export class SnackbarComponent {
15
17
  /**
16
18
  * Snackbar message from html
@@ -22,11 +24,12 @@ export class SnackbarComponent {
22
24
  this.safeHtml = this.domSanitizer.bypassSecurityTrustHtml(value);
23
25
  }
24
26
  }
25
- constructor(defaultAppTheme, data, snackbarRef, domSanitizer) {
27
+ constructor(defaultAppTheme, data, snackbarRef, domSanitizer, appLang) {
26
28
  this.defaultAppTheme = defaultAppTheme;
27
29
  this.data = data;
28
30
  this.snackbarRef = snackbarRef;
29
31
  this.domSanitizer = domSanitizer;
32
+ this.appLang = appLang;
30
33
  /**
31
34
  * Background color of the button while in active state
32
35
  *
@@ -116,6 +119,9 @@ export class SnackbarComponent {
116
119
  if (defaultAppTheme) {
117
120
  this.applicationTheme = defaultAppTheme;
118
121
  }
122
+ if (appLang) {
123
+ this.language = appLang;
124
+ }
119
125
  this.snackbarType = data.snackbarType ?? 'success';
120
126
  this.message = data.message ?? '';
121
127
  this.safeHtml = data.html ? this.domSanitizer.bypassSecurityTrustHtml(data.html) : '';
@@ -160,7 +166,7 @@ export class SnackbarComponent {
160
166
  this.visible = false;
161
167
  this.snackbarRef.dismiss();
162
168
  }
163
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SnackbarComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: MAT_SNACK_BAR_DATA }, { token: i1.MatSnackBarRef }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
169
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SnackbarComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: MAT_SNACK_BAR_DATA }, { token: i1.MatSnackBarRef }, { token: i2.DomSanitizer }, { token: CANOPY_UI_LANG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
164
170
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: SnackbarComponent, selector: "ui-snackbar", inputs: { snackbarType: "snackbarType", message: "message", html: "html", seconds: "seconds", includeDismissButton: "includeDismissButton", fixed: "fixed", linkText: "linkText", linkUrl: "linkUrl", linkTarget: "linkTarget", language: "language", variant: "variant", applicationTheme: "applicationTheme", closeButtonTooltip: "closeButtonTooltip", ariaDescribedby: "ariaDescribedby" }, ngImport: i0, template: "<ng-container>\n <div\n [ngClass]=\"snackbarType + ' ' + position\"\n [@openClose]\n *ngIf=\"visible\"\n class=\"snackbar-container\"\n [attr.theme]=\"applicationTheme\"\n [class.mobile]=\"variant === 'mobile'\"\n [class.desktop]=\"variant === 'desktop'\"\n (mouseenter)=\"onMouseEnter()\"\n (mouseleave)=\"onMouseLeave()\"\n data-testid=\"snackbar-wrapper\"\n [attr.data-test-snackbar-type]=\"snackbarType\"\n [attr.aria-describedby]=\"'describedby'\"\n role=\"alert\"\n [attr.aria-labelledby]=\"'labelledby'\"\n >\n <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate : language }}</span>\n <span style=\"position: absolute; left: -9999px\">{{ message }}\n <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n </span>\n <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n <div\n aria-hidden=\"true\"\n class=\"snackbar-text\"\n [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n data-testid=\"snackbar-content\"\n >\n <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n </div>\n <ui-button\n *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n variant=\"text\"\n [label]=\"translationContext + 'DISMISS' | uiTranslate: language\"\n [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n (buttonClickEvent)=\"dismissClick()\"\n data-testid=\"snackbar-dismiss-button\"\n ></ui-button>\n <ui-button\n *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n [variant]=\"'icon-button'\"\n [applicationTheme]=\"'light'\"\n [iconName]=\"'Close-in-line'\"\n [size]=\"'small'\"\n [tooltip]=\"closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate: language)\"\n (click)=\"dismissClick()\"\n data-testid=\"snackbar-dismiss-button\"\n ></ui-button>\n </div>\n</ng-container>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host{display:flex;width:100%;justify-content:center}:host .snackbar-container{max-width:600px}:host .alert-container,:host .snackbar-container{margin:0 auto;display:flex;padding:0 14px;border-radius:4px;align-items:center;justify-content:space-between;opacity:1;min-height:48px}:host .alert-container.fixed,:host .snackbar-container.fixed{position:fixed}:host .alert-container.static,:host .snackbar-container.static{position:relative}:host .alert-container ui-icon,:host .snackbar-container ui-icon{margin-right:14px}:host .alert-container ui-button,:host .snackbar-container ui-button{margin-left:14px}:host .alert-container ::ng-deep button.mat-mdc-unelevated-button.big,:host .snackbar-container ::ng-deep button.mat-mdc-unelevated-button.big{padding:0;min-width:auto}:host .alert-container .alert-text,:host .alert-container .snackbar-text,:host .snackbar-container .alert-text,:host .snackbar-container .snackbar-text{display:flex;align-items:center;color:#000}:host .alert-container .alert-text a,:host .alert-container .snackbar-text a,:host .snackbar-container .alert-text a,:host .snackbar-container .snackbar-text a{color:#000;text-decoration:underline;font-weight:700}:host .alert-container .alert-text a:hover,:host .alert-container .alert-text a:visited,:host .alert-container .alert-text a:focus,:host .alert-container .snackbar-text a:hover,:host .alert-container .snackbar-text a:visited,:host .alert-container .snackbar-text a:focus,:host .snackbar-container .alert-text a:hover,:host .snackbar-container .alert-text a:visited,:host .snackbar-container .alert-text a:focus,:host .snackbar-container .snackbar-text a:hover,:host .snackbar-container .snackbar-text a:visited,:host .snackbar-container .snackbar-text a:focus{text-decoration:none}:host .alert-container.success,:host .snackbar-container.success{background-color:#cbd6cb}:host .alert-container.info,:host .snackbar-container.info{background-color:#c8d7de}:host .alert-container.warning,:host .snackbar-container.warning{background-color:#f0d6bb}:host .alert-container.error,:host .snackbar-container.error{background-color:#e3c3c6}:host .alert-container[theme=dark].success,:host .alert-container[theme=light].success,:host .snackbar-container[theme=dark].success,:host .snackbar-container[theme=light].success{background-color:#aae47a}:host .alert-container[theme=dark].info,:host .alert-container[theme=light].info,:host .snackbar-container[theme=dark].info,:host .snackbar-container[theme=light].info{background-color:#d9e8ff}:host .alert-container[theme=dark].warning,:host .alert-container[theme=light].warning,:host .snackbar-container[theme=dark].warning,:host .snackbar-container[theme=light].warning{background-color:#ffe1b3}:host .alert-container[theme=dark].error,:host .alert-container[theme=light].error,:host .snackbar-container[theme=dark].error,:host .snackbar-container[theme=light].error{background-color:#ffac9a}::ng-deep .display-none{display:none!important}@media (max-width: 600px){:host .alert-container,:host .snackbar-container{padding:8px 14px}}:host .snackbar-container{bottom:0;z-index:98}:host .snackbar-container[theme=dark] ui-icon,:host .snackbar-container[theme=light] ui-icon{margin-right:10px;cursor:pointer}:host .snackbar-container[theme=dark] .snackbar-text,:host .snackbar-container[theme=light] .snackbar-text{padding-left:10px;margin-right:8px}:host .snackbar-container[theme=dark] .snackbar-text a,:host .snackbar-container[theme=light] .snackbar-text a{margin-left:4px}:host .snackbar-container[theme=dark].desktop,:host .snackbar-container[theme=light].desktop{border-radius:24px;box-shadow:0 4px 16px #2424240a;width:fit-content;max-width:600px;min-height:48px;line-height:1.4;font-size:14px;padding:16px 24px}:host .snackbar-container[theme=dark].mobile,:host .snackbar-container[theme=light].mobile{width:100%;min-width:100%;word-break:break-word}:host .mat-mdc-snack-bar-container{margin:16px 8px}::ng-deep .mdc-snackbar__surface{height:0}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ButtonComponent, selector: "ui-button", inputs: ["size", "variant", "label", "iconPosition", "justIcon", "iconName", "disabled", "loading", "fullWidth", "url", "urlTarget", "value", "tooltip", "isPremium", "type", "companyColor", "buttonBadgeConfig", "applicationTheme", "disabledScaleOnClick", "ariaLabel", "ariaRequired", "ariaLabelledby", "ariaDescribedby", "language", "preventDefault", "tooltipPosition"], outputs: ["buttonClickEvent", "buttonHoverEvent"] }, { kind: "component", type: i5.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i3.SlicePipe, name: "slice" }, { kind: "pipe", type: i7.UiTranslatePipe, name: "uiTranslate" }], animations: [
165
171
  trigger('openClose', [
166
172
  transition(':enter', [
@@ -196,7 +202,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
196
202
  }] }, { type: undefined, decorators: [{
197
203
  type: Inject,
198
204
  args: [MAT_SNACK_BAR_DATA]
199
- }] }, { type: i1.MatSnackBarRef }, { type: i2.DomSanitizer }], propDecorators: { snackbarType: [{
205
+ }] }, { type: i1.MatSnackBarRef }, { type: i2.DomSanitizer }, { type: i8.Language, decorators: [{
206
+ type: Optional
207
+ }, {
208
+ type: Inject,
209
+ args: [CANOPY_UI_LANG]
210
+ }] }], propDecorators: { snackbarType: [{
200
211
  type: Input
201
212
  }], message: [{
202
213
  type: Input
@@ -225,4 +236,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
225
236
  }], ariaDescribedby: [{
226
237
  type: Input
227
238
  }] } });
228
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.ts","../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { MAT_SNACK_BAR_DATA, MatSnackBarRef } from '@angular/material/snack-bar';\nimport { IconName } from '../../components/icon/icon.model';\nimport { SnackbarType, SnackbarVariant } from '../../components/snackbar/snackbar.model';\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { LinkTargetType } from '../alert-banner/alert-banner.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-snackbar',\n  templateUrl: './snackbar.component.html',\n  styleUrls: ['./snackbar.component.scss'],\n  animations: [\n    trigger('openClose', [\n      transition(':enter', [\n        style({ bottom: '-55px', opacity: 0 }),\n        animate('0.2s ease-out', style({ opacity: 1, bottom: '10px' })),\n      ]),\n      transition(':leave', [\n        style({ bottom: '10px', opacity: 1 }),\n        animate('0.2s ease-in', style({ bottom: '-55px', opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class SnackbarComponent implements OnInit {\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {SnackbarType}\n   * @memberof SnackbarComponent\n   */\n  @Input() snackbarType: SnackbarType = 'success';\n\n  /**\n   * Snackbar message\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() message = '';\n\n  /**\n   * Snackbar message from html\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() set html(value: string) {\n    if (value) {\n      this.safeHtml = this.domSanitizer.bypassSecurityTrustHtml(value);\n    }\n  }\n\n  /**\n   * Set the time that the snackbar will be visible\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() seconds = 5;\n\n  /**\n   * Include dismmiss button\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() includeDismissButton = true;\n\n  /**\n   * Static or fixed position\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() fixed = true;\n\n  /**\n   * Link text that will appended at the end of message\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkText? = '';\n\n  /**\n   * Link url\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkUrl?: string;\n\n  /**\n   * Link target\n   *\n   * @type {@type {LinkTargetType}}\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkTarget?: LinkTargetType = '_blank';\n\n  /**\n   * The language to be used\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * The variant to be used\n   *\n   * @type {SnackbarVariant}\n   * @memberof SnackbarComponent\n   */\n  @Input() variant: SnackbarVariant = 'desktop';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SnackbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Close button tooltip\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() closeButtonTooltip = '';\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 {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  iconName: IconName;\n  showSnackbar = true;\n  milisenconds: number;\n  visible = false;\n  timer?: number;\n  timerStartedAt = 0;\n  timerPausedAt = 0;\n  position: string;\n  safeHtml: SafeHtml;\n\n  translationContext = 'SNACKBAR.';\n  protected readonly maxCharacters = 70;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(MAT_SNACK_BAR_DATA) private data: any,\n    private snackbarRef: MatSnackBarRef<SnackbarComponent>,\n    private domSanitizer: DomSanitizer,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.snackbarType = data.snackbarType ?? 'success';\n    this.message = data.message ?? '';\n    this.safeHtml = data.html ? this.domSanitizer.bypassSecurityTrustHtml(data.html) : '';\n  }\n\n  ngOnInit(): void {\n    this.milisenconds = this.seconds * 1000;\n    this.iconName = alertBarsUtil.setIcon(this.snackbarType);\n    this.show();\n    this.position = alertBarsUtil.setPosition(this.fixed);\n  }\n\n  //Show snackbar\n  show() {\n    this.timerStartedAt = Date.now();\n    this.visible = true;\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds);\n  }\n\n  //Hide snackbar\n  hide() {\n    this.visible = false;\n    this.timerPausedAt = 0;\n    this.timerStartedAt = 0;\n    clearTimeout(this.timer);\n    this.timer = undefined;\n    this.snackbarRef.dismiss();\n  }\n\n  //Pause timer when mouse enter\n  onMouseEnter() {\n    this.visible = true;\n    this.timerPausedAt = Date.now();\n    clearTimeout(this.timer);\n  }\n\n  //Continue timer when mouse leave\n  onMouseLeave() {\n    const diff = this.timerPausedAt - this.timerStartedAt;\n    if (diff <= 0) {\n      return this.hide();\n    }\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds - diff);\n  }\n\n  //Hide snackbar when dismiss button is clicked\n  dismissClick() {\n    this.visible = false;\n    this.snackbarRef.dismiss();\n  }\n}\n","<ng-container>\n  <div\n    [ngClass]=\"snackbarType + ' ' + position\"\n    [@openClose]\n    *ngIf=\"visible\"\n    class=\"snackbar-container\"\n    [attr.theme]=\"applicationTheme\"\n    [class.mobile]=\"variant === 'mobile'\"\n    [class.desktop]=\"variant === 'desktop'\"\n    (mouseenter)=\"onMouseEnter()\"\n    (mouseleave)=\"onMouseLeave()\"\n    data-testid=\"snackbar-wrapper\"\n    [attr.data-test-snackbar-type]=\"snackbarType\"\n    [attr.aria-describedby]=\"'describedby'\"\n    role=\"alert\"\n    [attr.aria-labelledby]=\"'labelledby'\"\n  >\n    <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate : language }}</span>\n    <span style=\"position: absolute; left: -9999px\">{{ message }}\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </span>\n    <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n    <div\n      aria-hidden=\"true\"\n      class=\"snackbar-text\"\n      [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n      data-testid=\"snackbar-content\"\n    >\n      <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n      {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n      <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [label]=\"translationContext + 'DISMISS' | uiTranslate: language\"\n      [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n      (buttonClickEvent)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"'light'\"\n      [iconName]=\"'Close-in-line'\"\n      [size]=\"'small'\"\n      [tooltip]=\"closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate: language)\"\n      (click)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n  </div>\n</ng-container>\n"]}
239
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.ts","../../../../../projects/tgo-canopy-ui/components/snackbar/snackbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAU,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAkB,MAAM,6BAA6B,CAAC;AAGjF,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAI5E,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;;AAoB7D,MAAM,OAAO,iBAAiB;IAgB5B;;;;OAIG;IACH,IAAa,IAAI,CAAC,KAAa;QAC7B,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QACnE,CAAC;IACH,CAAC;IAmGD,YAC6E,eAAiC,EACxE,IAAS,EACrC,WAA8C,EAC9C,YAA0B,EACqB,OAAiB;QAJG,oBAAe,GAAf,eAAe,CAAkB;QACxE,SAAI,GAAJ,IAAI,CAAK;QACrC,gBAAW,GAAX,WAAW,CAAmC;QAC9C,iBAAY,GAAZ,YAAY,CAAc;QACqB,YAAO,GAAP,OAAO,CAAU;QAhI1E;;;;;WAKG;QACM,iBAAY,GAAiB,SAAS,CAAC;QAEhD;;;;WAIG;QACM,YAAO,GAAG,EAAE,CAAC;QAatB;;;;WAIG;QACM,YAAO,GAAG,CAAC,CAAC;QAErB;;;;WAIG;QACM,yBAAoB,GAAG,IAAI,CAAC;QAErC;;;;WAIG;QACM,UAAK,GAAG,IAAI,CAAC;QAEtB;;;;WAIG;QACM,aAAQ,GAAI,EAAE,CAAC;QASxB;;;;;WAKG;QACM,eAAU,GAAoB,QAAQ,CAAC;QAEhD;;;;;WAKG;QACM,aAAQ,GAAG,eAAe,CAAC,eAAe,CAAC;QAEpD;;;;;WAKG;QACM,YAAO,GAAoB,SAAS,CAAC;QAE9C;;;;;;WAMG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAEtD;;;;;WAKG;QACM,uBAAkB,GAAG,EAAE,CAAC;QAEjC;;;;;WAKG;QACM,oBAAe,GAAG,EAAE,CAAC;QAG9B,iBAAY,GAAG,IAAI,CAAC;QAEpB,YAAO,GAAG,KAAK,CAAC;QAEhB,mBAAc,GAAG,CAAC,CAAC;QACnB,kBAAa,GAAG,CAAC,CAAC;QAIlB,uBAAkB,GAAG,WAAW,CAAC;QACd,kBAAa,GAAG,EAAE,CAAC;QASpC,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;QAED,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QAC1B,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,SAAS,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACxF,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxC,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzD,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAED,eAAe;IACf,IAAI;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACvE,CAAC;IAED,eAAe;IACf,IAAI;QACF,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QACxB,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED,8BAA8B;IAC9B,YAAY;QACV,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAChC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,iCAAiC;IACjC,YAAY;QACV,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC;QACtD,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;YACd,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC;QACrB,CAAC;QACD,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;IAC9E,CAAC;IAED,8CAA8C;IAC9C,YAAY;QACV,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;8GA5LU,iBAAiB,kBA6HN,oCAAoC,6BAChD,kBAAkB,uEAGN,cAAc;kGAjIzB,iBAAiB,mbC9B9B,8yEAqDA,qnODpCc;YACV,OAAO,CAAC,WAAW,EAAE;gBACnB,UAAU,CAAC,QAAQ,EAAE;oBACnB,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;oBACtC,OAAO,CAAC,eAAe,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;iBAChE,CAAC;gBACF,UAAU,CAAC,QAAQ,EAAE;oBACnB,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;oBACrC,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;iBAChE,CAAC;aACH,CAAC;SACH;;2FAEU,iBAAiB;kBAjB7B,SAAS;+BACE,aAAa,cAGX;wBACV,OAAO,CAAC,WAAW,EAAE;4BACnB,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;gCACtC,OAAO,CAAC,eAAe,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;6BAChE,CAAC;4BACF,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;gCACrC,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;6BAChE,CAAC;yBACH,CAAC;qBACH;;0BA+HE,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BACvD,MAAM;2BAAC,kBAAkB;;0BAGzB,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;yCA1H3B,YAAY;sBAApB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAOO,IAAI;sBAAhB,KAAK;gBAWG,OAAO;sBAAf,KAAK;gBAOG,oBAAoB;sBAA5B,KAAK;gBAOG,KAAK;sBAAb,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBASG,gBAAgB;sBAAxB,KAAK;gBAQG,kBAAkB;sBAA1B,KAAK;gBAQG,eAAe;sBAAvB,KAAK","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { MAT_SNACK_BAR_DATA, MatSnackBarRef } from '@angular/material/snack-bar';\nimport { IconName } from '../../components/icon/icon.model';\nimport { SnackbarType, SnackbarVariant } from '../../components/snackbar/snackbar.model';\nimport { alertBarsUtil } from '../../utils/alert-bars.utils';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { LinkTargetType } from '../alert-banner/alert-banner.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { CANOPY_UI_LANG } from '../../tokens/app-lang.token';\nimport { Language } from '../../utils/localization/language.model';\n\n@Component({\n  selector: 'ui-snackbar',\n  templateUrl: './snackbar.component.html',\n  styleUrls: ['./snackbar.component.scss'],\n  animations: [\n    trigger('openClose', [\n      transition(':enter', [\n        style({ bottom: '-55px', opacity: 0 }),\n        animate('0.2s ease-out', style({ opacity: 1, bottom: '10px' })),\n      ]),\n      transition(':leave', [\n        style({ bottom: '10px', opacity: 1 }),\n        animate('0.2s ease-in', style({ bottom: '-55px', opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class SnackbarComponent implements OnInit {\n  /**\n   * Background color of the button while in active state\n   *\n   * @type {SnackbarType}\n   * @memberof SnackbarComponent\n   */\n  @Input() snackbarType: SnackbarType = 'success';\n\n  /**\n   * Snackbar message\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() message = '';\n\n  /**\n   * Snackbar message from html\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() set html(value: string) {\n    if (value) {\n      this.safeHtml = this.domSanitizer.bypassSecurityTrustHtml(value);\n    }\n  }\n\n  /**\n   * Set the time that the snackbar will be visible\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() seconds = 5;\n\n  /**\n   * Include dismmiss button\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() includeDismissButton = true;\n\n  /**\n   * Static or fixed position\n   *\n   * @memberof SnackbarComponent\n   */\n  @Input() fixed = true;\n\n  /**\n   * Link text that will appended at the end of message\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkText? = '';\n\n  /**\n   * Link url\n   *\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkUrl?: string;\n\n  /**\n   * Link target\n   *\n   * @type {@type {LinkTargetType}}\n   * @memberof AlertBannerComponent\n   */\n  @Input() linkTarget?: LinkTargetType = '_blank';\n\n  /**\n   * The language to be used\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * The variant to be used\n   *\n   * @type {SnackbarVariant}\n   * @memberof SnackbarComponent\n   */\n  @Input() variant: SnackbarVariant = 'desktop';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SnackbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Close button tooltip\n   *\n   * @type {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() closeButtonTooltip = '';\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 {string}\n   * @memberof SnackbarComponent\n   */\n  @Input() ariaDescribedby = '';\n\n  iconName: IconName;\n  showSnackbar = true;\n  milisenconds: number;\n  visible = false;\n  timer?: number;\n  timerStartedAt = 0;\n  timerPausedAt = 0;\n  position: string;\n  safeHtml: SafeHtml;\n\n  translationContext = 'SNACKBAR.';\n  protected readonly maxCharacters = 70;\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    @Inject(MAT_SNACK_BAR_DATA) private data: any,\n    private snackbarRef: MatSnackBarRef<SnackbarComponent>,\n    private domSanitizer: DomSanitizer,\n    @Optional() @Inject(CANOPY_UI_LANG) protected readonly appLang: Language,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (appLang) {\n      this.language = appLang;\n    }\n\n    this.snackbarType = data.snackbarType ?? 'success';\n    this.message = data.message ?? '';\n    this.safeHtml = data.html ? this.domSanitizer.bypassSecurityTrustHtml(data.html) : '';\n  }\n\n  ngOnInit(): void {\n    this.milisenconds = this.seconds * 1000;\n    this.iconName = alertBarsUtil.setIcon(this.snackbarType);\n    this.show();\n    this.position = alertBarsUtil.setPosition(this.fixed);\n  }\n\n  //Show snackbar\n  show() {\n    this.timerStartedAt = Date.now();\n    this.visible = true;\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds);\n  }\n\n  //Hide snackbar\n  hide() {\n    this.visible = false;\n    this.timerPausedAt = 0;\n    this.timerStartedAt = 0;\n    clearTimeout(this.timer);\n    this.timer = undefined;\n    this.snackbarRef.dismiss();\n  }\n\n  //Pause timer when mouse enter\n  onMouseEnter() {\n    this.visible = true;\n    this.timerPausedAt = Date.now();\n    clearTimeout(this.timer);\n  }\n\n  //Continue timer when mouse leave\n  onMouseLeave() {\n    const diff = this.timerPausedAt - this.timerStartedAt;\n    if (diff <= 0) {\n      return this.hide();\n    }\n    this.timer = window.setTimeout(() => this.hide(), this.milisenconds - diff);\n  }\n\n  //Hide snackbar when dismiss button is clicked\n  dismissClick() {\n    this.visible = false;\n    this.snackbarRef.dismiss();\n  }\n}\n","<ng-container>\n  <div\n    [ngClass]=\"snackbarType + ' ' + position\"\n    [@openClose]\n    *ngIf=\"visible\"\n    class=\"snackbar-container\"\n    [attr.theme]=\"applicationTheme\"\n    [class.mobile]=\"variant === 'mobile'\"\n    [class.desktop]=\"variant === 'desktop'\"\n    (mouseenter)=\"onMouseEnter()\"\n    (mouseleave)=\"onMouseLeave()\"\n    data-testid=\"snackbar-wrapper\"\n    [attr.data-test-snackbar-type]=\"snackbarType\"\n    [attr.aria-describedby]=\"'describedby'\"\n    role=\"alert\"\n    [attr.aria-labelledby]=\"'labelledby'\"\n  >\n    <span style=\"position: absolute; left: -9999px\" id=\"labelledby\">{{ ('ALERT_BANNER.' + (snackbarType | uppercase)) | uiTranslate : language }}</span>\n    <span style=\"position: absolute; left: -9999px\">{{ message }}\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </span>\n    <span [style.display]=\"'none'\" id=\"describedby\">{{ ariaDescribedby }}</span>\n    <div\n      aria-hidden=\"true\"\n      class=\"snackbar-text\"\n      [matTooltip]=\"message.length > maxCharacters ? message : ''\"\n      data-testid=\"snackbar-content\"\n    >\n      <ui-icon *ngIf=\"applicationTheme === 'classic'\" [name]=\"iconName\" size=\"24\"></ui-icon>\n      {{ message.length > maxCharacters ? (message | slice: 0:maxCharacters) + '..' : message }}\n      <div *ngIf=\"safeHtml\" [innerHTML]=\"safeHtml\"></div>\n      <a *ngIf=\"!!linkText\" [target]=\"linkTarget\" [href]=\"linkUrl\">{{ linkText }}</a>\n    </div>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme === 'classic'\"\n      variant=\"text\"\n      [label]=\"translationContext + 'DISMISS' | uiTranslate: language\"\n      [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n      (buttonClickEvent)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n    <ui-button\n      *ngIf=\"includeDismissButton && applicationTheme !== 'classic'\"\n      [variant]=\"'icon-button'\"\n      [applicationTheme]=\"'light'\"\n      [iconName]=\"'Close-in-line'\"\n      [size]=\"'small'\"\n      [tooltip]=\"closeButtonTooltip || ('COMMON.CLOSE' | uiTranslate: language)\"\n      (click)=\"dismissClick()\"\n      data-testid=\"snackbar-dismiss-button\"\n    ></ui-button>\n  </div>\n</ng-container>\n"]}
@@ -1,11 +1,14 @@
1
1
  import { Component, Inject, Input, Optional } from '@angular/core';
2
2
  import { LanguageService } from "../../utils/localization/language.service";
3
+ import { CANOPY_UI_LANG } from '../../tokens/app-lang.token';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/common";
5
6
  import * as i2 from "../../pipes/ui-translate.pipe";
7
+ import * as i3 from "../../utils/localization/language.model";
6
8
  export class SpinnerComponent {
7
- constructor(defaultAppTheme) {
9
+ constructor(defaultAppTheme, appLang) {
8
10
  this.defaultAppTheme = defaultAppTheme;
11
+ this.appLang = appLang;
9
12
  /**
10
13
  * The size variant of the spinner. Can be 'small' or 'large'.
11
14
  * Defaults to 'large'.
@@ -40,6 +43,9 @@ export class SpinnerComponent {
40
43
  if (defaultAppTheme) {
41
44
  this.applicationTheme = defaultAppTheme;
42
45
  }
46
+ if (appLang) {
47
+ this.language = appLang;
48
+ }
43
49
  }
44
50
  ngOnChanges() {
45
51
  this.setSpinnerClasses();
@@ -50,7 +56,7 @@ export class SpinnerComponent {
50
56
  setSpinnerClasses() {
51
57
  this.classes = `${this.size === 'large' ? 'large' : 'small'} ${this.isLoader ? 'loader' : ''} ${this.applicationTheme}`;
52
58
  }
53
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SpinnerComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
59
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SpinnerComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: CANOPY_UI_LANG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
54
60
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: SpinnerComponent, selector: "ui-spinner", inputs: { size: "size", language: "language", isLoader: "isLoader", applicationTheme: "applicationTheme" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"spinner-container\"\n [ngClass]=\"classes\"\n [attr.theme]=\"applicationTheme\"\n [attr.aria-label]=\"'COMMON.LOADING' | uiTranslate : language\"\n role=\"alert\"\n>\n <svg class=\"spinner\" viewBox=\"0 0 50 50\">\n <circle class=\"path\" cx=\"25\" cy=\"25\" r=\"20\" fill=\"none\"></circle>\n </svg>\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.spinner-container.large{width:48px;height:48px;stroke-width:8px}.spinner-container.large .spinner{width:48px;height:48px}.spinner-container.small{stroke-width:4px;width:16px;height:16px}.spinner-container.small .spinner{width:16px;height:16px}.spinner-container .spinner{animation:rotate 2s linear infinite;width:48px;height:48px}.spinner-container .spinner .path{stroke:#d410aa;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}.spinner-container.classic .spinner .path{stroke:#276678}.spinner-container.loader{position:fixed;top:50%;left:50%;z-index:999;margin:-25px 0 0 -25px}.spinner-container[theme=dark] .path{stroke:#fff!important}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.UiTranslatePipe, name: "uiTranslate" }] }); }
55
61
  }
56
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: SpinnerComponent, decorators: [{
@@ -61,6 +67,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
61
67
  }, {
62
68
  type: Inject,
63
69
  args: ['CANOPYUI_DEFAULT_APPLICATION_THEME']
70
+ }] }, { type: i3.Language, decorators: [{
71
+ type: Optional
72
+ }, {
73
+ type: Inject,
74
+ args: [CANOPY_UI_LANG]
64
75
  }] }], propDecorators: { size: [{
65
76
  type: Input
66
77
  }], language: [{
@@ -70,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
70
81
  }], applicationTheme: [{
71
82
  type: Input
72
83
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFxQixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOzs7O0FBTzVFLE1BQU0sT0FBTyxnQkFBZ0I7SUFzQzNCLFlBQzZFLGVBQWlDO1FBQWpDLG9CQUFlLEdBQWYsZUFBZSxDQUFrQjtRQXRDOUc7Ozs7OztXQU1HO1FBQ00sU0FBSSxHQUFnQixPQUFPLENBQUM7UUFFckM7Ozs7O1dBS0c7UUFDTSxhQUFRLEdBQUcsZUFBZSxDQUFDLGVBQWUsQ0FBQztRQUVwRDs7Ozs7O1dBTUc7UUFDTSxhQUFRLEdBQUcsSUFBSSxDQUFDO1FBRXpCOzs7Ozs7V0FNRztRQUNNLHFCQUFnQixHQUFxQixPQUFPLENBQUM7UUFPcEQsSUFBSSxlQUFlLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZUFBZSxDQUFDO1FBQzFDLENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELGlCQUFpQjtRQUNmLElBQUksQ0FBQyxPQUFPLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDMUgsQ0FBQzs4R0F4RFUsZ0JBQWdCLGtCQXVDTCxvQ0FBb0M7a0dBdkMvQyxnQkFBZ0IsbUxDVjdCLDBWQVVBOzsyRkRBYSxnQkFBZ0I7a0JBTDVCLFNBQVM7K0JBQ0UsWUFBWTs7MEJBMkNuQixRQUFROzswQkFBSSxNQUFNOzJCQUFDLG9DQUFvQzt5Q0EvQmpELElBQUk7c0JBQVosS0FBSztnQkFRRyxRQUFRO3NCQUFoQixLQUFLO2dCQVNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBU0csZ0JBQWdCO3NCQUF4QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNwaW5uZXJTaXplIH0gZnJvbSAnLi9zcGlubmVyLm1vZGVsJztcbmltcG9ydCB7IEFwcGxpY2F0aW9uVGhlbWUgfSBmcm9tICcuLi8uLi9tb2RlbHMvYXBwbGljYXRpb24tdGhlbWUubW9kZWwnO1xuaW1wb3J0IHsgTGFuZ3VhZ2VTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL3V0aWxzL2xvY2FsaXphdGlvbi9sYW5ndWFnZS5zZXJ2aWNlXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3VpLXNwaW5uZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vc3Bpbm5lci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3NwaW5uZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgU3Bpbm5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgLyoqXG4gICAqIFRoZSBzaXplIHZhcmlhbnQgb2YgdGhlIHNwaW5uZXIuIENhbiBiZSAnc21hbGwnIG9yICdsYXJnZScuXG4gICAqIERlZmF1bHRzIHRvICdsYXJnZScuXG4gICAqIEBkZWZhdWx0ICdsYXJnZSdcbiAgICogQHR5cGUge1NwaW5uZXJTaXplfVxuICAgKiBAbWVtYmVyb2YgU3Bpbm5lckNvbXBvbmVudFxuICAgKi9cbiAgQElucHV0KCkgc2l6ZTogU3Bpbm5lclNpemUgPSAnbGFyZ2UnO1xuXG4gIC8qKlxuICAgKiBUaGUgbGFuZ3VhZ2UgdG8gYmUgdXNlZFxuICAgKlxuICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgKiBAbWVtYmVyb2YgU3Bpbm5lckNvbXBvbmVudFxuICAgKi9cbiAgQElucHV0KCkgbGFuZ3VhZ2UgPSBMYW5ndWFnZVNlcnZpY2UuZGVmYXVsdExhbmd1YWdlO1xuXG4gIC8qKlxuICAgKiBTZXQgcG9zaXRpb24gZml4ZWQgb24gcGFnZVxuICAgKiBEZWZhdWx0cyB0byAndHJ1ZScuXG4gICAqIEBkZWZhdWx0ICd0cnVlJ1xuICAgKiBAdHlwZSB7U3Bpbm5lclNpemV9XG4gICAqIEBtZW1iZXJvZiBTcGlubmVyQ29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKSBpc0xvYWRlciA9IHRydWU7XG5cbiAgLyoqXG4gICAqXG4gICAqIERlZmluZXMgdGhlIGFwcGxpY2F0aW9uIHRoZW1lXG4gICAqXG4gICAqIEB0eXBlIHtBcHBsaWNhdGlvblRoZW1lfVxuICAgKiBAbWVtYmVyb2YgU3Bpbm5lckNvbXBvbmVudFxuICAgKi9cbiAgQElucHV0KCkgYXBwbGljYXRpb25UaGVtZTogQXBwbGljYXRpb25UaGVtZSA9ICdsaWdodCc7XG5cbiAgY2xhc3Nlczogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBPcHRpb25hbCgpIEBJbmplY3QoJ0NBTk9QWVVJX0RFRkFVTFRfQVBQTElDQVRJT05fVEhFTUUnKSBwcml2YXRlIHJlYWRvbmx5IGRlZmF1bHRBcHBUaGVtZTogQXBwbGljYXRpb25UaGVtZSxcbiAgKSB7XG4gICAgaWYgKGRlZmF1bHRBcHBUaGVtZSkge1xuICAgICAgdGhpcy5hcHBsaWNhdGlvblRoZW1lID0gZGVmYXVsdEFwcFRoZW1lO1xuICAgIH1cbiAgfVxuXG4gIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIHRoaXMuc2V0U3Bpbm5lckNsYXNzZXMoKTtcbiAgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuc2V0U3Bpbm5lckNsYXNzZXMoKTtcbiAgfVxuXG4gIHNldFNwaW5uZXJDbGFzc2VzKCk6IHZvaWQge1xuICAgIHRoaXMuY2xhc3NlcyA9IGAke3RoaXMuc2l6ZSA9PT0gJ2xhcmdlJyA/ICdsYXJnZScgOiAnc21hbGwnfSAke3RoaXMuaXNMb2FkZXIgPyAnbG9hZGVyJyA6ICcnfSAke3RoaXMuYXBwbGljYXRpb25UaGVtZX1gO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic3Bpbm5lci1jb250YWluZXJcIlxuICAgICBbbmdDbGFzc109XCJjbGFzc2VzXCJcbiAgICAgW2F0dHIudGhlbWVdPVwiYXBwbGljYXRpb25UaGVtZVwiXG4gICAgIFthdHRyLmFyaWEtbGFiZWxdPVwiJ0NPTU1PTi5MT0FESU5HJyB8IHVpVHJhbnNsYXRlIDogbGFuZ3VhZ2VcIlxuICAgICByb2xlPVwiYWxlcnRcIlxuPlxuICA8c3ZnIGNsYXNzPVwic3Bpbm5lclwiIHZpZXdCb3g9XCIwIDAgNTAgNTBcIj5cbiAgICA8Y2lyY2xlIGNsYXNzPVwicGF0aFwiIGN4PVwiMjVcIiBjeT1cIjI1XCIgcj1cIjIwXCIgZmlsbD1cIm5vbmVcIj48L2NpcmNsZT5cbiAgPC9zdmc+XG48L2Rpdj5cbiJdfQ==
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFxQixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7Ozs7QUFRN0QsTUFBTSxPQUFPLGdCQUFnQjtJQXNDM0IsWUFDNkUsZUFBaUMsRUFDckQsT0FBaUI7UUFERyxvQkFBZSxHQUFmLGVBQWUsQ0FBa0I7UUFDckQsWUFBTyxHQUFQLE9BQU8sQ0FBVTtRQXZDMUU7Ozs7OztXQU1HO1FBQ00sU0FBSSxHQUFnQixPQUFPLENBQUM7UUFFckM7Ozs7O1dBS0c7UUFDTSxhQUFRLEdBQUcsZUFBZSxDQUFDLGVBQWUsQ0FBQztRQUVwRDs7Ozs7O1dBTUc7UUFDTSxhQUFRLEdBQUcsSUFBSSxDQUFDO1FBRXpCOzs7Ozs7V0FNRztRQUNNLHFCQUFnQixHQUFxQixPQUFPLENBQUM7UUFRcEQsSUFBSSxlQUFlLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZUFBZSxDQUFDO1FBQzFDLENBQUM7UUFFRCxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUM7UUFDMUIsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUMxSCxDQUFDOzhHQTdEVSxnQkFBZ0Isa0JBdUNMLG9DQUFvQyw2QkFDcEMsY0FBYztrR0F4Q3pCLGdCQUFnQixtTENaN0IsMFZBVUE7OzJGREVhLGdCQUFnQjtrQkFMNUIsU0FBUzsrQkFDRSxZQUFZOzswQkEyQ25CLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsb0NBQW9DOzswQkFDdkQsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxjQUFjO3lDQWhDM0IsSUFBSTtzQkFBWixLQUFLO2dCQVFHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBU0csUUFBUTtzQkFBaEIsS0FBSztnQkFTRyxnQkFBZ0I7c0JBQXhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgSW5wdXQsIE9uQ2hhbmdlcywgT25Jbml0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Bpbm5lclNpemUgfSBmcm9tICcuL3NwaW5uZXIubW9kZWwnO1xuaW1wb3J0IHsgQXBwbGljYXRpb25UaGVtZSB9IGZyb20gJy4uLy4uL21vZGVscy9hcHBsaWNhdGlvbi10aGVtZS5tb2RlbCc7XG5pbXBvcnQgeyBMYW5ndWFnZVNlcnZpY2UgfSBmcm9tIFwiLi4vLi4vdXRpbHMvbG9jYWxpemF0aW9uL2xhbmd1YWdlLnNlcnZpY2VcIjtcbmltcG9ydCB7IENBTk9QWV9VSV9MQU5HIH0gZnJvbSAnLi4vLi4vdG9rZW5zL2FwcC1sYW5nLnRva2VuJztcbmltcG9ydCB7IExhbmd1YWdlIH0gZnJvbSAnLi4vLi4vdXRpbHMvbG9jYWxpemF0aW9uL2xhbmd1YWdlLm1vZGVsJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndWktc3Bpbm5lcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9zcGlubmVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3Bpbm5lci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBTcGlubmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAvKipcbiAgICogVGhlIHNpemUgdmFyaWFudCBvZiB0aGUgc3Bpbm5lci4gQ2FuIGJlICdzbWFsbCcgb3IgJ2xhcmdlJy5cbiAgICogRGVmYXVsdHMgdG8gJ2xhcmdlJy5cbiAgICogQGRlZmF1bHQgJ2xhcmdlJ1xuICAgKiBAdHlwZSB7U3Bpbm5lclNpemV9XG4gICAqIEBtZW1iZXJvZiBTcGlubmVyQ29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKSBzaXplOiBTcGlubmVyU2l6ZSA9ICdsYXJnZSc7XG5cbiAgLyoqXG4gICAqIFRoZSBsYW5ndWFnZSB0byBiZSB1c2VkXG4gICAqXG4gICAqIEB0eXBlIHtzdHJpbmd9XG4gICAqIEBtZW1iZXJvZiBTcGlubmVyQ29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKSBsYW5ndWFnZSA9IExhbmd1YWdlU2VydmljZS5kZWZhdWx0TGFuZ3VhZ2U7XG5cbiAgLyoqXG4gICAqIFNldCBwb3NpdGlvbiBmaXhlZCBvbiBwYWdlXG4gICAqIERlZmF1bHRzIHRvICd0cnVlJy5cbiAgICogQGRlZmF1bHQgJ3RydWUnXG4gICAqIEB0eXBlIHtTcGlubmVyU2l6ZX1cbiAgICogQG1lbWJlcm9mIFNwaW5uZXJDb21wb25lbnRcbiAgICovXG4gIEBJbnB1dCgpIGlzTG9hZGVyID0gdHJ1ZTtcblxuICAvKipcbiAgICpcbiAgICogRGVmaW5lcyB0aGUgYXBwbGljYXRpb24gdGhlbWVcbiAgICpcbiAgICogQHR5cGUge0FwcGxpY2F0aW9uVGhlbWV9XG4gICAqIEBtZW1iZXJvZiBTcGlubmVyQ29tcG9uZW50XG4gICAqL1xuICBASW5wdXQoKSBhcHBsaWNhdGlvblRoZW1lOiBBcHBsaWNhdGlvblRoZW1lID0gJ2xpZ2h0JztcblxuICBjbGFzc2VzOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdCgnQ0FOT1BZVUlfREVGQVVMVF9BUFBMSUNBVElPTl9USEVNRScpIHByaXZhdGUgcmVhZG9ubHkgZGVmYXVsdEFwcFRoZW1lOiBBcHBsaWNhdGlvblRoZW1lLFxuICAgIEBPcHRpb25hbCgpIEBJbmplY3QoQ0FOT1BZX1VJX0xBTkcpIHByb3RlY3RlZCByZWFkb25seSBhcHBMYW5nOiBMYW5ndWFnZSxcbiAgKSB7XG4gICAgaWYgKGRlZmF1bHRBcHBUaGVtZSkge1xuICAgICAgdGhpcy5hcHBsaWNhdGlvblRoZW1lID0gZGVmYXVsdEFwcFRoZW1lO1xuICAgIH1cblxuICAgIGlmIChhcHBMYW5nKSB7XG4gICAgICB0aGlzLmxhbmd1YWdlID0gYXBwTGFuZztcbiAgICB9XG4gIH1cblxuICBuZ09uQ2hhbmdlcygpOiB2b2lkIHtcbiAgICB0aGlzLnNldFNwaW5uZXJDbGFzc2VzKCk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnNldFNwaW5uZXJDbGFzc2VzKCk7XG4gIH1cblxuICBzZXRTcGlubmVyQ2xhc3NlcygpOiB2b2lkIHtcbiAgICB0aGlzLmNsYXNzZXMgPSBgJHt0aGlzLnNpemUgPT09ICdsYXJnZScgPyAnbGFyZ2UnIDogJ3NtYWxsJ30gJHt0aGlzLmlzTG9hZGVyID8gJ2xvYWRlcicgOiAnJ30gJHt0aGlzLmFwcGxpY2F0aW9uVGhlbWV9YDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInNwaW5uZXItY29udGFpbmVyXCJcbiAgICAgW25nQ2xhc3NdPVwiY2xhc3Nlc1wiXG4gICAgIFthdHRyLnRoZW1lXT1cImFwcGxpY2F0aW9uVGhlbWVcIlxuICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIidDT01NT04uTE9BRElORycgfCB1aVRyYW5zbGF0ZSA6IGxhbmd1YWdlXCJcbiAgICAgcm9sZT1cImFsZXJ0XCJcbj5cbiAgPHN2ZyBjbGFzcz1cInNwaW5uZXJcIiB2aWV3Qm94PVwiMCAwIDUwIDUwXCI+XG4gICAgPGNpcmNsZSBjbGFzcz1cInBhdGhcIiBjeD1cIjI1XCIgY3k9XCIyNVwiIHI9XCIyMFwiIGZpbGw9XCJub25lXCI+PC9jaXJjbGU+XG4gIDwvc3ZnPlxuPC9kaXY+XG4iXX0=
@@ -1,6 +1,7 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output, } from '@angular/core';
2
2
  import { IS_MOBILE_TOKEN } from '../../providers/is-mobile';
3
3
  import { LanguageService } from '../../utils/localization/language.service';
4
+ import { CANOPY_UI_LANG } from '../../tokens/app-lang.token';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common";
6
7
  import * as i2 from "../icon/icon.component";
@@ -9,6 +10,7 @@ import * as i4 from "../radial-progress/radial-progress.component";
9
10
  import * as i5 from "../../directives/step-line-element.directive";
10
11
  import * as i6 from "../../pipes/ui-translate.pipe";
11
12
  import * as i7 from "rxjs";
13
+ import * as i8 from "../../utils/localization/language.model";
12
14
  export class StepperComponent {
13
15
  /**
14
16
  *
@@ -56,9 +58,10 @@ export class StepperComponent {
56
58
  set isOpen(value) {
57
59
  this.isOpened = value;
58
60
  }
59
- constructor(defaultAppTheme, isMobile$) {
61
+ constructor(defaultAppTheme, isMobile$, appLang) {
60
62
  this.defaultAppTheme = defaultAppTheme;
61
63
  this.isMobile$ = isMobile$;
64
+ this.appLang = appLang;
62
65
  /**
63
66
  * Input property indicating whether the final icon should be displayed.
64
67
  * Default value is false.
@@ -105,6 +108,9 @@ export class StepperComponent {
105
108
  if (defaultAppTheme) {
106
109
  this.applicationTheme = defaultAppTheme;
107
110
  }
111
+ if (appLang) {
112
+ this.language = appLang;
113
+ }
108
114
  }
109
115
  onSelect(changedIndex, step) {
110
116
  if (!step.isVisited && this.selectedIndex !== changedIndex) {
@@ -120,7 +126,7 @@ export class StepperComponent {
120
126
  onCloseStepList() {
121
127
  this.isOpen = false;
122
128
  }
123
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: StepperComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: IS_MOBILE_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
129
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: StepperComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: IS_MOBILE_TOKEN }, { token: CANOPY_UI_LANG, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
124
130
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: StepperComponent, selector: "ui-stepper", inputs: { setFirstStepAutoSelect: ["firstStepAutoSelect", "setFirstStepAutoSelect"], steps: "steps", setSelectedIndex: ["selectedIndex", "setSelectedIndex"], lastStepFinalIcon: "lastStepFinalIcon", language: "language", applicationTheme: "applicationTheme", ariaLabel: "ariaLabel", position: "position", ariaRequired: "ariaRequired" }, outputs: { selectionChange: "selectionChange" }, ngImport: i0, template: "<ng-container>\n <div class=\"stepper-wrapper\" [ngClass]=\"position\" [attr.theme]=\"applicationTheme\" *ngIf=\"(position === 'horizontal' && !(isMobile$ | async)) || (position === 'vertical'); 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 [htmlDescription]=\"step.htmlDescription ?? []\"\n [boldLabel]=\"!!step.boldLabel\"\n [position]=\"position\"\n [descriptionTpl]=\"step.descriptionTpl\"\n [labelTooltip]=\"step.labelTooltip\"\n [alwaysShowIcon]=\"!!step.alwaysShowIcon\"\n [context]=\"step.context\"\n ></ui-step>\n </div>\n <div *ngIf=\"!isLast\" class=\"separator-line\" [ngClass]=\"{ visited: step.isVisited && !!this.itemSteps[i + 1]?.isVisited }\">\n <div [stepLineElement]=\"stepElement\" [position]=\"position\" 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 [applicationTheme]=\"applicationTheme\" [size]=\"'24'\" [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"></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", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}@media (max-width: 1024px){:host{width:100%}}@media (max-width: 600px){:host{width:fit-content}}.row,.mobile-stepper-wrapper .stepper,.stepper-wrapper .step,.stepper-wrapper{display:flex;flex-direction:row}.column,.mobile-stepper-wrapper .step-list,.mobile-stepper-wrapper .stepper .step-info{display:flex;flex-direction:column}.stepper-wrapper{width:100%}.stepper-wrapper .step{max-width:200px}.stepper-wrapper .separator-line{display:flex;flex:1 1 auto;position:relative;z-index:2}.stepper-wrapper .separator-line.visited .line{border-top:2px solid #276678}.stepper-wrapper .separator-line .line{position:absolute;top:45px;border-top:2px solid #C8D7DE;width:100%;left:0}.stepper-wrapper.vertical{flex-direction:column}.stepper-wrapper.vertical .step{max-width:1024px;width:100%}.stepper-wrapper.vertical .step ui-step{width:100%}.stepper-wrapper.vertical .separator-line.visited .line{border-right:2px solid #276678}.stepper-wrapper.vertical .separator-line .line{top:-15px;border-right:2px solid #C8D7DE;width:2px;left:34px}.stepper-wrapper[theme=dark] .separator-line.visited .line,.stepper-wrapper[theme=light] .separator-line.visited .line{border-top:2px solid #242424}.stepper-wrapper[theme=dark] .separator-line .line,.stepper-wrapper[theme=light] .separator-line .line{border-top:2px solid #D3D3D3}.stepper-wrapper[theme=dark].vertical .separator-line.visited .line,.stepper-wrapper[theme=light].vertical .separator-line.visited .line{border-right:2px solid #242424}.stepper-wrapper[theme=dark].vertical .separator-line .line,.stepper-wrapper[theme=light].vertical .separator-line .line{border-right:2px solid #D3D3D3}.mobile-stepper-wrapper{width:100%;position:relative}.mobile-stepper-wrapper .stepper{padding:12px 16px;height:72px;border:1px solid #888888;background:#fff;border-radius:8px}.mobile-stepper-wrapper .stepper .step-info{width:100%}.mobile-stepper-wrapper .stepper .step-info .current-step{font-weight:700;font-size:16px;line-height:24px}.mobile-stepper-wrapper .stepper .step-info .next-step{margin-top:4px;font-size:14px;line-height:20px}.mobile-stepper-wrapper .stepper .step-info .current-step,.mobile-stepper-wrapper .stepper .step-info .next-step{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.mobile-stepper-wrapper .stepper .open-steps{cursor:pointer;display:flex;justify-content:center;align-items:center}.mobile-stepper-wrapper .stepper .open-steps.opened ::ng-deep ui-icon{transform:rotateX(-180deg)}.mobile-stepper-wrapper .stepper .progress-step{position:relative;width:40px;height:40px;margin-right:16px}.mobile-stepper-wrapper .step-list{position:absolute;width:100%;margin-top:4px;z-index:1;background:#fff;box-shadow:0 8px 24px 4px #00000014;border-bottom-right-radius:8px;border-bottom-left-radius:8px}.mobile-stepper-wrapper .overlay{position:fixed;width:100%;height:100%;left:0;top:0;z-index:-1;background:transparent}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme"] }, { kind: "component", type: i3.StepComponent, selector: "ui-step", inputs: ["label", "isVisited", "submitted", "icon", "index", "selected", "isLast", "selectedIndex", "disabled", "prevStepIsVisited", "mobileMode", "finalIcon", "showIconWhenSelected", "applicationTheme", "position", "htmlDescription", "boldLabel", "descriptionTpl", "labelTooltip", "alwaysShowIcon", "context"], outputs: ["stepSelected"] }, { kind: "component", type: i4.RadialProgressComponent, selector: "ui-radial-progress", inputs: ["size", "value", "total", "variant", "icon", "buttonTooltip", "companyColor", "applicationTheme"], outputs: ["buttonClicked"] }, { kind: "directive", type: i5.StepLineElementDirective, selector: "[stepLineElement]", inputs: ["stepLineElement", "position"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.UiTranslatePipe, name: "uiTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
125
131
  }
126
132
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: StepperComponent, decorators: [{
@@ -134,6 +140,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
134
140
  }] }, { type: i7.Observable, decorators: [{
135
141
  type: Inject,
136
142
  args: [IS_MOBILE_TOKEN]
143
+ }] }, { type: i8.Language, decorators: [{
144
+ type: Optional
145
+ }, {
146
+ type: Inject,
147
+ args: [CANOPY_UI_LANG]
137
148
  }] }], propDecorators: { setFirstStepAutoSelect: [{
138
149
  type: Input,
139
150
  args: ['firstStepAutoSelect']
@@ -157,4 +168,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
157
168
  }], selectionChange: [{
158
169
  type: Output
159
170
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/stepper/stepper.component.ts","../../../../../projects/tgo-canopy-ui/components/stepper/stepper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { Step, StepperPosition } 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   *\n   * Auto selects first step as visited\n   * Defaults to true\n   *\n   * @memberof StepperComponent\n   */\n  @Input('firstStepAutoSelect') set setFirstStepAutoSelect(value: boolean) {\n    this.firstStepAutoSelect = value;\n    if (!this.firstStepAutoSelect) {\n      this.itemSteps = this.itemSteps.map((step, i) => ({...step, isVisited: i === 0 && this.selectedIndex === -1 ? false : step.isVisited}));\n    }\n  };\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    if (itemSteps.length && this.firstStepAutoSelect) {\n      const [first, ...other] = itemSteps;\n      first.isVisited = true;\n      this.itemSteps = [first, ...other];\n    }\n\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') set setSelectedIndex(value: number) {\n    this.selectedIndex = value;\n    if (!this.firstStepAutoSelect) {\n      this.itemSteps = this.itemSteps.map((step, i) => ({...step, isVisited: i === 0 && this.selectedIndex === -1 ? false : step.isVisited}));\n    }\n  }\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   * Defines the stepper position\n   *\n   * @type {StepperPosition}\n   * @memberof StepperComponent\n   */\n  @Input() position: StepperPosition = 'horizontal';\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  private firstStepAutoSelect = true;\n  protected itemSteps: Step[] = [];\n  protected progressValue = 0;\n  protected translationContext = 'STEPPER.';\n  protected selectedIndex = 0;\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\" [ngClass]=\"position\" [attr.theme]=\"applicationTheme\" *ngIf=\"(position === 'horizontal' && !(isMobile$ | async)) || (position === 'vertical'); 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          [htmlDescription]=\"step.htmlDescription ?? []\"\n          [boldLabel]=\"!!step.boldLabel\"\n          [position]=\"position\"\n          [descriptionTpl]=\"step.descriptionTpl\"\n          [labelTooltip]=\"step.labelTooltip\"\n          [alwaysShowIcon]=\"!!step.alwaysShowIcon\"\n          [context]=\"step.context\"\n        ></ui-step>\n      </div>\n      <div *ngIf=\"!isLast\" class=\"separator-line\" [ngClass]=\"{ visited: step.isVisited && !!this.itemSteps[i + 1]?.isVisited }\">\n        <div [stepLineElement]=\"stepElement\" [position]=\"position\" 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 [applicationTheme]=\"applicationTheme\" [size]=\"'24'\" [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"></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"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/stepper/stepper.component.ts","../../../../../projects/tgo-canopy-ui/components/stepper/stepper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { Step, StepperPosition } 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\";\nimport { CANOPY_UI_LANG } from '../../tokens/app-lang.token';\nimport { Language } from '../../utils/localization/language.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   *\n   * Auto selects first step as visited\n   * Defaults to true\n   *\n   * @memberof StepperComponent\n   */\n  @Input('firstStepAutoSelect') set setFirstStepAutoSelect(value: boolean) {\n    this.firstStepAutoSelect = value;\n    if (!this.firstStepAutoSelect) {\n      this.itemSteps = this.itemSteps.map((step, i) => ({...step, isVisited: i === 0 && this.selectedIndex === -1 ? false : step.isVisited}));\n    }\n  };\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    if (itemSteps.length && this.firstStepAutoSelect) {\n      const [first, ...other] = itemSteps;\n      first.isVisited = true;\n      this.itemSteps = [first, ...other];\n    }\n\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') set setSelectedIndex(value: number) {\n    this.selectedIndex = value;\n    if (!this.firstStepAutoSelect) {\n      this.itemSteps = this.itemSteps.map((step, i) => ({...step, isVisited: i === 0 && this.selectedIndex === -1 ? false : step.isVisited}));\n    }\n  }\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   * Defines the stepper position\n   *\n   * @type {StepperPosition}\n   * @memberof StepperComponent\n   */\n  @Input() position: StepperPosition = 'horizontal';\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  private firstStepAutoSelect = true;\n  protected itemSteps: Step[] = [];\n  protected progressValue = 0;\n  protected translationContext = 'STEPPER.';\n  protected selectedIndex = 0;\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    @Optional() @Inject(CANOPY_UI_LANG) protected readonly appLang: Language,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (appLang) {\n      this.language = appLang;\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\" [ngClass]=\"position\" [attr.theme]=\"applicationTheme\" *ngIf=\"(position === 'horizontal' && !(isMobile$ | async)) || (position === 'vertical'); 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          [htmlDescription]=\"step.htmlDescription ?? []\"\n          [boldLabel]=\"!!step.boldLabel\"\n          [position]=\"position\"\n          [descriptionTpl]=\"step.descriptionTpl\"\n          [labelTooltip]=\"step.labelTooltip\"\n          [alwaysShowIcon]=\"!!step.alwaysShowIcon\"\n          [context]=\"step.context\"\n        ></ui-step>\n      </div>\n      <div *ngIf=\"!isLast\" class=\"separator-line\" [ngClass]=\"{ visited: step.isVisited && !!this.itemSteps[i + 1]?.isVisited }\">\n        <div [stepLineElement]=\"stepElement\" [position]=\"position\" 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 [applicationTheme]=\"applicationTheme\" [size]=\"'24'\" [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"></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"]}