design-angular-kit 1.2.2 → 1.3.0

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 (39) hide show
  1. package/assets/i18n/en.json +89 -0
  2. package/assets/i18n/it.json +89 -0
  3. package/esm2022/lib/abstracts/abstract-form.component.mjs +19 -6
  4. package/esm2022/lib/components/core/carousel/carousel/carousel.component.mjs +8 -6
  5. package/esm2022/lib/components/core/video-player/video-player-i18n.model.mjs +2 -0
  6. package/esm2022/lib/components/core/video-player/video-player-i18n.service.mjs +130 -0
  7. package/esm2022/lib/components/core/video-player/video-player.component.mjs +303 -0
  8. package/esm2022/lib/components/core/video-player/video-player.config.mjs +43 -0
  9. package/esm2022/lib/components/core/video-player/video-player.cookie.mjs +25 -0
  10. package/esm2022/lib/components/core/video-player/video-player.model.mjs +3 -0
  11. package/esm2022/lib/components/core/video-player/video-player.module.mjs +16 -0
  12. package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +144 -78
  13. package/esm2022/lib/components/form/form.module.mjs +6 -2
  14. package/esm2022/lib/components/form/input/input.component.mjs +3 -3
  15. package/esm2022/lib/components/form/search/search.component.mjs +112 -0
  16. package/esm2022/lib/components/navigation/navscroll/navscroll-list-item.component.mjs +2 -3
  17. package/esm2022/lib/design-angular-kit.module.mjs +8 -4
  18. package/esm2022/lib/interfaces/form.mjs +1 -1
  19. package/esm2022/lib/validators/it-validators.mjs +6 -1
  20. package/esm2022/public_api.mjs +7 -3
  21. package/fesm2022/design-angular-kit.mjs +782 -90
  22. package/fesm2022/design-angular-kit.mjs.map +1 -1
  23. package/lib/abstracts/abstract-form.component.d.ts +6 -4
  24. package/lib/components/core/carousel/carousel/carousel.component.d.ts +1 -1
  25. package/lib/components/core/video-player/video-player-i18n.model.d.ts +179 -0
  26. package/lib/components/core/video-player/video-player-i18n.service.d.ts +17 -0
  27. package/lib/components/core/video-player/video-player.component.d.ts +48 -0
  28. package/lib/components/core/video-player/video-player.config.d.ts +68 -0
  29. package/lib/components/core/video-player/video-player.cookie.d.ts +6 -0
  30. package/lib/components/core/video-player/video-player.model.d.ts +44 -0
  31. package/lib/components/core/video-player/video-player.module.d.ts +7 -0
  32. package/lib/components/form/autocomplete/autocomplete.component.d.ts +55 -39
  33. package/lib/components/form/form.module.d.ts +13 -12
  34. package/lib/components/form/search/search.component.d.ts +59 -0
  35. package/lib/design-angular-kit.module.d.ts +18 -17
  36. package/lib/interfaces/form.d.ts +3 -3
  37. package/lib/validators/it-validators.d.ts +1 -0
  38. package/package.json +20 -7
  39. package/public_api.d.ts +6 -2
@@ -173,6 +173,95 @@
173
173
  "months": "{{count}} months",
174
174
  "year": "{{count}} year",
175
175
  "years": "{{count}} years"
176
+ },
177
+ "video-player": {
178
+ "audio-player": "Lettore audio",
179
+ "video-player": "Lettore video",
180
+ "play": "Play",
181
+ "pause": "Pause",
182
+ "replay": "Replay",
183
+ "current-time": "Orario attuale",
184
+ "duration": "Durata",
185
+ "remaining-time": "Tempo rimanente",
186
+ "stream-type": "Tipo di streaming",
187
+ "live": "LIVE",
188
+ "loaded": "Caricato",
189
+ "progress": "Stato",
190
+ "progress-bar": "Barra di avanzamento",
191
+ "progress-bar-timing:-currenttime={1}-duration={2}": "{1} di {2}",
192
+ "fullscreen": "Schermo intero",
193
+ "exit-fullscreen": "Chiudi Schermo intero",
194
+ "mute": "Disattiva l’audio",
195
+ "unmute": "Attiva l’audio",
196
+ "playback-rate": "Velocità di riproduzione",
197
+ "subtitles": "Sottotitoli",
198
+ "subtitles-off": "Senza sottotitoli",
199
+ "captions": "Sottotitoli non udenti",
200
+ "captions-off": "Senza sottotitoli non udenti",
201
+ "chapters": "Capitolo",
202
+ "descriptions": "Descrizioni",
203
+ "descriptions-off": "Descrizioni disattivate",
204
+ "audio-track": "Traccia audio",
205
+ "volume-level": "Livello del volume",
206
+ "you-aborted-the-media-playback": "La riproduzione del filmato è stata interrotta.",
207
+ "a-network-error-caused-the-media-download-to-fail-part-way.": "Il download del filmato è stato interrotto a causa di un problema rete.",
208
+ "the-media-could-not-be-loaded,-either-because-the-server-or-network-failed-or-because-the-format-is-not-supported.": "Il filmato non può essere caricato a causa di un errore nel server o nella rete o perché il formato non viene supportato.",
209
+ "the-media-playback-was-aborted-due-to-a-corruption-problem-or-because-the-media-used-features-your-browser-did-not-support.": "La riproduzione del filmato è stata interrotta a causa di un file danneggiato o per l’utilizzo di impostazioni non supportate dal browser.",
210
+ "no-compatible-source-was-found-for-this-media.": "Non ci sono fonti compatibili per questo filmato.",
211
+ "the-media-is-encrypted-and-we-do-not-have-the-keys-to-decrypt-it.": "Il contenuto multimediale è criptato e non disponiamo delle chiavi per decifrarlo.",
212
+ "play-video": "Riproduci il video",
213
+ "close": "Chiudi",
214
+ "close-modal-dialog": "Chiudi la finestra di dialogo",
215
+ "modal-window": "Finestra di dialogo",
216
+ "this-is-a-modal-window": "Questa è una finestra di dialogo",
217
+ "this-modal-can-be-closed-by-pressing-the-escape-key-or-activating-the-close-button.": "Questa finestra di dialogo può essere chiusa premendo sul tasto Esc o attivando il pulsante di chiusura.",
218
+ ",-opens-captions-settings-dialog": ", aprire i parametri della trascrizione dei sottotitoli",
219
+ ",-opens-subtitles-settings-dialog": ", aprire i parametri dei sottotitoli",
220
+ ",-opens-descriptions-settings-dialog": ", aprire i parametri delle descrizioni",
221
+ ",-selected": ", selezionato",
222
+ "captions-settings": "Parametri sottotitoli non udenti",
223
+ "subtitles-settings": "Parametri sottotitoli",
224
+ "descriptions-settings": "Parametri descrizioni",
225
+ "text": "Testo",
226
+ "white": "Bianco",
227
+ "black": "Nero",
228
+ "red": "Rosso",
229
+ "green": "Verde",
230
+ "blue": "Blu",
231
+ "yellow": "Giallo",
232
+ "magenta": "Magenta",
233
+ "cyan": "Ciano",
234
+ "background": "Sfondo",
235
+ "window": "Finestra",
236
+ "transparent": "Trasparente",
237
+ "semi-transparent": "Semi-Trasparente",
238
+ "opaque": "Opaco",
239
+ "font-size": "Dimensione dei caratteri",
240
+ "text-edge-style": "Stile dei bordi del testo",
241
+ "none": "Nessuno",
242
+ "uniform": "Uniforme",
243
+ "drop-shadow": "Ombra",
244
+ "font-family": "Carattere",
245
+ "proportional-sans-serif": "Sans-Serif proporzionale",
246
+ "monospace-sans-serif": "Sans-Serif monospaziato",
247
+ "proportional-serif": "Serif proporzionale",
248
+ "monospace-serif": "Serif monospaziato",
249
+ "small-caps": "Maiuscoletto",
250
+ "reset": "Reinizializza",
251
+ "restore-all-settings-to-the-default-values": "Ripristina i valori predefiniti per tutti i parametri",
252
+ "done": "Fatto",
253
+ "caption-settings-dialog": "Finestra di dialogo dei parametri della trascrizione dei sottotitoli",
254
+ "beginning-of-dialog-window.-escape-will-cancel-and-close-the-window.": "Inizio della finestra di dialogo. Il tasto Esc annullerà l’operazione e chiuderà la finestra.",
255
+ "end-of-dialog-window.": "Fine della finestra di dialogo.",
256
+ "{1}-is-loading.": "{1} in fase di caricamento.",
257
+ "exit-picture-in-picture": "Esci dalla modalità Picture-in-Picture",
258
+ "picture-in-picture": "Picture-in-Picture",
259
+ "color": "Colore",
260
+ "opacity": "Opacità",
261
+ "text-background": "Sfondo testo",
262
+ "caption-area-background": "Sfondo area sottotitoli",
263
+ "skip-forward-{1}-seconds": "Avanti {1} secondi",
264
+ "skip-backward-{1}-seconds": "Indietro {1} secondi"
176
265
  }
177
266
  }
178
267
  }
@@ -173,6 +173,95 @@
173
173
  "months": "{{count}} mesi",
174
174
  "year": "{{count}} anno",
175
175
  "years": "{{count}} anni"
176
+ },
177
+ "video-player": {
178
+ "audio-player": "Lettore audio",
179
+ "video-player": "Lettore video",
180
+ "play": "Play",
181
+ "pause": "Pausa",
182
+ "replay": "Replay",
183
+ "current-time": "Orario attuale",
184
+ "duration": "Durata",
185
+ "remaining-time": "Tempo rimanente",
186
+ "stream-type": "Tipo di streaming",
187
+ "live": "LIVE",
188
+ "loaded": "Caricato",
189
+ "progress": "Stato",
190
+ "progress-bar": "Barra di avanzamento",
191
+ "progress-bar-timing:-currenttime={1}-duration={2}": "{1} di {2}",
192
+ "fullscreen": "Schermo intero",
193
+ "exit-fullscreen": "Chiudi Schermo intero",
194
+ "mute": "Disattiva l’audio",
195
+ "unmute": "Attiva l’audio",
196
+ "playback-rate": "Velocità di riproduzione",
197
+ "subtitles": "Sottotitoli",
198
+ "subtitles-off": "Senza sottotitoli",
199
+ "captions": "Sottotitoli non udenti",
200
+ "captions-off": "Senza sottotitoli non udenti",
201
+ "chapters": "Capitolo",
202
+ "descriptions": "Descrizioni",
203
+ "descriptions-off": "Descrizioni disattivate",
204
+ "audio-track": "Traccia audio",
205
+ "volume-level": "Livello del volume",
206
+ "you-aborted-the-media-playback": "La riproduzione del filmato è stata interrotta.",
207
+ "a-network-error-caused-the-media-download-to-fail-part-way.": "Il download del filmato è stato interrotto a causa di un problema rete.",
208
+ "the-media-could-not-be-loaded,-either-because-the-server-or-network-failed-or-because-the-format-is-not-supported.": "Il filmato non può essere caricato a causa di un errore nel server o nella rete o perché il formato non viene supportato.",
209
+ "the-media-playback-was-aborted-due-to-a-corruption-problem-or-because-the-media-used-features-your-browser-did-not-support.": "La riproduzione del filmato è stata interrotta a causa di un file danneggiato o per l’utilizzo di impostazioni non supportate dal browser.",
210
+ "no-compatible-source-was-found-for-this-media.": "Non ci sono fonti compatibili per questo filmato.",
211
+ "the-media-is-encrypted-and-we-do-not-have-the-keys-to-decrypt-it.": "Il contenuto multimediale è criptato e non disponiamo delle chiavi per decifrarlo.",
212
+ "play-video": "Riproduci il video",
213
+ "close": "Chiudi",
214
+ "close-modal-dialog": "Chiudi la finestra di dialogo",
215
+ "modal-window": "Finestra di dialogo",
216
+ "this-is-a-modal-window": "Questa è una finestra di dialogo",
217
+ "this-modal-can-be-closed-by-pressing-the-escape-key-or-activating-the-close-button.": "Questa finestra di dialogo può essere chiusa premendo sul tasto Esc o attivando il pulsante di chiusura.",
218
+ ",-opens-captions-settings-dialog": ", aprire i parametri della trascrizione dei sottotitoli",
219
+ ",-opens-subtitles-settings-dialog": ", aprire i parametri dei sottotitoli",
220
+ ",-opens-descriptions-settings-dialog": ", aprire i parametri delle descrizioni",
221
+ ",-selected": ", selezionato",
222
+ "captions-settings": "Parametri sottotitoli non udenti",
223
+ "subtitles-settings": "Parametri sottotitoli",
224
+ "descriptions-settings": "Parametri descrizioni",
225
+ "text": "Testo",
226
+ "white": "Bianco",
227
+ "black": "Nero",
228
+ "red": "Rosso",
229
+ "green": "Verde",
230
+ "blue": "Blu",
231
+ "yellow": "Giallo",
232
+ "magenta": "Magenta",
233
+ "cyan": "Ciano",
234
+ "background": "Sfondo",
235
+ "window": "Finestra",
236
+ "transparent": "Trasparente",
237
+ "semi-transparent": "Semi-Trasparente",
238
+ "opaque": "Opaco",
239
+ "font-size": "Dimensione dei caratteri",
240
+ "text-edge-style": "Stile dei bordi del testo",
241
+ "none": "Nessuno",
242
+ "uniform": "Uniforme",
243
+ "drop-shadow": "Ombra",
244
+ "font-family": "Carattere",
245
+ "proportional-sans-serif": "Sans-Serif proporzionale",
246
+ "monospace-sans-serif": "Sans-Serif monospaziato",
247
+ "proportional-serif": "Serif proporzionale",
248
+ "monospace-serif": "Serif monospaziato",
249
+ "small-caps": "Maiuscoletto",
250
+ "reset": "Reinizializza",
251
+ "restore-all-settings-to-the-default-values": "Ripristina i valori predefiniti per tutti i parametri",
252
+ "done": "Fatto",
253
+ "caption-settings-dialog": "Finestra di dialogo dei parametri della trascrizione dei sottotitoli",
254
+ "beginning-of-dialog-window.-escape-will-cancel-and-close-the-window.": "Inizio della finestra di dialogo. Il tasto Esc annullerà l’operazione e chiuderà la finestra.",
255
+ "end-of-dialog-window.": "Fine della finestra di dialogo.",
256
+ "{1}-is-loading.": "{1} in fase di caricamento.",
257
+ "exit-picture-in-picture": "Esci dalla modalità Picture-in-Picture",
258
+ "picture-in-picture": "Picture-in-Picture",
259
+ "color": "Colore",
260
+ "opacity": "Opacità",
261
+ "text-background": "Sfondo testo",
262
+ "caption-area-background": "Sfondo area sottotitoli",
263
+ "skip-forward-{1}-seconds": "Avanti {1} secondi",
264
+ "skip-backward-{1}-seconds": "Indietro {1} secondi"
176
265
  }
177
266
  }
178
267
  }
@@ -1,4 +1,4 @@
1
- import { FormControl } from '@angular/forms';
1
+ import { FormControl, FormGroup } from '@angular/forms';
2
2
  import { Component, Input, Optional, Self } from '@angular/core';
3
3
  import { ItAbstractComponent } from './abstract.component';
4
4
  import { inputToBoolean } from '../utils/coercion';
@@ -12,19 +12,20 @@ export class ItAbstractFormComponent extends ItAbstractComponent {
12
12
  set disabled(isDisabled) {
13
13
  this.setDisabledState(isDisabled);
14
14
  }
15
- constructor(_translateService, _ngControl) {
15
+ constructor(_translateService, _ngControl, fgd) {
16
16
  super();
17
17
  this._translateService = _translateService;
18
18
  this._ngControl = _ngControl;
19
+ this.fgd = fgd;
19
20
  /**
20
21
  * Validation color display mode (validation triggered if field is touched or not pristine)
21
22
  * - <b>true</b>: Always show the validation color
22
23
  * - <b>false</b>: Never show validation color
23
24
  * - <b>only-valid</b>: Show only valid validation color
24
25
  * - <b>only-invalid</b>: Show only invalid validation color
25
- * @default <b>true</b>: Always show the validation color
26
+ * @default <b>false</b>: Do not show the validation color by default
26
27
  */
27
- this.validationMode = true;
28
+ this.validationMode = false;
28
29
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
29
30
  this.onChange = (_) => { };
30
31
  this.onTouched = () => { };
@@ -67,6 +68,7 @@ export class ItAbstractFormComponent extends ItAbstractComponent {
67
68
  ngOnInit() {
68
69
  if (this._ngControl?.control) {
69
70
  this.control.setValidators(this._ngControl.control.validator);
71
+ this.setValidationModeWhenInAForm();
70
72
  }
71
73
  }
72
74
  registerOnChange(fn) {
@@ -165,7 +167,16 @@ export class ItAbstractFormComponent extends ItAbstractComponent {
165
167
  }
166
168
  return this.control.getError(errorCode, path);
167
169
  }
168
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItAbstractFormComponent, deps: [{ token: i1.TranslateService }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
170
+ // This function assurest that validation mode remains complaiant with the Design kit
171
+ // When the validation mode is `false` and input elements are wrapped in a `FormGroup`
172
+ // validation mode is automatically set to `true`.
173
+ setValidationModeWhenInAForm() {
174
+ const isInAForm = this.fgd?.control instanceof FormGroup;
175
+ if (isInAForm && this.validationMode == false) {
176
+ this.validationMode = true;
177
+ }
178
+ }
179
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItAbstractFormComponent, deps: [{ token: i1.TranslateService }, { token: i2.NgControl, optional: true, self: true }, { token: i2.ControlContainer, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
169
180
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.6", type: ItAbstractFormComponent, selector: "ng-component", inputs: { label: "label", validationMode: "validationMode", disabled: ["disabled", "disabled", inputToBoolean] }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
170
181
  }
171
182
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItAbstractFormComponent, decorators: [{
@@ -175,6 +186,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
175
186
  type: Self
176
187
  }, {
177
188
  type: Optional
189
+ }] }, { type: i2.ControlContainer, decorators: [{
190
+ type: Optional
178
191
  }] }], propDecorators: { label: [{
179
192
  type: Input
180
193
  }], validationMode: [{
@@ -183,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
183
196
  type: Input,
184
197
  args: [{ transform: inputToBoolean }]
185
198
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-form.component.js","sourceRoot":"","sources":["../../../../../projects/design-angular-kit/src/lib/abstracts/abstract-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ControlValueAccessor, FormControl, NgControl, ValidatorFn } from '@angular/forms';\nimport { Component, DoCheck, Input, OnInit, Optional, Self } from '@angular/core';\nimport { ItAbstractComponent } from './abstract.component';\nimport { Observable } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\nimport { inputToBoolean } from '../utils/coercion';\n\n@Component({ template: '' })\nexport abstract class ItAbstractFormComponent<T = any> extends ItAbstractComponent implements OnInit, ControlValueAccessor, DoCheck {\n  /**\n   * The label of form control\n   */\n  @Input() label?: string;\n\n  /**\n   * Validation color display mode (validation triggered if field is touched or not pristine)\n   * - <b>true</b>: Always show the validation color\n   * - <b>false</b>: Never show validation color\n   * - <b>only-valid</b>: Show only valid validation color\n   * - <b>only-invalid</b>: Show only invalid validation color\n   * @default <b>true</b>: Always show the validation color\n   */\n  @Input() validationMode: boolean | 'only-valid' | 'only-invalid' = true;\n\n  /**\n   * Set the disabled state\n   */\n  @Input({ transform: inputToBoolean }) set disabled(isDisabled: boolean) {\n    this.setDisabledState(isDisabled);\n  }\n\n  /**\n   * Internal form control\n   */\n  protected control: FormControl<T>;\n\n  constructor(\n    protected readonly _translateService: TranslateService,\n    @Self() @Optional() protected readonly _ngControl: NgControl\n  ) {\n    super();\n    this.control = new FormControl();\n    this._ngControl && (this._ngControl.valueAccessor = this);\n  }\n\n  /**\n   * Check if field is invalid (Validation failed)\n   */\n  get isInvalid(): boolean | undefined {\n    if (this.validationMode === 'only-valid' || (this.validationMode !== 'only-invalid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.invalid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.invalid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Check if field is valid (Validation successful)\n   */\n  get isValid(): boolean | undefined {\n    if (this.validationMode === 'only-invalid' || (this.validationMode !== 'only-valid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.valid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.valid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Return the invalid message string from TranslateService\n   */\n  get invalidMessage(): Observable<string> {\n    if (this.hasError('required')) {\n      return this._translateService.get('it.errors.required-field');\n    }\n\n    return this._translateService.get('it.errors.invalid-field');\n  }\n\n  ngOnInit(): void {\n    if (this._ngControl?.control) {\n      this.control.setValidators((this._ngControl.control as FormControl).validator);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (_: T) => {};\n\n  onTouched = () => {};\n\n  registerOnChange(fn: any): void {\n    this.control.valueChanges.subscribe(fn);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n    this.control.enable();\n  }\n\n  writeValue(value: T): void {\n    this.control.setValue(value, { emitEvent: false });\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Mark the control as touched\n   */\n  markAsTouched(): void {\n    if (!this.control.touched) {\n      this.onTouched();\n    }\n  }\n\n  /**\n   * Fired to check if form control is touched\n   */\n  ngDoCheck() {\n    if (this._ngControl?.control) {\n      const ngControl = this._ngControl.control;\n      if (this.control.touched !== ngControl.touched) {\n        if (ngControl.touched) {\n          this.control.markAsTouched();\n        } else {\n          this.control.markAsUntouched();\n        }\n      }\n      if (this.control.pristine !== ngControl.pristine) {\n        if (ngControl.pristine) {\n          this.control.markAsPristine();\n        } else {\n          this.control.markAsDirty();\n        }\n      }\n    }\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Add the validators in control and parent control\n   * @param validators the validators\n   * @protected\n   */\n  protected addValidators(validators: ValidatorFn | ValidatorFn[]): void {\n    if (!Array.isArray(validators)) {\n      validators = [validators];\n    }\n\n    validators.forEach(validator => {\n      if (!this.control.hasValidator(validator)) {\n        this.control.addValidators(validator);\n      }\n\n      if (this._ngControl?.control && !this._ngControl.control.hasValidator(validator)) {\n        this._ngControl.control.addValidators(validator);\n      }\n    });\n  }\n\n  /**\n   * Reports whether the control with the given path has the error specified. <br/>\n   * If the control is not present, false is returned.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns whether the given error is present in the control at the given path.\n   */\n  public hasError(errorCode: string, path?: Array<string | number> | string): boolean {\n    if (this._ngControl) {\n      return this._ngControl.hasError(errorCode, path);\n    }\n    return this.control.hasError(errorCode, path);\n  }\n\n  /**\n   * Reports error data for the control with the given path.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns error data for that particular error. If the control or error is not present,\n   * null is returned.\n   */\n  public getError(errorCode: string, path?: Array<string | number> | string): any {\n    if (this._ngControl) {\n      return this._ngControl.getError(errorCode, path);\n    }\n    return this.control.getError(errorCode, path);\n  }\n}\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-form.component.js","sourceRoot":"","sources":["../../../../../projects/design-angular-kit/src/lib/abstracts/abstract-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ControlContainer, ControlValueAccessor, FormControl, FormGroup, NgControl, ValidatorFn } from '@angular/forms';\nimport { Component, DoCheck, Input, OnInit, Optional, Self } from '@angular/core';\nimport { ItAbstractComponent } from './abstract.component';\nimport { Observable } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\nimport { inputToBoolean } from '../utils/coercion';\n\n@Component({ template: '' })\nexport abstract class ItAbstractFormComponent<T = any> extends ItAbstractComponent implements OnInit, ControlValueAccessor, DoCheck {\n  /**\n   * The label of form control\n   */\n  @Input() label?: string;\n\n  /**\n   * Validation color display mode (validation triggered if field is touched or not pristine)\n   * - <b>true</b>: Always show the validation color\n   * - <b>false</b>: Never show validation color\n   * - <b>only-valid</b>: Show only valid validation color\n   * - <b>only-invalid</b>: Show only invalid validation color\n   * @default <b>false</b>: Do not show the validation color by default\n   */\n  @Input() validationMode: boolean | 'only-valid' | 'only-invalid' = false;\n\n  /**\n   * Set the disabled state\n   */\n  @Input({ transform: inputToBoolean }) set disabled(isDisabled: boolean) {\n    this.setDisabledState(isDisabled);\n  }\n\n  /**\n   * Internal form control\n   */\n  protected control: FormControl<T>;\n\n  constructor(\n    protected readonly _translateService: TranslateService,\n    @Self() @Optional() protected readonly _ngControl: NgControl,\n    @Optional() protected fgd?: ControlContainer\n  ) {\n    super();\n    this.control = new FormControl();\n    this._ngControl && (this._ngControl.valueAccessor = this);\n  }\n\n  /**\n   * Check if field is invalid (Validation failed)\n   */\n  get isInvalid(): boolean | undefined {\n    if (this.validationMode === 'only-valid' || (this.validationMode !== 'only-invalid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.invalid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.invalid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Check if field is valid (Validation successful)\n   */\n  get isValid(): boolean | undefined {\n    if (this.validationMode === 'only-invalid' || (this.validationMode !== 'only-valid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.valid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.valid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Return the invalid message string from TranslateService\n   */\n  get invalidMessage(): Observable<string> {\n    if (this.hasError('required')) {\n      return this._translateService.get('it.errors.required-field');\n    }\n\n    return this._translateService.get('it.errors.invalid-field');\n  }\n\n  ngOnInit(): void {\n    if (this._ngControl?.control) {\n      this.control.setValidators((this._ngControl.control as FormControl).validator);\n      this.setValidationModeWhenInAForm();\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (_: T) => {};\n\n  onTouched = () => {};\n\n  registerOnChange(fn: any): void {\n    this.control.valueChanges.subscribe(fn);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n    this.control.enable();\n  }\n\n  writeValue(value: T): void {\n    this.control.setValue(value, { emitEvent: false });\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Mark the control as touched\n   */\n  markAsTouched(): void {\n    if (!this.control.touched) {\n      this.onTouched();\n    }\n  }\n\n  /**\n   * Fired to check if form control is touched\n   */\n  ngDoCheck() {\n    if (this._ngControl?.control) {\n      const ngControl = this._ngControl.control;\n      if (this.control.touched !== ngControl.touched) {\n        if (ngControl.touched) {\n          this.control.markAsTouched();\n        } else {\n          this.control.markAsUntouched();\n        }\n      }\n      if (this.control.pristine !== ngControl.pristine) {\n        if (ngControl.pristine) {\n          this.control.markAsPristine();\n        } else {\n          this.control.markAsDirty();\n        }\n      }\n    }\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Add the validators in control and parent control\n   * @param validators the validators\n   * @protected\n   */\n  protected addValidators(validators: ValidatorFn | ValidatorFn[]): void {\n    if (!Array.isArray(validators)) {\n      validators = [validators];\n    }\n\n    validators.forEach(validator => {\n      if (!this.control.hasValidator(validator)) {\n        this.control.addValidators(validator);\n      }\n\n      if (this._ngControl?.control && !this._ngControl.control.hasValidator(validator)) {\n        this._ngControl.control.addValidators(validator);\n      }\n    });\n  }\n\n  /**\n   * Reports whether the control with the given path has the error specified. <br/>\n   * If the control is not present, false is returned.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns whether the given error is present in the control at the given path.\n   */\n  public hasError(errorCode: string, path?: Array<string | number> | string): boolean {\n    if (this._ngControl) {\n      return this._ngControl.hasError(errorCode, path);\n    }\n    return this.control.hasError(errorCode, path);\n  }\n\n  /**\n   * Reports error data for the control with the given path.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns error data for that particular error. If the control or error is not present,\n   * null is returned.\n   */\n  public getError(errorCode: string, path?: Array<string | number> | string): any {\n    if (this._ngControl) {\n      return this._ngControl.getError(errorCode, path);\n    }\n    return this.control.getError(errorCode, path);\n  }\n\n  // This function assurest that validation mode remains complaiant with the Design kit\n  // When the validation mode is `false` and input elements are wrapped in a `FormGroup`\n  // validation mode is automatically set to `true`.\n  private setValidationModeWhenInAForm() {\n    const isInAForm: boolean = this.fgd?.control instanceof FormGroup;\n    if (isInAForm && this.validationMode == false) {\n      this.validationMode = true;\n    }\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, ContentChildren, Input, ViewChild, } from '@angular/core';
2
2
  import { ItCarouselItemComponent } from '../carousel-item/carousel-item.component';
3
- import { CarouselBI } from 'bootstrap-italia';
3
+ import { Carousel } from 'bootstrap-italia';
4
4
  import { startWith } from 'rxjs';
5
5
  import { NgTemplateOutlet } from '@angular/common';
6
6
  import { inputToBoolean } from '../../../../utils/coercion';
@@ -28,7 +28,6 @@ export class ItCarouselComponent {
28
28
  this.trackClass = '';
29
29
  }
30
30
  ngAfterViewInit() {
31
- this.carousel = CarouselBI.getOrCreateInstance(this.carouselDiv.nativeElement);
32
31
  this.items?.changes
33
32
  .pipe(
34
33
  // When carousel items changes (dynamic add/remove)
@@ -40,22 +39,25 @@ export class ItCarouselComponent {
40
39
  }));
41
40
  this._changeDetectorRef.detectChanges(); // Force update html render
42
41
  });
42
+ setTimeout(() => {
43
+ this.carousel = Carousel.getOrCreateInstance(this.carouselDiv.nativeElement);
44
+ }, 100);
43
45
  }
44
46
  ngOnDestroy() {
45
47
  this.itemSubscriptions?.forEach(item => item.unsubscribe());
46
48
  }
47
49
  /**
48
- * Removes CarouselBI features
50
+ * Removes Carousel features
49
51
  */
50
52
  dispose() {
51
53
  this.carousel?.dispose();
52
54
  }
53
55
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItCarouselComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
54
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItCarouselComponent, isStandalone: true, selector: "it-carousel", inputs: { title: "title", type: "type", trackClass: "trackClass", fullCarousel: ["fullCarousel", "fullCarousel", inputToBoolean], bigImg: ["bigImg", "bigImg", inputToBoolean], standardImage: ["standardImage", "standardImage", inputToBoolean], lined: ["lined", "lined", inputToBoolean] }, queries: [{ propertyName: "items", predicate: ItCarouselItemComponent }], viewQueries: [{ propertyName: "carouselDiv", first: true, predicate: ["carousel"], descendants: true }], exportAs: ["itCarousel"], ngImport: i0, template: "<div\n #carousel\n class=\"it-carousel-wrapper splide {{ typeClass }}\"\n [class.it-full-carousel]=\"fullCarousel\"\n [class.it-big-img]=\"bigImg\"\n [class.it-standard-image]=\"standardImage\"\n data-bs-carousel-splide>\n @if (title) {\n <div class=\"it-header-block\">\n <div class=\"it-header-block-title\">\n <h2>{{ title }}</h2>\n </div>\n </div>\n }\n\n <div class=\"splide__track {{ trackClass }}\">\n @if (items) {\n <ul class=\"splide__list\">\n @for (item of items; track item) {\n <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n <div class=\"it-single-slide-wrapper\">\n <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n </div>\n </li>\n }\n </ul>\n }\n </div>\n</div>\n", styles: [".splide__container{box-sizing:border-box;position:relative}.splide__list{-webkit-backface-visibility:hidden;backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important;transform-style:preserve-3d}.splide.is-initialized:not(.is-active) .splide__list{display:block}.splide__pagination{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;margin:0;pointer-events:none}.splide__pagination li{display:inline-block;line-height:1;list-style-type:none;margin:0;pointer-events:auto}.splide__progress__bar{width:0}.splide{outline:none;position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;outline:none;position:relative}.splide__slide img{vertical-align:bottom}.splide__slider{position:relative}.splide__spinner{animation:splide-loading 1s linear infinite;border:2px solid #999;border-left-color:transparent;border-radius:50%;contain:strict;display:inline-block;height:20px;inset:0;margin:auto;position:absolute;width:20px}.splide__track{overflow:hidden;position:relative;z-index:0}@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide--draggable>.splide__slider>.splide__track,.splide--draggable>.splide__track{-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide--fade>.splide__slider>.splide__track>.splide__list,.splide--fade>.splide__track>.splide__list{display:block}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide,.splide--fade>.splide__track>.splide__list>.splide__slide{left:0;opacity:0;position:absolute;top:0;z-index:0}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide.is-active,.splide--fade>.splide__track>.splide__list>.splide__slide.is-active{opacity:1;position:relative;z-index:1}.splide--rtl{direction:rtl}.splide--ttb.is-active>.splide__slider>.splide__track>.splide__list,.splide--ttb.is-active>.splide__track>.splide__list{display:block}.splide__arrow{-ms-flex-align:center;align-items:center;background:#ccc;border:0;border-radius:50%;cursor:pointer;display:-ms-flexbox;display:flex;height:2em;-ms-flex-pack:center;justify-content:center;opacity:.7;padding:0;position:absolute;top:50%;transform:translateY(-50%);width:2em;z-index:1}.splide__arrow svg{fill:#000;height:1.2em;width:1.2em}.splide__arrow:hover{opacity:.9}.splide__arrow:focus{outline:none}.splide__arrow--prev{left:1em}.splide__arrow--prev svg{transform:scaleX(-1)}.splide__arrow--next{right:1em}.splide__pagination{bottom:.5em;left:0;padding:0 1em;position:absolute;right:0;z-index:1}.splide__pagination__page{background:#ccc;border:0;border-radius:50%;display:inline-block;height:8px;margin:3px;opacity:.7;padding:0;transition:transform .2s linear;width:8px}.splide__pagination__page.is-active{background:#fff;transform:scale(1.4)}.splide__pagination__page:hover{cursor:pointer;opacity:.9}.splide__pagination__page:focus{outline:none}.splide__progress__bar{background:#ccc;height:3px}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide,.splide--nav>.splide__track>.splide__list>.splide__slide{border:3px solid transparent;cursor:pointer}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide.is-active,.splide--nav>.splide__track>.splide__list>.splide__slide.is-active{border:3px solid #000}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide:focus,.splide--nav>.splide__track>.splide__list>.splide__slide:focus{outline:none}.splide--rtl>.splide__arrows .splide__arrow--prev,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--prev{left:auto;right:1em}.splide--rtl>.splide__arrows .splide__arrow--prev svg,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev svg,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--prev svg{transform:scaleX(1)}.splide--rtl>.splide__arrows .splide__arrow--next,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--next{left:1em;right:auto}.splide--rtl>.splide__arrows .splide__arrow--next svg,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next svg,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--next svg{transform:scaleX(-1)}.splide--ttb>.splide__arrows .splide__arrow,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow,.splide--ttb>.splide__track>.splide__arrows .splide__arrow{left:50%;transform:translate(-50%)}.splide--ttb>.splide__arrows .splide__arrow--prev,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--prev{top:1em}.splide--ttb>.splide__arrows .splide__arrow--prev svg,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev svg,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--prev svg{transform:rotate(-90deg)}.splide--ttb>.splide__arrows .splide__arrow--next,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--next{bottom:1em;top:auto}.splide--ttb>.splide__arrows .splide__arrow--next svg,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next svg,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--next svg{transform:rotate(90deg)}.splide--ttb>.splide__pagination,.splide--ttb>.splide__slider>.splide__pagination{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;inset:0 .5em 0 auto;padding:1em 0}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
56
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItCarouselComponent, isStandalone: true, selector: "it-carousel", inputs: { title: "title", type: "type", trackClass: "trackClass", fullCarousel: ["fullCarousel", "fullCarousel", inputToBoolean], bigImg: ["bigImg", "bigImg", inputToBoolean], standardImage: ["standardImage", "standardImage", inputToBoolean], lined: ["lined", "lined", inputToBoolean] }, queries: [{ propertyName: "items", predicate: ItCarouselItemComponent }], viewQueries: [{ propertyName: "carouselDiv", first: true, predicate: ["carousel"], descendants: true }], exportAs: ["itCarousel"], ngImport: i0, template: "<div\n #carousel\n class=\"it-carousel-wrapper splide {{ typeClass }}\"\n [class.it-full-carousel]=\"fullCarousel\"\n [class.it-big-img]=\"bigImg\"\n [class.it-standard-image]=\"standardImage\">\n @if (title) {\n <div class=\"it-header-block\">\n <div class=\"it-header-block-title\">\n <h2>{{ title }}</h2>\n </div>\n </div>\n }\n\n <div class=\"splide__track {{ trackClass }}\">\n @if (items) {\n <ul class=\"splide__list\">\n @for (item of items; track item) {\n <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n <div class=\"it-single-slide-wrapper\">\n <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n </div>\n </li>\n }\n </ul>\n }\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
55
57
  }
56
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItCarouselComponent, decorators: [{
57
59
  type: Component,
58
- args: [{ standalone: true, selector: 'it-carousel', exportAs: 'itCarousel', changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgTemplateOutlet], template: "<div\n #carousel\n class=\"it-carousel-wrapper splide {{ typeClass }}\"\n [class.it-full-carousel]=\"fullCarousel\"\n [class.it-big-img]=\"bigImg\"\n [class.it-standard-image]=\"standardImage\"\n data-bs-carousel-splide>\n @if (title) {\n <div class=\"it-header-block\">\n <div class=\"it-header-block-title\">\n <h2>{{ title }}</h2>\n </div>\n </div>\n }\n\n <div class=\"splide__track {{ trackClass }}\">\n @if (items) {\n <ul class=\"splide__list\">\n @for (item of items; track item) {\n <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n <div class=\"it-single-slide-wrapper\">\n <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n </div>\n </li>\n }\n </ul>\n }\n </div>\n</div>\n", styles: [".splide__container{box-sizing:border-box;position:relative}.splide__list{-webkit-backface-visibility:hidden;backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important;transform-style:preserve-3d}.splide.is-initialized:not(.is-active) .splide__list{display:block}.splide__pagination{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;margin:0;pointer-events:none}.splide__pagination li{display:inline-block;line-height:1;list-style-type:none;margin:0;pointer-events:auto}.splide__progress__bar{width:0}.splide{outline:none;position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;outline:none;position:relative}.splide__slide img{vertical-align:bottom}.splide__slider{position:relative}.splide__spinner{animation:splide-loading 1s linear infinite;border:2px solid #999;border-left-color:transparent;border-radius:50%;contain:strict;display:inline-block;height:20px;inset:0;margin:auto;position:absolute;width:20px}.splide__track{overflow:hidden;position:relative;z-index:0}@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide--draggable>.splide__slider>.splide__track,.splide--draggable>.splide__track{-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide--fade>.splide__slider>.splide__track>.splide__list,.splide--fade>.splide__track>.splide__list{display:block}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide,.splide--fade>.splide__track>.splide__list>.splide__slide{left:0;opacity:0;position:absolute;top:0;z-index:0}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide.is-active,.splide--fade>.splide__track>.splide__list>.splide__slide.is-active{opacity:1;position:relative;z-index:1}.splide--rtl{direction:rtl}.splide--ttb.is-active>.splide__slider>.splide__track>.splide__list,.splide--ttb.is-active>.splide__track>.splide__list{display:block}.splide__arrow{-ms-flex-align:center;align-items:center;background:#ccc;border:0;border-radius:50%;cursor:pointer;display:-ms-flexbox;display:flex;height:2em;-ms-flex-pack:center;justify-content:center;opacity:.7;padding:0;position:absolute;top:50%;transform:translateY(-50%);width:2em;z-index:1}.splide__arrow svg{fill:#000;height:1.2em;width:1.2em}.splide__arrow:hover{opacity:.9}.splide__arrow:focus{outline:none}.splide__arrow--prev{left:1em}.splide__arrow--prev svg{transform:scaleX(-1)}.splide__arrow--next{right:1em}.splide__pagination{bottom:.5em;left:0;padding:0 1em;position:absolute;right:0;z-index:1}.splide__pagination__page{background:#ccc;border:0;border-radius:50%;display:inline-block;height:8px;margin:3px;opacity:.7;padding:0;transition:transform .2s linear;width:8px}.splide__pagination__page.is-active{background:#fff;transform:scale(1.4)}.splide__pagination__page:hover{cursor:pointer;opacity:.9}.splide__pagination__page:focus{outline:none}.splide__progress__bar{background:#ccc;height:3px}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide,.splide--nav>.splide__track>.splide__list>.splide__slide{border:3px solid transparent;cursor:pointer}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide.is-active,.splide--nav>.splide__track>.splide__list>.splide__slide.is-active{border:3px solid #000}.splide--nav>.splide__slider>.splide__track>.splide__list>.splide__slide:focus,.splide--nav>.splide__track>.splide__list>.splide__slide:focus{outline:none}.splide--rtl>.splide__arrows .splide__arrow--prev,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--prev{left:auto;right:1em}.splide--rtl>.splide__arrows .splide__arrow--prev svg,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev svg,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--prev svg{transform:scaleX(1)}.splide--rtl>.splide__arrows .splide__arrow--next,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--next{left:1em;right:auto}.splide--rtl>.splide__arrows .splide__arrow--next svg,.splide--rtl>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next svg,.splide--rtl>.splide__track>.splide__arrows .splide__arrow--next svg{transform:scaleX(-1)}.splide--ttb>.splide__arrows .splide__arrow,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow,.splide--ttb>.splide__track>.splide__arrows .splide__arrow{left:50%;transform:translate(-50%)}.splide--ttb>.splide__arrows .splide__arrow--prev,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--prev{top:1em}.splide--ttb>.splide__arrows .splide__arrow--prev svg,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--prev svg,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--prev svg{transform:rotate(-90deg)}.splide--ttb>.splide__arrows .splide__arrow--next,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--next{bottom:1em;top:auto}.splide--ttb>.splide__arrows .splide__arrow--next svg,.splide--ttb>.splide__slider>.splide__track>.splide__arrows .splide__arrow--next svg,.splide--ttb>.splide__track>.splide__arrows .splide__arrow--next svg{transform:rotate(90deg)}.splide--ttb>.splide__pagination,.splide--ttb>.splide__slider>.splide__pagination{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;inset:0 .5em 0 auto;padding:1em 0}\n"] }]
60
+ args: [{ standalone: true, selector: 'it-carousel', exportAs: 'itCarousel', changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgTemplateOutlet], template: "<div\n #carousel\n class=\"it-carousel-wrapper splide {{ typeClass }}\"\n [class.it-full-carousel]=\"fullCarousel\"\n [class.it-big-img]=\"bigImg\"\n [class.it-standard-image]=\"standardImage\">\n @if (title) {\n <div class=\"it-header-block\">\n <div class=\"it-header-block-title\">\n <h2>{{ title }}</h2>\n </div>\n </div>\n }\n\n <div class=\"splide__track {{ trackClass }}\">\n @if (items) {\n <ul class=\"splide__list\">\n @for (item of items; track item) {\n <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n <div class=\"it-single-slide-wrapper\">\n <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n </div>\n </li>\n }\n </ul>\n }\n </div>\n</div>\n" }]
59
61
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { title: [{
60
62
  type: Input
61
63
  }], type: [{
@@ -81,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
81
83
  type: ViewChild,
82
84
  args: ['carousel']
83
85
  }] } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-angular-kit/src/lib/components/core/carousel/carousel/carousel.component.ts","../../../../../../../../projects/design-angular-kit/src/lib/components/core/carousel/carousel/carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,eAAe,EAEf,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,0CAA0C,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAgB,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;;AAE5D;;;GAGG;AAUH,MAAM,OAAO,mBAAmB;IAmD9B,IAAc,SAAS;QACrB,MAAM,SAAS,GAAG,gCAAgC,CAAC;QACnD,OAAO,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3E,CAAC;IAED,YAA6B,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;QAjDlE;;;WAGG;QACM,SAAI,GAAiB,SAAS,CAAC;QAExC;;;WAGG;QACM,eAAU,GAAW,EAAE,CAAC;IAuCoC,CAAC;IAEtE,eAAe;QACb,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC/E,IAAI,CAAC,KAAK,EAAE,OAAO;aAChB,IAAI;QACH,mDAAmD;QACnD,SAAS,CAAC,SAAS,CAAC,CACrB;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,2BAA2B;YACtF,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAC9C,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC/B,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,CAAC,sDAAsD;YACjG,CAAC,CAAC,CACH,CAAC;YACF,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,CAAC,2BAA2B;QACtE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC;IAC3B,CAAC;8GArFU,mBAAmB;kGAAnB,mBAAmB,gKAuBV,cAAc,gCAMd,cAAc,qDAMd,cAAc,6BAMd,cAAc,mDAEjB,uBAAuB,gKC3E1C,i0BA6BA,m1LDCY,gBAAgB;;2FAEf,mBAAmB;kBAT/B,SAAS;iCACI,IAAI,YACN,aAAa,YAGb,YAAY,mBACL,uBAAuB,CAAC,MAAM,WACtC,CAAC,gBAAgB,CAAC;sFAOlB,KAAK;sBAAb,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAMgC,YAAY;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,MAAM;sBAA3C,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,aAAa;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,KAAK;sBAA1C,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAEgB,KAAK;sBAAxD,eAAe;uBAAC,uBAAuB;gBAIT,WAAW;sBAAzC,SAAS;uBAAC,UAAU","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\nimport { CarouselType } from '../../../../interfaces/core';\nimport { ItCarouselItemComponent } from '../carousel-item/carousel-item.component';\nimport { CarouselBI } from 'bootstrap-italia';\nimport { startWith, Subscription } from 'rxjs';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { inputToBoolean } from '../../../../utils/coercion';\n\n/**\n * Carousel\n * @description A presentation component for scrolling through elements, images or text slides.\n */\n@Component({\n  standalone: true,\n  selector: 'it-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  exportAs: 'itCarousel',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgTemplateOutlet],\n})\nexport class ItCarouselComponent implements AfterViewInit, OnDestroy {\n  /**\n   * The callout title\n   * @default undefined\n   */\n  @Input() title: string | undefined;\n\n  /**\n   * The carousel type\n   * @default default\n   */\n  @Input() type: CarouselType = 'default';\n\n  /**\n   * Custom class in splide__track element\n   * @default ''\n   */\n  @Input() trackClass: string = '';\n\n  /**\n   * True for full screen (landscape) viewing\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) fullCarousel?: boolean;\n\n  /**\n   * To indicate that the contained image is of a large type\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) bigImg?: boolean;\n\n  /**\n   * To indicate that the contained image is of a standard type\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) standardImage?: boolean;\n\n  /**\n   * Card line style\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) lined?: boolean;\n\n  @ContentChildren(ItCarouselItemComponent) protected items?: QueryList<ItCarouselItemComponent>;\n\n  private carousel?: CarouselBI;\n\n  @ViewChild('carousel') private carouselDiv!: ElementRef<HTMLDivElement>;\n\n  private itemSubscriptions?: Array<Subscription>;\n\n  protected get typeClass(): string {\n    const typeClass = 'it-carousel-landscape-abstract';\n    return this.type === 'default' ? typeClass : typeClass + `-${this.type}`;\n  }\n\n  constructor(private readonly _changeDetectorRef: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    this.carousel = CarouselBI.getOrCreateInstance(this.carouselDiv.nativeElement);\n    this.items?.changes\n      .pipe(\n        // When carousel items changes (dynamic add/remove)\n        startWith(undefined)\n      )\n      .subscribe(() => {\n        this.itemSubscriptions?.forEach(sub => sub.unsubscribe()); // Remove old subscriptions\n        this.itemSubscriptions = this.items?.map(item =>\n          item.valueChanges.subscribe(() => {\n            this._changeDetectorRef.detectChanges(); // DetectChanges when carousel item attributes changes\n          })\n        );\n        this._changeDetectorRef.detectChanges(); // Force update html render\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.itemSubscriptions?.forEach(item => item.unsubscribe());\n  }\n\n  /**\n   * Removes CarouselBI features\n   */\n  public dispose(): void {\n    this.carousel?.dispose();\n  }\n}\n","<div\n  #carousel\n  class=\"it-carousel-wrapper splide {{ typeClass }}\"\n  [class.it-full-carousel]=\"fullCarousel\"\n  [class.it-big-img]=\"bigImg\"\n  [class.it-standard-image]=\"standardImage\"\n  data-bs-carousel-splide>\n  @if (title) {\n    <div class=\"it-header-block\">\n      <div class=\"it-header-block-title\">\n        <h2>{{ title }}</h2>\n      </div>\n    </div>\n  }\n\n  <div class=\"splide__track {{ trackClass }}\">\n    @if (items) {\n      <ul class=\"splide__list\">\n        @for (item of items; track item) {\n          <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n            <div class=\"it-single-slide-wrapper\">\n              <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n            </div>\n          </li>\n        }\n      </ul>\n    }\n  </div>\n</div>\n"]}
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-angular-kit/src/lib/components/core/carousel/carousel/carousel.component.ts","../../../../../../../../projects/design-angular-kit/src/lib/components/core/carousel/carousel/carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,eAAe,EAEf,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,0CAA0C,CAAC;AACnF,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAgB,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;;AAE5D;;;GAGG;AASH,MAAM,OAAO,mBAAmB;IAmD9B,IAAc,SAAS;QACrB,MAAM,SAAS,GAAG,gCAAgC,CAAC;QACnD,OAAO,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3E,CAAC;IAED,YAA6B,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;QAjDlE;;;WAGG;QACM,SAAI,GAAiB,SAAS,CAAC;QAExC;;;WAGG;QACM,eAAU,GAAW,EAAE,CAAC;IAuCoC,CAAC;IAEtE,eAAe;QACb,IAAI,CAAC,KAAK,EAAE,OAAO;aAChB,IAAI;QACH,mDAAmD;QACnD,SAAS,CAAC,SAAS,CAAC,CACrB;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,2BAA2B;YACtF,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAC9C,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC/B,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,CAAC,sDAAsD;YACjG,CAAC,CAAC,CACH,CAAC;YACF,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,CAAC,2BAA2B;QACtE,CAAC,CAAC,CAAC;QACL,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC/E,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC;IAC3B,CAAC;8GAvFU,mBAAmB;kGAAnB,mBAAmB,gKAuBV,cAAc,gCAMd,cAAc,qDAMd,cAAc,6BAMd,cAAc,mDAEjB,uBAAuB,gKC1E1C,syBA4BA,4CDCY,gBAAgB;;2FAEf,mBAAmB;kBAR/B,SAAS;iCACI,IAAI,YACN,aAAa,YAEb,YAAY,mBACL,uBAAuB,CAAC,MAAM,WACtC,CAAC,gBAAgB,CAAC;sFAOlB,KAAK;sBAAb,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAMgC,YAAY;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,MAAM;sBAA3C,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,aAAa;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAME,KAAK;sBAA1C,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE;gBAEgB,KAAK;sBAAxD,eAAe;uBAAC,uBAAuB;gBAIT,WAAW;sBAAzC,SAAS;uBAAC,UAAU","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChild,\n} from '@angular/core';\nimport { CarouselType } from '../../../../interfaces/core';\nimport { ItCarouselItemComponent } from '../carousel-item/carousel-item.component';\nimport { Carousel } from 'bootstrap-italia';\nimport { startWith, Subscription } from 'rxjs';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { inputToBoolean } from '../../../../utils/coercion';\n\n/**\n * Carousel\n * @description A presentation component for scrolling through elements, images or text slides.\n */\n@Component({\n  standalone: true,\n  selector: 'it-carousel',\n  templateUrl: './carousel.component.html',\n  exportAs: 'itCarousel',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgTemplateOutlet],\n})\nexport class ItCarouselComponent implements AfterViewInit, OnDestroy {\n  /**\n   * The callout title\n   * @default undefined\n   */\n  @Input() title: string | undefined;\n\n  /**\n   * The carousel type\n   * @default default\n   */\n  @Input() type: CarouselType = 'default';\n\n  /**\n   * Custom class in splide__track element\n   * @default ''\n   */\n  @Input() trackClass: string = '';\n\n  /**\n   * True for full screen (landscape) viewing\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) fullCarousel?: boolean;\n\n  /**\n   * To indicate that the contained image is of a large type\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) bigImg?: boolean;\n\n  /**\n   * To indicate that the contained image is of a standard type\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) standardImage?: boolean;\n\n  /**\n   * Card line style\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) lined?: boolean;\n\n  @ContentChildren(ItCarouselItemComponent) protected items?: QueryList<ItCarouselItemComponent>;\n\n  private carousel?: Carousel;\n\n  @ViewChild('carousel') private carouselDiv!: ElementRef<HTMLDivElement>;\n\n  private itemSubscriptions?: Array<Subscription>;\n\n  protected get typeClass(): string {\n    const typeClass = 'it-carousel-landscape-abstract';\n    return this.type === 'default' ? typeClass : typeClass + `-${this.type}`;\n  }\n\n  constructor(private readonly _changeDetectorRef: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    this.items?.changes\n      .pipe(\n        // When carousel items changes (dynamic add/remove)\n        startWith(undefined)\n      )\n      .subscribe(() => {\n        this.itemSubscriptions?.forEach(sub => sub.unsubscribe()); // Remove old subscriptions\n        this.itemSubscriptions = this.items?.map(item =>\n          item.valueChanges.subscribe(() => {\n            this._changeDetectorRef.detectChanges(); // DetectChanges when carousel item attributes changes\n          })\n        );\n        this._changeDetectorRef.detectChanges(); // Force update html render\n      });\n    setTimeout(() => {\n      this.carousel = Carousel.getOrCreateInstance(this.carouselDiv.nativeElement);\n    }, 100);\n  }\n\n  ngOnDestroy(): void {\n    this.itemSubscriptions?.forEach(item => item.unsubscribe());\n  }\n\n  /**\n   * Removes Carousel features\n   */\n  public dispose(): void {\n    this.carousel?.dispose();\n  }\n}\n","<div\n  #carousel\n  class=\"it-carousel-wrapper splide {{ typeClass }}\"\n  [class.it-full-carousel]=\"fullCarousel\"\n  [class.it-big-img]=\"bigImg\"\n  [class.it-standard-image]=\"standardImage\">\n  @if (title) {\n    <div class=\"it-header-block\">\n      <div class=\"it-header-block-title\">\n        <h2>{{ title }}</h2>\n      </div>\n    </div>\n  }\n\n  <div class=\"splide__track {{ trackClass }}\">\n    @if (items) {\n      <ul class=\"splide__list\">\n        @for (item of items; track item) {\n          <li class=\"splide__slide\" [class.lined_slide]=\"lined\">\n            <div class=\"it-single-slide-wrapper\">\n              <ng-container *ngTemplateOutlet=\"item.htmlContent\"></ng-container>\n            </div>\n          </li>\n        }\n      </ul>\n    }\n  </div>\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video-player-i18n.model.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/video-player/video-player-i18n.model.ts"],"names":[],"mappings":"","sourcesContent":["interface VideoJsTranslation {\n  'Audio Player': string;\n  'Video Player': string;\n  Play: string;\n  Pause: string;\n  Replay: string;\n  'Current Time': string;\n  Duration: string;\n  'Remaining Time': string;\n  'Stream Type': string;\n  LIVE: string;\n  Loaded: string;\n  Progress: string;\n  'Progress Bar': string;\n  'progress bar timing: currentTime={1} duration={2}': string;\n  Fullscreen: string;\n  'Exit Fullscreen': string;\n  Mute: string;\n  Unmute: string;\n  'Playback Rate': string;\n  Subtitles: string;\n  'subtitles off': string;\n  Captions: string;\n  'captions off': string;\n  Chapters: string;\n  Descriptions: string;\n  'descriptions off': string;\n  'Audio Track': string;\n  'Volume Level': string;\n  'You aborted the media playback': string;\n  'A network error caused the media download to fail part-way.': string;\n  'The media could not be loaded, either because the server or network failed or because the format is not supported.': string;\n  'The media playback was aborted due to a corruption problem or because the media used features your browser did not support.': string;\n  'No compatible source was found for this media.': string;\n  'The media is encrypted and we do not have the keys to decrypt it.': string;\n  'Play Video': string;\n  Close: string;\n  'Close Modal Dialog': string;\n  'Modal Window': string;\n  'This is a modal window': string;\n  'This modal can be closed by pressing the Escape key or activating the close button.': string;\n  ', opens captions settings dialog': string;\n  ', opens subtitles settings dialog': string;\n  ', opens descriptions settings dialog': string;\n  ', selected': string;\n  'captions settings': string;\n  'subtitles settings': string;\n  'descriptions settings': string;\n  Text: string;\n  White: string;\n  Black: string;\n  Red: string;\n  Green: string;\n  Blue: string;\n  Yellow: string;\n  Magenta: string;\n  Cyan: string;\n  Background: string;\n  Window: string;\n  Transparent: string;\n  'Semi-Transparent': string;\n  Opaque: string;\n  'Font Size': string;\n  'Text Edge Style': string;\n  None: string;\n  Uniform: string;\n  'Drop shadow': string;\n  'Font Family': string;\n  'Proportional Sans-Serif': string;\n  'Monospace Sans-Serif': string;\n  'Proportional Serif': string;\n  'Monospace Serif': string;\n  'Small Caps': string;\n  Reset: string;\n  'restore all settings to the default values': string;\n  Done: string;\n  'Caption Settings Dialog': string;\n  'Beginning of dialog window. Escape will cancel and close the window.': string;\n  'End of dialog window.': string;\n  '{1} is loading.': string;\n  'Exit Picture-in-Picture': string;\n  'Picture-in-Picture': string;\n  Color: string;\n  Opacity: string;\n  'Text Background': string;\n  'Caption Area Background': string;\n  'Skip forward {1} seconds': string;\n  'Skip backward {1} seconds': string;\n}\n\ninterface VideoPlayerTranslations {\n  'audio-player': string;\n  'video-player': string;\n  play: string;\n  pause: string;\n  replay: string;\n  'current-time': string;\n  duration: string;\n  'remaining-time': string;\n  'stream-type': string;\n  live: string;\n  loaded: string;\n  progress: string;\n  'progress-bar': string;\n  'progress-bar-timing:-currenttime={1}-duration={2}': string;\n  fullscreen: string;\n  'exit-fullscreen': string;\n  mute: string;\n  unmute: string;\n  'playback-rate': string;\n  subtitles: string;\n  'subtitles-off': string;\n  captions: string;\n  'captions-off': string;\n  chapters: string;\n  descriptions: string;\n  'descriptions-off': string;\n  'audio-track': string;\n  'volume-level': string;\n  'you-aborted-the-media-playback': string;\n  'a-network-error-caused-the-media-download-to-fail-part-way.': string;\n  'the-media-could-not-be-loaded,-either-because-the-server-or-network-failed-or-because-the-format-is-not-supported.': string;\n  'the-media-playback-was-aborted-due-to-a-corruption-problem-or-because-the-media-used-features-your-browser-did-not-support.': string;\n  'no-compatible-source-was-found-for-this-media.': string;\n  'the-media-is-encrypted-and-we-do-not-have-the-keys-to-decrypt-it.': string;\n  'play-video': string;\n  close: string;\n  'close-modal-dialog': string;\n  'modal-window': string;\n  'this-is-a-modal-window': string;\n  'this-modal-can-be-closed-by-pressing-the-escape-key-or-activating-the-close-button.': string;\n  ',-opens-captions-settings-dialog': string;\n  ',-opens-subtitles-settings-dialog': string;\n  ',-opens-descriptions-settings-dialog': string;\n  ',-selected': string;\n  'captions-settings': string;\n  'subtitles-settings': string;\n  'descriptions-settings': string;\n  text: string;\n  white: string;\n  black: string;\n  red: string;\n  green: string;\n  blue: string;\n  yellow: string;\n  magenta: string;\n  cyan: string;\n  background: string;\n  window: string;\n  transparent: string;\n  'semi-transparent': string;\n  opaque: string;\n  'font-size': string;\n  'text-edge-style': string;\n  none: string;\n  uniform: string;\n  'drop-shadow': string;\n  'font-family': string;\n  'proportional-sans-serif': string;\n  'monospace-sans-serif': string;\n  'proportional-serif': string;\n  'monospace-serif': string;\n  'small-caps': string;\n  reset: string;\n  'restore-all-settings-to-the-default-values': string;\n  done: string;\n  'caption-settings-dialog': string;\n  'beginning-of-dialog-window.-escape-will-cancel-and-close-the-window.': string;\n  'end-of-dialog-window.': string;\n  '{1}-is-loading.': string;\n  'exit-picture-in-picture': string;\n  'picture-in-picture': string;\n  color: string;\n  opacity: string;\n  'text-background': string;\n  'caption-area-background': string;\n  'skip-forward-{1}-seconds': string;\n  'skip-backward-{1}-seconds': string;\n}\n\nexport type { VideoJsTranslation, VideoPlayerTranslations };\n"]}