@eui/mobile-core 17.0.0-next.4 → 17.0.0-next.5

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 (66) hide show
  1. package/docs/components/EuimAlertMessageComponent.html +3 -3
  2. package/docs/components/EuimChipSelectorComponent.html +3 -3
  3. package/docs/components/EuimEmptyListPlaceholderComponent.html +3 -3
  4. package/docs/components/EuimLabelComponent.html +4 -4
  5. package/docs/components/EuimMediaHeaderComponent.html +1 -1
  6. package/docs/components/EuimMenuComponent.html +0 -11
  7. package/docs/components/EuimMultiselectComponent.html +1 -1
  8. package/docs/components/EuimMultiselectToolbarComponent.html +1 -1
  9. package/docs/components/EuimSkeletonListItemComponent.html +5 -5
  10. package/docs/components/EuimSliderComponent.html +3 -25
  11. package/docs/components/EuimSliderInfoScreenComponent.html +5 -27
  12. package/docs/components/EuimStepperComponent.html +2 -2
  13. package/docs/components/EuimToolbarComponent.html +3 -3
  14. package/docs/dependencies.html +4 -4
  15. package/docs/directives/BaseStatesDirective.html +29 -29
  16. package/docs/directives/EuimChipSelectorItemDirective.html +1 -1
  17. package/docs/js/search/search_index.js +2 -2
  18. package/esm2022/lib/components/atoms/euim-label/euim-label.component.mjs +11 -21
  19. package/esm2022/lib/components/base-states.directive.mjs +61 -121
  20. package/esm2022/lib/components/euim-alert-message/euim-alert-messsage.component.mjs +9 -17
  21. package/esm2022/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.mjs +5 -9
  22. package/esm2022/lib/components/euim-chip-selector/euim-chip-selector.component.mjs +9 -17
  23. package/esm2022/lib/components/euim-empty-list-placeholder/euim-empty-list-placeholder.component.mjs +9 -17
  24. package/esm2022/lib/components/euim-media-header/euim-media-header.component.mjs +5 -9
  25. package/esm2022/lib/components/euim-menu/euim-menu.component.mjs +2 -7
  26. package/esm2022/lib/components/euim-multiselect/euim-multiselect-toolbar/euim-multiselect-toolbar.component.mjs +5 -9
  27. package/esm2022/lib/components/euim-multiselect/euim-multiselect.component.mjs +5 -9
  28. package/esm2022/lib/components/euim-skeleton-list-item/euim-skeleton-list-item.component.mjs +13 -25
  29. package/esm2022/lib/components/euim-slider/euim-slider.component.mjs +11 -25
  30. package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.mjs +15 -33
  31. package/esm2022/lib/components/euim-stepper/euim-stepper.component.mjs +7 -13
  32. package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar.component.mjs +9 -17
  33. package/fesm2022/eui-mobile-core.mjs +148 -293
  34. package/fesm2022/eui-mobile-core.mjs.map +1 -1
  35. package/lib/components/atoms/euim-label/euim-label.component.d.ts +8 -5
  36. package/lib/components/atoms/euim-label/euim-label.component.d.ts.map +1 -1
  37. package/lib/components/base-states.directive.d.ts +58 -30
  38. package/lib/components/base-states.directive.d.ts.map +1 -1
  39. package/lib/components/euim-alert-message/euim-alert-messsage.component.d.ts +6 -4
  40. package/lib/components/euim-alert-message/euim-alert-messsage.component.d.ts.map +1 -1
  41. package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts +2 -2
  42. package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts.map +1 -1
  43. package/lib/components/euim-chip-selector/euim-chip-selector.component.d.ts +6 -3
  44. package/lib/components/euim-chip-selector/euim-chip-selector.component.d.ts.map +1 -1
  45. package/lib/components/euim-empty-list-placeholder/euim-empty-list-placeholder.component.d.ts +6 -4
  46. package/lib/components/euim-empty-list-placeholder/euim-empty-list-placeholder.component.d.ts.map +1 -1
  47. package/lib/components/euim-media-header/euim-media-header.component.d.ts +2 -2
  48. package/lib/components/euim-media-header/euim-media-header.component.d.ts.map +1 -1
  49. package/lib/components/euim-menu/euim-menu.component.d.ts.map +1 -1
  50. package/lib/components/euim-multiselect/euim-multiselect-toolbar/euim-multiselect-toolbar.component.d.ts +2 -2
  51. package/lib/components/euim-multiselect/euim-multiselect-toolbar/euim-multiselect-toolbar.component.d.ts.map +1 -1
  52. package/lib/components/euim-multiselect/euim-multiselect.component.d.ts +2 -2
  53. package/lib/components/euim-multiselect/euim-multiselect.component.d.ts.map +1 -1
  54. package/lib/components/euim-skeleton-list-item/euim-skeleton-list-item.component.d.ts +10 -6
  55. package/lib/components/euim-skeleton-list-item/euim-skeleton-list-item.component.d.ts.map +1 -1
  56. package/lib/components/euim-slider/euim-slider.component.d.ts +6 -3
  57. package/lib/components/euim-slider/euim-slider.component.d.ts.map +1 -1
  58. package/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.d.ts +10 -5
  59. package/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.d.ts.map +1 -1
  60. package/lib/components/euim-stepper/euim-stepper.component.d.ts +4 -3
  61. package/lib/components/euim-stepper/euim-stepper.component.d.ts.map +1 -1
  62. package/lib/components/layout/euim-language-selector/euim-language-selector.component.d.ts +1 -1
  63. package/lib/components/layout/euim-language-selector/euim-language-selector.component.d.ts.map +1 -1
  64. package/lib/components/layout/euim-toolbar/euim-toolbar.component.d.ts +6 -4
  65. package/lib/components/layout/euim-toolbar/euim-toolbar.component.d.ts.map +1 -1
  66. package/package.json +1 -1
@@ -1,6 +1,4 @@
1
- import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, } from '@angular/core';
3
- import { coerceBoolean } from '@eui/base';
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, booleanAttribute, } from '@angular/core';
4
2
  import * as i0 from "@angular/core";
5
3
  import * as i1 from "@ionic/angular";
6
4
  export class EuimMultiselectComponent {
@@ -62,11 +60,8 @@ export class EuimMultiselectComponent {
62
60
  }
63
61
  }
64
62
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimMultiselectComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
65
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimMultiselectComponent, selector: "euim-multiselect", inputs: { currentDataProvider: "currentDataProvider", toolbarTitle: "toolbarTitle", euimKeepSelection: "euimKeepSelection" }, host: { properties: { "class": "this.className" } }, usesOnChanges: true, ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"light\" class=\"euim-multiselect__toolbar\">\n <ng-content select=\"euim-multiselect-toolbar\"></ng-content>\n <ion-toolbar color=\"light\">\n <ng-content select=\"euim-multiselect-filter\"></ng-content>\n </ion-toolbar>\n </ion-toolbar>\n</ion-header>\n\n@if (currentDataProvider?.length > 0) {\n <ng-content select=\"euim-multiselect-list\">\n </ng-content>\n}\n\n@if (currentDataProvider?.length === 0) {\n <ng-content select=\"euim-empty-list-placeholder\">\n </ng-content>\n}\n\n\n\n", styles: [".euim-multiselect__toolbar{color:var(--eui-base-color-grey-100)}.euim-multiselect__toolbar--title{font:normal normal 400 1.25rem/1.5rem var(--eui-base-font-family);font-weight:700}\n"], dependencies: [{ kind: "component", type: i1.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i1.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
63
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimMultiselectComponent, selector: "euim-multiselect", inputs: { currentDataProvider: "currentDataProvider", toolbarTitle: "toolbarTitle", euimKeepSelection: ["euimKeepSelection", "euimKeepSelection", booleanAttribute] }, host: { properties: { "class": "this.className" } }, usesOnChanges: true, ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"light\" class=\"euim-multiselect__toolbar\">\n <ng-content select=\"euim-multiselect-toolbar\"></ng-content>\n <ion-toolbar color=\"light\">\n <ng-content select=\"euim-multiselect-filter\"></ng-content>\n </ion-toolbar>\n </ion-toolbar>\n</ion-header>\n\n@if (currentDataProvider?.length > 0) {\n <ng-content select=\"euim-multiselect-list\">\n </ng-content>\n}\n\n@if (currentDataProvider?.length === 0) {\n <ng-content select=\"euim-empty-list-placeholder\">\n </ng-content>\n}\n\n\n\n", styles: [".euim-multiselect__toolbar{color:var(--eui-base-color-grey-100)}.euim-multiselect__toolbar--title{font:normal normal 400 1.25rem/1.5rem var(--eui-base-font-family);font-weight:700}\n"], dependencies: [{ kind: "component", type: i1.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i1.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
66
64
  }
67
- __decorate([
68
- coerceBoolean
69
- ], EuimMultiselectComponent.prototype, "euimKeepSelection", void 0);
70
65
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimMultiselectComponent, decorators: [{
71
66
  type: Component,
72
67
  args: [{ selector: 'euim-multiselect', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ion-header>\n <ion-toolbar color=\"light\" class=\"euim-multiselect__toolbar\">\n <ng-content select=\"euim-multiselect-toolbar\"></ng-content>\n <ion-toolbar color=\"light\">\n <ng-content select=\"euim-multiselect-filter\"></ng-content>\n </ion-toolbar>\n </ion-toolbar>\n</ion-header>\n\n@if (currentDataProvider?.length > 0) {\n <ng-content select=\"euim-multiselect-list\">\n </ng-content>\n}\n\n@if (currentDataProvider?.length === 0) {\n <ng-content select=\"euim-empty-list-placeholder\">\n </ng-content>\n}\n\n\n\n", styles: [".euim-multiselect__toolbar{color:var(--eui-base-color-grey-100)}.euim-multiselect__toolbar--title{font:normal normal 400 1.25rem/1.5rem var(--eui-base-font-family);font-weight:700}\n"] }]
@@ -78,6 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
78
73
  }], toolbarTitle: [{
79
74
  type: Input
80
75
  }], euimKeepSelection: [{
81
- type: Input
76
+ type: Input,
77
+ args: [{ transform: booleanAttribute }]
82
78
  }] } });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-multiselect.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-multiselect/euim-multiselect.component.ts","../../../../../src/lib/components/euim-multiselect/euim-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy, ChangeDetectorRef,\n    Component, EventEmitter,\n    HostBinding,\n    Input, OnInit, Output, AfterContentChecked,\n    ViewEncapsulation, SimpleChanges, OnChanges,\n} from '@angular/core';\nimport { coerceBoolean } from '@eui/base';\nimport { BooleanInput } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'euim-multiselect',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: './euim-multiselect.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n\nexport class EuimMultiselectComponent\n    implements OnInit, AfterContentChecked, OnChanges {\n    @HostBinding('class') className = 'euim-multiselect';\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    initialDataProvider: any[] ;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input()  currentDataProvider: any[];\n    @Input()  toolbarTitle: string;\n    @Input()\n    @coerceBoolean\n    euimKeepSelection: BooleanInput = false;\n\n    selectAll: boolean;\n    indeterminate: boolean;\n    numberOfSelected = 0 ;\n\n    constructor(private ref: ChangeDetectorRef) {\n    }\n\n    ngOnInit ():void {\n\n        if (this.euimKeepSelection) {\n            this.currentDataProvider =\n                [...this.currentDataProvider]?.map((obj, index) =>\n                    ({ ...obj, _id: index + 1 }));\n        }\n\n        this.initialDataProvider = this.currentDataProvider;\n    }\n\n    selectAllItems():void {\n        this.currentDataProvider =\n            [...this.currentDataProvider]?.map(item => ({ ...item, selected: true }));\n\n        this.selectAll = true;\n\n    }\n\n    deselectAllItems():void {\n        this.currentDataProvider =\n            [...this.currentDataProvider]?.map(item => ({ ...item, selected: false }));\n        this.selectAll = false;\n    }\n\n    countSelectedItems(): number {\n        return this.currentDataProvider?.filter(item => item.selected).length;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    selectedItems(): any[] {\n        if (this.euimKeepSelection) {\n            const filteredItemsWithoutId = this.currentDataProvider\n                ?.filter(item => item.selected)\n                .map(({ _id, ...rest }) => rest);\n\n            return filteredItemsWithoutId;\n        } else {\n            return this.currentDataProvider?.filter(item => item.selected);\n        }\n\n    }\n\n    selectByIndex(index: number, state = true): void{\n        if (index <  this.currentDataProvider?.length) {\n            this.currentDataProvider[index].selected = state;\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        this.ref.detectChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.currentDataProvider &&\n            changes.currentDataProvider.currentValue\n            && changes.currentDataProvider.previousValue === null) {\n\n            if (this.euimKeepSelection) {\n                this.currentDataProvider =\n                    [...this.currentDataProvider]?.map((obj, index) =>\n                        ({ ...obj, _id: index + 1 }));\n            }\n\n            this.initialDataProvider = changes.currentDataProvider.currentValue;\n        }\n    }\n}\n","<ion-header>\n  <ion-toolbar color=\"light\" class=\"euim-multiselect__toolbar\">\n    <ng-content select=\"euim-multiselect-toolbar\"></ng-content>\n    <ion-toolbar color=\"light\">\n      <ng-content select=\"euim-multiselect-filter\"></ng-content>\n    </ion-toolbar>\n  </ion-toolbar>\n</ion-header>\n\n@if (currentDataProvider?.length > 0) {\n  <ng-content select=\"euim-multiselect-list\">\n  </ng-content>\n}\n\n@if (currentDataProvider?.length === 0) {\n  <ng-content select=\"euim-empty-list-placeholder\">\n  </ng-content>\n}\n\n\n\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-multiselect.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-multiselect/euim-multiselect.component.ts","../../../../../src/lib/components/euim-multiselect/euim-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy, ChangeDetectorRef,\n    Component, EventEmitter,\n    HostBinding,\n    Input, OnInit, Output, AfterContentChecked,\n    ViewEncapsulation, SimpleChanges, OnChanges, booleanAttribute,\n} from '@angular/core';\nimport { coerceBoolean } from '@eui/base';\nimport { BooleanInput } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'euim-multiselect',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: './euim-multiselect.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n\nexport class EuimMultiselectComponent\n    implements OnInit, AfterContentChecked, OnChanges {\n    @HostBinding('class') className = 'euim-multiselect';\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    initialDataProvider: any[] ;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input()  currentDataProvider: any[];\n    @Input()  toolbarTitle: string;\n    @Input({ transform: booleanAttribute })\n    euimKeepSelection = false;\n\n    selectAll: boolean;\n    indeterminate: boolean;\n    numberOfSelected = 0 ;\n\n    constructor(private ref: ChangeDetectorRef) {\n    }\n\n    ngOnInit ():void {\n\n        if (this.euimKeepSelection) {\n            this.currentDataProvider =\n                [...this.currentDataProvider]?.map((obj, index) =>\n                    ({ ...obj, _id: index + 1 }));\n        }\n\n        this.initialDataProvider = this.currentDataProvider;\n    }\n\n    selectAllItems():void {\n        this.currentDataProvider =\n            [...this.currentDataProvider]?.map(item => ({ ...item, selected: true }));\n\n        this.selectAll = true;\n\n    }\n\n    deselectAllItems():void {\n        this.currentDataProvider =\n            [...this.currentDataProvider]?.map(item => ({ ...item, selected: false }));\n        this.selectAll = false;\n    }\n\n    countSelectedItems(): number {\n        return this.currentDataProvider?.filter(item => item.selected).length;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    selectedItems(): any[] {\n        if (this.euimKeepSelection) {\n            const filteredItemsWithoutId = this.currentDataProvider\n                ?.filter(item => item.selected)\n                .map(({ _id, ...rest }) => rest);\n\n            return filteredItemsWithoutId;\n        } else {\n            return this.currentDataProvider?.filter(item => item.selected);\n        }\n\n    }\n\n    selectByIndex(index: number, state = true): void{\n        if (index <  this.currentDataProvider?.length) {\n            this.currentDataProvider[index].selected = state;\n        }\n    }\n\n    ngAfterContentChecked(): void {\n        this.ref.detectChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.currentDataProvider &&\n            changes.currentDataProvider.currentValue\n            && changes.currentDataProvider.previousValue === null) {\n\n            if (this.euimKeepSelection) {\n                this.currentDataProvider =\n                    [...this.currentDataProvider]?.map((obj, index) =>\n                        ({ ...obj, _id: index + 1 }));\n            }\n\n            this.initialDataProvider = changes.currentDataProvider.currentValue;\n        }\n    }\n}\n","<ion-header>\n  <ion-toolbar color=\"light\" class=\"euim-multiselect__toolbar\">\n    <ng-content select=\"euim-multiselect-toolbar\"></ng-content>\n    <ion-toolbar color=\"light\">\n      <ng-content select=\"euim-multiselect-filter\"></ng-content>\n    </ion-toolbar>\n  </ion-toolbar>\n</ion-header>\n\n@if (currentDataProvider?.length > 0) {\n  <ng-content select=\"euim-multiselect-list\">\n  </ng-content>\n}\n\n@if (currentDataProvider?.length === 0) {\n  <ng-content select=\"euim-empty-list-placeholder\">\n  </ng-content>\n}\n\n\n\n"]}
@@ -1,6 +1,4 @@
1
- import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
3
- import { coerceBoolean } from '@eui/base';
1
+ import { booleanAttribute, ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, } from '@angular/core';
4
2
  import { BaseStatesDirective } from '../base-states.directive';
5
3
  import * as i0 from "@angular/core";
6
4
  import * as i1 from "../base-states.directive";
@@ -29,23 +27,8 @@ export class EuimSkeletonListItemComponent {
29
27
  .trim();
30
28
  }
31
29
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSkeletonListItemComponent, deps: [{ token: i1.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
32
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSkeletonListItemComponent, selector: "euim-skeleton-list-item", inputs: { hasAvatar: "hasAvatar", hasTitle: "hasTitle", hasSubtitle: "hasSubtitle", hasMetaLine: "hasMetaLine", isAnimated: "isAnimated", avatarType: "avatarType", separator: "separator", titleWidth: "titleWidth", subTitleWidth: "subTitleWidth", metaLineWidth: "metaLineWidth" }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i1.BaseStatesDirective, inputs: ["euimSize2XL", "euimSize2XL", "euimSizeL", "euimSizeL"] }], ngImport: i0, template: "<ion-item button [lines]=\"separator\">\n @if (hasAvatar) {\n <ion-thumbnail slot=\"start\">\n <ion-skeleton-text [animated]=\"true\"></ion-skeleton-text>\n </ion-thumbnail>\n }\n <ion-label>\n @if (hasTitle) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"titleWidth || '80%'\"></ion-skeleton-text>\n }\n @if (hasSubtitle) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"subTitleWidth || '60%'\"></ion-skeleton-text>\n }\n @if (hasMetaLine) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"metaLineWidth || '40%'\"></ion-skeleton-text>\n }\n </ion-label>\n</ion-item>\n", styles: [".euim-skeleton-list-item ion-label ion-skeleton-text{margin-bottom:var(--eui-base-spacing-xs)}.euim-skeleton-list-item ion-thumbnail{width:var(--eui-base-spacing-2xl);height:var(--eui-base-spacing-2xl)}.euim-skeleton-list-item--size-l ion-thumbnail{width:var(--eui-base-spacing-l);height:var(--eui-base-spacing-l)}.euim-skeleton-list-item--size-2xl ion-thumbnail{width:var(--eui-base-spacing-2xl);height:var(--eui-base-spacing-2xl)}.euim-skeleton-list-item ion-thumbnail{--border-radius: 50%}.euim-skeleton-list-item--square ion-thumbnail{--border-radius: 0}\n"], dependencies: [{ kind: "component", type: i2.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonSkeletonText, selector: "ion-skeleton-text", inputs: ["animated"] }, { kind: "component", type: i2.IonThumbnail, selector: "ion-thumbnail" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
30
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSkeletonListItemComponent, selector: "euim-skeleton-list-item", inputs: { hasAvatar: ["hasAvatar", "hasAvatar", booleanAttribute], hasTitle: ["hasTitle", "hasTitle", booleanAttribute], hasSubtitle: ["hasSubtitle", "hasSubtitle", booleanAttribute], hasMetaLine: ["hasMetaLine", "hasMetaLine", booleanAttribute], isAnimated: ["isAnimated", "isAnimated", booleanAttribute], avatarType: "avatarType", separator: "separator", titleWidth: "titleWidth", subTitleWidth: "subTitleWidth", metaLineWidth: "metaLineWidth" }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i1.BaseStatesDirective, inputs: ["euimSize2XL", "euimSize2XL", "euimSizeL", "euimSizeL"] }], ngImport: i0, template: "<ion-item button [lines]=\"separator\">\n @if (hasAvatar) {\n <ion-thumbnail slot=\"start\">\n <ion-skeleton-text [animated]=\"true\"></ion-skeleton-text>\n </ion-thumbnail>\n }\n <ion-label>\n @if (hasTitle) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"titleWidth || '80%'\"></ion-skeleton-text>\n }\n @if (hasSubtitle) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"subTitleWidth || '60%'\"></ion-skeleton-text>\n }\n @if (hasMetaLine) {\n <ion-skeleton-text [animated]=\"isAnimated\"\n [style.width]=\"metaLineWidth || '40%'\"></ion-skeleton-text>\n }\n </ion-label>\n</ion-item>\n", styles: [".euim-skeleton-list-item ion-label ion-skeleton-text{margin-bottom:var(--eui-base-spacing-xs)}.euim-skeleton-list-item ion-thumbnail{width:var(--eui-base-spacing-2xl);height:var(--eui-base-spacing-2xl)}.euim-skeleton-list-item--size-l ion-thumbnail{width:var(--eui-base-spacing-l);height:var(--eui-base-spacing-l)}.euim-skeleton-list-item--size-2xl ion-thumbnail{width:var(--eui-base-spacing-2xl);height:var(--eui-base-spacing-2xl)}.euim-skeleton-list-item ion-thumbnail{--border-radius: 50%}.euim-skeleton-list-item--square ion-thumbnail{--border-radius: 0}\n"], dependencies: [{ kind: "component", type: i2.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonSkeletonText, selector: "ion-skeleton-text", inputs: ["animated"] }, { kind: "component", type: i2.IonThumbnail, selector: "ion-thumbnail" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
33
31
  }
34
- __decorate([
35
- coerceBoolean
36
- ], EuimSkeletonListItemComponent.prototype, "hasAvatar", void 0);
37
- __decorate([
38
- coerceBoolean
39
- ], EuimSkeletonListItemComponent.prototype, "hasTitle", void 0);
40
- __decorate([
41
- coerceBoolean
42
- ], EuimSkeletonListItemComponent.prototype, "hasSubtitle", void 0);
43
- __decorate([
44
- coerceBoolean
45
- ], EuimSkeletonListItemComponent.prototype, "hasMetaLine", void 0);
46
- __decorate([
47
- coerceBoolean
48
- ], EuimSkeletonListItemComponent.prototype, "isAnimated", void 0);
49
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSkeletonListItemComponent, decorators: [{
50
33
  type: Component,
51
34
  args: [{ selector: 'euim-skeleton-list-item', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [
@@ -61,15 +44,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
61
44
  type: HostBinding,
62
45
  args: ['class']
63
46
  }], hasAvatar: [{
64
- type: Input
47
+ type: Input,
48
+ args: [{ transform: booleanAttribute }]
65
49
  }], hasTitle: [{
66
- type: Input
50
+ type: Input,
51
+ args: [{ transform: booleanAttribute }]
67
52
  }], hasSubtitle: [{
68
- type: Input
53
+ type: Input,
54
+ args: [{ transform: booleanAttribute }]
69
55
  }], hasMetaLine: [{
70
- type: Input
56
+ type: Input,
57
+ args: [{ transform: booleanAttribute }]
71
58
  }], isAnimated: [{
72
- type: Input
59
+ type: Input,
60
+ args: [{ transform: booleanAttribute }]
73
61
  }], avatarType: [{
74
62
  type: Input
75
63
  }], separator: [{
@@ -81,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
81
69
  }], metaLineWidth: [{
82
70
  type: Input
83
71
  }] } });
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1za2VsZXRvbi1saXN0LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtL2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9ldWltLXNrZWxldG9uLWxpc3QtaXRlbS9ldWltLXNrZWxldG9uLWxpc3QtaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFHLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDMUMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFpQi9ELE1BQU0sT0FBTyw2QkFBNkI7SUFDdEMsSUFDVyxVQUFVO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFxQkQsWUFBbUIsbUJBQXdDO1FBQXhDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFsQjNELGNBQVMsR0FBaUIsSUFBSSxDQUFDO1FBRy9CLGFBQVEsR0FBaUIsSUFBSSxDQUFDO1FBRzlCLGdCQUFXLEdBQWlCLElBQUksQ0FBQztRQUdqQyxnQkFBVyxHQUFpQixJQUFJLENBQUM7UUFHakMsZUFBVSxHQUFpQixJQUFJLENBQUM7UUFHdkIsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNuQixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUN0QixrQkFBYSxHQUFHLEtBQUssQ0FBQztJQUMrQixDQUFDO0lBRXZELGFBQWE7UUFDakIsT0FBTztZQUNILElBQUksQ0FBQyxVQUFVLElBQUksUUFBUSxDQUFDLENBQUMsQ0FBQyw0QkFBNEIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHO1lBQ2pGLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxhQUFhLENBQUMseUJBQXlCLENBQUM7U0FDcEU7YUFDSSxJQUFJLENBQUMsR0FBRyxDQUFDO2FBQ1QsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztpSUFsQ1EsNkJBQTZCO3FIQUE3Qiw2QkFBNkIsd2dCQ3BCMUMsbXJCQXFCQTs7QURNSTtJQURDLGFBQWE7Z0VBQ2lCO0FBRy9CO0lBREMsYUFBYTsrREFDZ0I7QUFHOUI7SUFEQyxhQUFhO2tFQUNtQjtBQUdqQztJQURDLGFBQWE7a0VBQ21CO0FBR2pDO0lBREMsYUFBYTtpRUFDa0I7MkZBbkJ2Qiw2QkFBNkI7a0JBaEJ6QyxTQUFTOytCQUNJLHlCQUF5QixpQkFHcEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxrQkFDL0I7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLG1CQUFtQjs0QkFDOUIsTUFBTSxFQUFFO2dDQUNKLGFBQWE7Z0NBQ2IsV0FBVzs2QkFDZDt5QkFDSjtxQkFDSjt3RkFJVSxVQUFVO3NCQURwQixXQUFXO3VCQUFDLE9BQU87Z0JBTXBCLFNBQVM7c0JBRlIsS0FBSztnQkFLTixRQUFRO3NCQUZQLEtBQUs7Z0JBS04sV0FBVztzQkFGVixLQUFLO2dCQUtOLFdBQVc7c0JBRlYsS0FBSztnQkFLTixVQUFVO3NCQUZULEtBQUs7Z0JBR0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW4gfSBmcm9tICdAZXVpL2Jhc2UnO1xuaW1wb3J0IHsgQmFzZVN0YXRlc0RpcmVjdGl2ZSB9IGZyb20gJy4uL2Jhc2Utc3RhdGVzLmRpcmVjdGl2ZSc7XG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zdHlsZXMvX2luZGV4LnNjc3MnXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXVpbS1za2VsZXRvbi1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgZGlyZWN0aXZlOiBCYXNlU3RhdGVzRGlyZWN0aXZlLFxuICAgICAgICAgICAgaW5wdXRzOiBbXG4gICAgICAgICAgICAgICAgJ2V1aW1TaXplMlhMJyxcbiAgICAgICAgICAgICAgICAnZXVpbVNpemVMJyxcbiAgICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbVNrZWxldG9uTGlzdEl0ZW1Db21wb25lbnQge1xuICAgIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICAgIHB1YmxpYyBnZXQgY3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRDc3NDbGFzc2VzKCk7XG4gICAgfVxuICAgIEBJbnB1dCgpXG4gICAgQGNvZXJjZUJvb2xlYW5cbiAgICBoYXNBdmF0YXI6IEJvb2xlYW5JbnB1dCA9IHRydWU7XG4gICAgQElucHV0KClcbiAgICBAY29lcmNlQm9vbGVhblxuICAgIGhhc1RpdGxlOiBCb29sZWFuSW5wdXQgPSB0cnVlO1xuICAgIEBJbnB1dCgpXG4gICAgQGNvZXJjZUJvb2xlYW5cbiAgICBoYXNTdWJ0aXRsZTogQm9vbGVhbklucHV0ID0gdHJ1ZTtcbiAgICBASW5wdXQoKVxuICAgIEBjb2VyY2VCb29sZWFuXG4gICAgaGFzTWV0YUxpbmU6IEJvb2xlYW5JbnB1dCA9IHRydWU7XG4gICAgQElucHV0KClcbiAgICBAY29lcmNlQm9vbGVhblxuICAgIGlzQW5pbWF0ZWQ6IEJvb2xlYW5JbnB1dCA9IHRydWU7XG4gICAgQElucHV0KCkgYXZhdGFyVHlwZTogJ2RlZmF1bHQnIHwgJ3NxdWFyZSc7XG4gICAgQElucHV0KCkgc2VwYXJhdG9yOiAnbm9uZScgfCAnZnVsbCcgfCAnaW5zZXQnO1xuICAgIEBJbnB1dCgpIHRpdGxlV2lkdGggPSAnODAlJztcbiAgICBASW5wdXQoKSBzdWJUaXRsZVdpZHRoID0gJzYwJSc7XG4gICAgQElucHV0KCkgbWV0YUxpbmVXaWR0aCA9ICc0MCUnO1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBiYXNlU3RhdGVzRGlyZWN0aXZlOiBCYXNlU3RhdGVzRGlyZWN0aXZlKSB7fVxuXG4gICAgcHJpdmF0ZSBnZXRDc3NDbGFzc2VzKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICB0aGlzLmF2YXRhclR5cGUgPT0gJ3NxdWFyZScgPyBgZXVpbS1za2VsZXRvbi1saXN0LWl0ZW0tLSR7dGhpcy5hdmF0YXJUeXBlfWAgOiAnICcsXG4gICAgICAgICAgICB0aGlzLmJhc2VTdGF0ZXNEaXJlY3RpdmUuZ2V0Q3NzQ2xhc3NlcygnZXVpbS1za2VsZXRvbi1saXN0LWl0ZW0nKSxcbiAgICAgICAgXVxuICAgICAgICAgICAgLmpvaW4oJyAnKVxuICAgICAgICAgICAgLnRyaW0oKTtcbiAgICB9XG59XG4iLCI8aW9uLWl0ZW0gYnV0dG9uIFtsaW5lc109XCJzZXBhcmF0b3JcIj5cbiAgQGlmIChoYXNBdmF0YXIpIHtcbiAgICA8aW9uLXRodW1ibmFpbCBzbG90PVwic3RhcnRcIj5cbiAgICAgIDxpb24tc2tlbGV0b24tdGV4dCBbYW5pbWF0ZWRdPVwidHJ1ZVwiPjwvaW9uLXNrZWxldG9uLXRleHQ+XG4gICAgPC9pb24tdGh1bWJuYWlsPlxuICB9XG4gIDxpb24tbGFiZWw+XG4gICAgQGlmIChoYXNUaXRsZSkge1xuICAgICAgPGlvbi1za2VsZXRvbi10ZXh0IFthbmltYXRlZF09XCJpc0FuaW1hdGVkXCJcbiAgICAgIFtzdHlsZS53aWR0aF09XCJ0aXRsZVdpZHRoIHx8ICc4MCUnXCI+PC9pb24tc2tlbGV0b24tdGV4dD5cbiAgICB9XG4gICAgQGlmIChoYXNTdWJ0aXRsZSkge1xuICAgICAgPGlvbi1za2VsZXRvbi10ZXh0IFthbmltYXRlZF09XCJpc0FuaW1hdGVkXCJcbiAgICAgIFtzdHlsZS53aWR0aF09XCJzdWJUaXRsZVdpZHRoIHx8ICc2MCUnXCI+PC9pb24tc2tlbGV0b24tdGV4dD5cbiAgICB9XG4gICAgQGlmIChoYXNNZXRhTGluZSkge1xuICAgICAgPGlvbi1za2VsZXRvbi10ZXh0IFthbmltYXRlZF09XCJpc0FuaW1hdGVkXCJcbiAgICAgIFtzdHlsZS53aWR0aF09XCJtZXRhTGluZVdpZHRoIHx8ICc0MCUnXCI+PC9pb24tc2tlbGV0b24tdGV4dD5cbiAgICB9XG4gIDwvaW9uLWxhYmVsPlxuPC9pb24taXRlbT5cbiJdfQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1za2VsZXRvbi1saXN0LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtL2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9ldWltLXNrZWxldG9uLWxpc3QtaXRlbS9ldWltLXNrZWxldG9uLWxpc3QtaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsZ0JBQWdCLEVBQ2hCLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsV0FBVyxFQUNYLEtBQUssRUFDTCxpQkFBaUIsR0FDcEIsTUFBTSxlQUFlLENBQUM7QUFHdkIsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFpQi9ELE1BQU0sT0FBTyw2QkFBNkI7SUFDdEMsSUFDVyxVQUFVO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFnQkQsWUFBbUIsbUJBQXdDO1FBQXhDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFkM0QsY0FBUyxHQUFHLElBQUksQ0FBQztRQUVqQixhQUFRLEdBQUcsSUFBSSxDQUFDO1FBRWhCLGdCQUFXLEdBQUcsSUFBSSxDQUFDO1FBRW5CLGdCQUFXLEdBQUcsSUFBSSxDQUFDO1FBRW5CLGVBQVUsR0FBRyxJQUFJLENBQUM7UUFHVCxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ25CLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLGtCQUFhLEdBQUcsS0FBSyxDQUFDO0lBQytCLENBQUM7SUFFdkQsYUFBYTtRQUNqQixPQUFPO1lBQ0gsSUFBSSxDQUFDLFVBQVUsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLDRCQUE0QixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUc7WUFDakYsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyx5QkFBeUIsQ0FBQztTQUNwRTthQUNJLElBQUksQ0FBQyxHQUFHLENBQUM7YUFDVCxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO2lJQTdCUSw2QkFBNkI7cUhBQTdCLDZCQUE2Qix1RkFLbEIsZ0JBQWdCLHNDQUVoQixnQkFBZ0IsK0NBRWhCLGdCQUFnQiwrQ0FFaEIsZ0JBQWdCLDRDQUVoQixnQkFBZ0IsMFZDeEN4QyxtckJBcUJBOzsyRkRNYSw2QkFBNkI7a0JBaEJ6QyxTQUFTOytCQUNJLHlCQUF5QixpQkFHcEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxrQkFDL0I7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLG1CQUFtQjs0QkFDOUIsTUFBTSxFQUFFO2dDQUNKLGFBQWE7Z0NBQ2IsV0FBVzs2QkFDZDt5QkFDSjtxQkFDSjt3RkFJVSxVQUFVO3NCQURwQixXQUFXO3VCQUFDLE9BQU87Z0JBS3BCLFNBQVM7c0JBRFIsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFHdEMsUUFBUTtzQkFEUCxLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUd0QyxXQUFXO3NCQURWLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBR3RDLFdBQVc7c0JBRFYsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFHdEMsVUFBVTtzQkFEVCxLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUU3QixVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIGJvb2xlYW5BdHRyaWJ1dGUsXG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIElucHV0LFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuIH0gZnJvbSAnQGV1aS9iYXNlJztcbmltcG9ydCB7IEJhc2VTdGF0ZXNEaXJlY3RpdmUgfSBmcm9tICcuLi9iYXNlLXN0YXRlcy5kaXJlY3RpdmUnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldWltLXNrZWxldG9uLWxpc3QtaXRlbScsXG4gICAgc3R5bGVVcmxzOiBbJy4vc3R5bGVzL19pbmRleC5zY3NzJ10sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGRpcmVjdGl2ZTogQmFzZVN0YXRlc0RpcmVjdGl2ZSxcbiAgICAgICAgICAgIGlucHV0czogW1xuICAgICAgICAgICAgICAgICdldWltU2l6ZTJYTCcsXG4gICAgICAgICAgICAgICAgJ2V1aW1TaXplTCcsXG4gICAgICAgICAgICBdLFxuICAgICAgICB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIEV1aW1Ta2VsZXRvbkxpc3RJdGVtQ29tcG9uZW50IHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBwdWJsaWMgZ2V0IGNzc0NsYXNzZXMoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZ2V0Q3NzQ2xhc3NlcygpO1xuICAgIH1cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICBoYXNBdmF0YXIgPSB0cnVlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KVxuICAgIGhhc1RpdGxlID0gdHJ1ZTtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICBoYXNTdWJ0aXRsZSA9IHRydWU7XG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgaGFzTWV0YUxpbmUgPSB0cnVlO1xuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KVxuICAgIGlzQW5pbWF0ZWQgPSB0cnVlO1xuICAgIEBJbnB1dCgpIGF2YXRhclR5cGU6ICdkZWZhdWx0JyB8ICdzcXVhcmUnO1xuICAgIEBJbnB1dCgpIHNlcGFyYXRvcjogJ25vbmUnIHwgJ2Z1bGwnIHwgJ2luc2V0JztcbiAgICBASW5wdXQoKSB0aXRsZVdpZHRoID0gJzgwJSc7XG4gICAgQElucHV0KCkgc3ViVGl0bGVXaWR0aCA9ICc2MCUnO1xuICAgIEBJbnB1dCgpIG1ldGFMaW5lV2lkdGggPSAnNDAlJztcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgYmFzZVN0YXRlc0RpcmVjdGl2ZTogQmFzZVN0YXRlc0RpcmVjdGl2ZSkge31cblxuICAgIHByaXZhdGUgZ2V0Q3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gW1xuICAgICAgICAgICAgdGhpcy5hdmF0YXJUeXBlID09ICdzcXVhcmUnID8gYGV1aW0tc2tlbGV0b24tbGlzdC1pdGVtLS0ke3RoaXMuYXZhdGFyVHlwZX1gIDogJyAnLFxuICAgICAgICAgICAgdGhpcy5iYXNlU3RhdGVzRGlyZWN0aXZlLmdldENzc0NsYXNzZXMoJ2V1aW0tc2tlbGV0b24tbGlzdC1pdGVtJyksXG4gICAgICAgIF1cbiAgICAgICAgICAgIC5qb2luKCcgJylcbiAgICAgICAgICAgIC50cmltKCk7XG4gICAgfVxufVxuIiwiPGlvbi1pdGVtIGJ1dHRvbiBbbGluZXNdPVwic2VwYXJhdG9yXCI+XG4gIEBpZiAoaGFzQXZhdGFyKSB7XG4gICAgPGlvbi10aHVtYm5haWwgc2xvdD1cInN0YXJ0XCI+XG4gICAgICA8aW9uLXNrZWxldG9uLXRleHQgW2FuaW1hdGVkXT1cInRydWVcIj48L2lvbi1za2VsZXRvbi10ZXh0PlxuICAgIDwvaW9uLXRodW1ibmFpbD5cbiAgfVxuICA8aW9uLWxhYmVsPlxuICAgIEBpZiAoaGFzVGl0bGUpIHtcbiAgICAgIDxpb24tc2tlbGV0b24tdGV4dCBbYW5pbWF0ZWRdPVwiaXNBbmltYXRlZFwiXG4gICAgICBbc3R5bGUud2lkdGhdPVwidGl0bGVXaWR0aCB8fCAnODAlJ1wiPjwvaW9uLXNrZWxldG9uLXRleHQ+XG4gICAgfVxuICAgIEBpZiAoaGFzU3VidGl0bGUpIHtcbiAgICAgIDxpb24tc2tlbGV0b24tdGV4dCBbYW5pbWF0ZWRdPVwiaXNBbmltYXRlZFwiXG4gICAgICBbc3R5bGUud2lkdGhdPVwic3ViVGl0bGVXaWR0aCB8fCAnNjAlJ1wiPjwvaW9uLXNrZWxldG9uLXRleHQ+XG4gICAgfVxuICAgIEBpZiAoaGFzTWV0YUxpbmUpIHtcbiAgICAgIDxpb24tc2tlbGV0b24tdGV4dCBbYW5pbWF0ZWRdPVwiaXNBbmltYXRlZFwiXG4gICAgICBbc3R5bGUud2lkdGhdPVwibWV0YUxpbmVXaWR0aCB8fCAnNDAlJ1wiPjwvaW9uLXNrZWxldG9uLXRleHQ+XG4gICAgfVxuICA8L2lvbi1sYWJlbD5cbjwvaW9uLWl0ZW0+XG4iXX0=
@@ -1,6 +1,4 @@
1
- import { __decorate } from "tslib";
2
- import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, HostListener, } from '@angular/core';
3
- import { coerceBoolean } from '@eui/base';
1
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, HostListener, booleanAttribute, } from '@angular/core';
4
2
  import * as i0 from "@angular/core";
5
3
  import * as i1 from "@ionic/angular";
6
4
  import * as i2 from "@angular/common";
@@ -127,23 +125,8 @@ export class EuimSliderComponent {
127
125
  this.leftBtnActionClicked.emit(event);
128
126
  }
129
127
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSliderComponent, deps: [{ token: i0.Renderer2 }, { token: i1.GestureController }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
130
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSliderComponent, selector: "euim-slider", inputs: { actionBtnNames: "actionBtnNames", isLeftBtnVisible: "isLeftBtnVisible", isPreviousBtn: "isPreviousBtn", isNextBtn: "isNextBtn" }, outputs: { actionClicked: "actionClicked", lastStepActionClicked: "lastStepActionClicked", leftBtnActionClicked: "leftBtnActionClicked" }, host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "slides", first: true, predicate: ["slides"], descendants: true, static: true }], ngImport: i0, template: "<div #sliderElement class=\"euim-slider__slider-container\">\n <div #slides class=\"euim-slider__slides\">\n <ng-content></ng-content>\n </div>\n <div class=\"euim-slider__pagination-container\">\n @if (isLeftBtnVisible) {\n <ion-button (click)=\"onLeftBtnAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftActionBtnName}}</ion-button>\n }\n <div class=\"euim-slider__pagination\">\n @for (slide of slidesArray; track slide; let i = $index) {\n <span (click)=\"goToSlide(i)\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider__span\"></span>\n }\n </div>\n @if (!isLastItemReached && !isNextBtn || isNextBtn && isRightBtnVisible) {\n <ion-button (click)=\"onAction($event)\" class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.actionBtnName}}</ion-button>\n }\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n</div>\n", styles: [".euim-slider__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider__slides{display:flex;transition:all .5s ease;width:100%}.euim-slider__slide{width:100%}.euim-slider__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider__pagination{display:flex}.euim-slider__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }] }); }
128
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSliderComponent, selector: "euim-slider", inputs: { actionBtnNames: "actionBtnNames", isLeftBtnVisible: ["isLeftBtnVisible", "isLeftBtnVisible", booleanAttribute], isPreviousBtn: ["isPreviousBtn", "isPreviousBtn", booleanAttribute], isNextBtn: ["isNextBtn", "isNextBtn", booleanAttribute] }, outputs: { actionClicked: "actionClicked", lastStepActionClicked: "lastStepActionClicked", leftBtnActionClicked: "leftBtnActionClicked" }, host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "slides", first: true, predicate: ["slides"], descendants: true, static: true }], ngImport: i0, template: "<div #sliderElement class=\"euim-slider__slider-container\">\n <div #slides class=\"euim-slider__slides\">\n <ng-content></ng-content>\n </div>\n <div class=\"euim-slider__pagination-container\">\n @if (isLeftBtnVisible) {\n <ion-button (click)=\"onLeftBtnAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftActionBtnName}}</ion-button>\n }\n <div class=\"euim-slider__pagination\">\n @for (slide of slidesArray; track slide; let i = $index) {\n <span (click)=\"goToSlide(i)\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider__span\"></span>\n }\n </div>\n @if (!isLastItemReached && !isNextBtn || isNextBtn && isRightBtnVisible) {\n <ion-button (click)=\"onAction($event)\" class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.actionBtnName}}</ion-button>\n }\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n</div>\n", styles: [".euim-slider__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider__slides{display:flex;transition:all .5s ease;width:100%}.euim-slider__slide{width:100%}.euim-slider__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider__pagination{display:flex}.euim-slider__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }] }); }
131
129
  }
132
- __decorate([
133
- coerceBoolean
134
- ], EuimSliderComponent.prototype, "isLastItemReached", void 0);
135
- __decorate([
136
- coerceBoolean
137
- ], EuimSliderComponent.prototype, "isLeftBtnVisible", void 0);
138
- __decorate([
139
- coerceBoolean
140
- ], EuimSliderComponent.prototype, "isPreviousBtn", void 0);
141
- __decorate([
142
- coerceBoolean
143
- ], EuimSliderComponent.prototype, "isNextBtn", void 0);
144
- __decorate([
145
- coerceBoolean
146
- ], EuimSliderComponent.prototype, "isRightBtnVisible", void 0);
147
130
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSliderComponent, decorators: [{
148
131
  type: Component,
149
132
  args: [{ selector: 'euim-slider', template: "<div #sliderElement class=\"euim-slider__slider-container\">\n <div #slides class=\"euim-slider__slides\">\n <ng-content></ng-content>\n </div>\n <div class=\"euim-slider__pagination-container\">\n @if (isLeftBtnVisible) {\n <ion-button (click)=\"onLeftBtnAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftActionBtnName}}</ion-button>\n }\n <div class=\"euim-slider__pagination\">\n @for (slide of slidesArray; track slide; let i = $index) {\n <span (click)=\"goToSlide(i)\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider__span\"></span>\n }\n </div>\n @if (!isLastItemReached && !isNextBtn || isNextBtn && isRightBtnVisible) {\n <ion-button (click)=\"onAction($event)\" class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.actionBtnName}}</ion-button>\n }\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n</div>\n", styles: [".euim-slider__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider__slides{display:flex;transition:all .5s ease;width:100%}.euim-slider__slide{width:100%}.euim-slider__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider__pagination{display:flex}.euim-slider__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}\n"] }]
@@ -158,17 +141,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
158
141
  type: Output
159
142
  }], actionBtnNames: [{
160
143
  type: Input
161
- }], isLastItemReached: [], isLeftBtnVisible: [{
162
- type: Input
144
+ }], isLeftBtnVisible: [{
145
+ type: Input,
146
+ args: [{ transform: booleanAttribute }]
163
147
  }], isPreviousBtn: [{
164
- type: Input
148
+ type: Input,
149
+ args: [{ transform: booleanAttribute }]
165
150
  }], isNextBtn: [{
166
- type: Input
167
- }], isRightBtnVisible: [], className: [{
151
+ type: Input,
152
+ args: [{ transform: booleanAttribute }]
153
+ }], className: [{
168
154
  type: HostBinding,
169
155
  args: ['class']
170
156
  }], onResize: [{
171
157
  type: HostListener,
172
158
  args: ['window:resize', ['$event']]
173
159
  }] } });
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-slider.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-slider/euim-slider.component.ts","../../../../../src/lib/components/euim-slider/euim-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    HostListener,\n} from '@angular/core';\nimport { GestureController } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { coerceBoolean } from '@eui/base';\n\n@Component({\n    selector: 'euim-slider',\n    templateUrl: './euim-slider.component.html',\n    styleUrls: ['./styles/_index.scss'],\n})\n\n/**\n*  @deprecated It was removed in v16. Use {@link euim-slider-info-screen} instead. \n*/\nexport class EuimSliderComponent implements OnInit, AfterViewInit {\n    @ViewChild('slides', { static: true }) slides: ElementRef;\n\n    @Output() actionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() lastStepActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() leftBtnActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n\n    @Input() actionBtnNames: ActionBtnNames = {\n        actionBtnName: 'Skip',\n        lastStepActionBtnName: 'Done',\n        leftActionBtnName: 'Previous',\n    };\n\n    @coerceBoolean\n    isLastItemReached: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isLeftBtnVisible: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isPreviousBtn: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isNextBtn: BooleanInput = false;\n\n    @coerceBoolean\n    isRightBtnVisible: BooleanInput = true;\n\n    @HostBinding('class') className = 'euim-slider';\n\n    slidesArray = [];\n    currentSlide = 0;\n    startX = 0;\n\n    constructor(private renderer: Renderer2,\n                private gestureCtrl: GestureController,\n                private sliderElement: ElementRef,\n                private cdr: ChangeDetectorRef) {\n\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: Event): void {\n        this.setSliderStyles();\n    }\n\n    ngAfterViewInit(): void {\n        this.setSliderStyles();\n    }\n\n    ngOnInit(): void {\n        const gesture = this.gestureCtrl.create({\n            el: this.sliderElement.nativeElement,\n            gestureName: 'on-gesture-end',\n            onEnd: (event) => {\n                this.handleTouchEnd(event);\n                this.isPreviousButtonVisible();\n                this.isNextButtonVisible();\n            },\n        });\n\n        gesture.enable();\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    setSliderStyles(): void {\n        const windowHeight = window.innerHeight;\n        const paginationHeight = 60;\n        const slideHeight = windowHeight - paginationHeight;\n\n        this.slidesArray = this.slides.nativeElement.children;\n        this.renderer.setStyle(this.slides.nativeElement, 'width', `${this.slidesArray.length * 100}%`);\n\n        for (const slide of this.slidesArray) {\n            this.renderer.setStyle(slide, 'width', `${100 / this.slidesArray.length}%`);\n            this.renderer.setStyle(slide, 'maxHeight', `${slideHeight}px`);\n            this.renderer.setStyle(slide, 'overflow', 'auto');\n        }\n\n        // to calculate the case when there is only one slide\n        if (!this.isLastItemReached && this.slidesArray.length < 2) {\n            this.isLastItemReached = true;\n        }\n    }\n\n    isPreviousButtonVisible(): void {\n        this.isLeftBtnVisible = this.currentSlide > 0 && this.isPreviousBtn;\n    }\n\n    isNextButtonVisible(): void {\n        this.isRightBtnVisible = this.currentSlide !== this.slidesArray.length - 1 && this.isNextBtn;\n    }\n\n    handleTouchEnd(e): void {\n        const difference = -e.deltaX;\n\n        if (difference > 0 && this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.isLastItemReached = false;\n        } else if (difference < 0 && this.currentSlide > 0) {\n            this.currentSlide--;\n            this.isLastItemReached = false;\n        }\n\n        this.isLastItemReached = this.currentSlide === this.slidesArray.length - 1;\n\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        this.cdr.detectChanges();\n\n    }\n\n    goToSlide(index): void {\n        this.currentSlide = index;\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToPreviousSlide(): void {\n        if (this.currentSlide > 0) {\n            this.currentSlide--;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToNextSlide(): void {\n        if (this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    onAction(event: MouseEvent): void {\n        if (this.isNextBtn) {\n            this.goToNextSlide();\n            return;\n        }\n\n        this.actionClicked.emit(event);\n    }\n\n    onLastStepAction(event: MouseEvent): void {\n        this.lastStepActionClicked.emit(event);\n    }\n\n    onLeftBtnAction(event: MouseEvent): void {\n        if (this.isPreviousBtn) {\n            this.goToPreviousSlide();\n            return;\n        }\n\n        this.leftBtnActionClicked.emit(event);\n    }\n}\n\nexport interface ActionBtnNames {\n    actionBtnName: string;\n    lastStepActionBtnName: string;\n    leftActionBtnName: string;\n}\n","<div #sliderElement class=\"euim-slider__slider-container\">\n  <div #slides class=\"euim-slider__slides\">\n    <ng-content></ng-content>\n  </div>\n  <div class=\"euim-slider__pagination-container\">\n    @if (isLeftBtnVisible) {\n      <ion-button (click)=\"onLeftBtnAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--left\"\n      fill=\"clear\">{{actionBtnNames.leftActionBtnName}}</ion-button>\n    }\n    <div class=\"euim-slider__pagination\">\n      @for (slide of slidesArray; track slide; let i = $index) {\n        <span (click)=\"goToSlide(i)\"\n          [ngClass]=\"{ 'active': currentSlide === i }\"\n        class=\"euim-slider__span\"></span>\n      }\n    </div>\n    @if (!isLastItemReached && !isNextBtn || isNextBtn && isRightBtnVisible) {\n      <ion-button (click)=\"onAction($event)\" class=\"euim-slider__action-button euim-slider__action-button--right\"\n      fill=\"clear\">{{actionBtnNames.actionBtnName}}</ion-button>\n    }\n    @if (isLastItemReached) {\n      <ion-button (click)=\"onLastStepAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--right\"\n      fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n    }\n  </div>\n</div>\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-slider.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-slider/euim-slider.component.ts","../../../../../src/lib/components/euim-slider/euim-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    HostListener, booleanAttribute,\n} from '@angular/core';\nimport { GestureController } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'euim-slider',\n    templateUrl: './euim-slider.component.html',\n    styleUrls: ['./styles/_index.scss'],\n})\n\n/**\n*  @deprecated It was removed in v16. Use {@link euim-slider-info-screen} instead.\n*/\nexport class EuimSliderComponent implements OnInit, AfterViewInit {\n    @ViewChild('slides', { static: true }) slides: ElementRef;\n\n    @Output() actionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() lastStepActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() leftBtnActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n\n    @Input() actionBtnNames: ActionBtnNames = {\n        actionBtnName: 'Skip',\n        lastStepActionBtnName: 'Done',\n        leftActionBtnName: 'Previous',\n    };\n\n    isLastItemReached: BooleanInput = false;\n\n    @Input({ transform: booleanAttribute })\n    isLeftBtnVisible = false;\n\n    @Input({ transform: booleanAttribute })\n    isPreviousBtn = false;\n\n    @Input({ transform: booleanAttribute })\n    isNextBtn = false;\n\n    isRightBtnVisible: BooleanInput = true;\n\n    @HostBinding('class') className = 'euim-slider';\n\n    slidesArray = [];\n    currentSlide = 0;\n    startX = 0;\n\n    constructor(private renderer: Renderer2,\n                private gestureCtrl: GestureController,\n                private sliderElement: ElementRef,\n                private cdr: ChangeDetectorRef) {\n\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: Event): void {\n        this.setSliderStyles();\n    }\n\n    ngAfterViewInit(): void {\n        this.setSliderStyles();\n    }\n\n    ngOnInit(): void {\n        const gesture = this.gestureCtrl.create({\n            el: this.sliderElement.nativeElement,\n            gestureName: 'on-gesture-end',\n            onEnd: (event) => {\n                this.handleTouchEnd(event);\n                this.isPreviousButtonVisible();\n                this.isNextButtonVisible();\n            },\n        });\n\n        gesture.enable();\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    setSliderStyles(): void {\n        const windowHeight = window.innerHeight;\n        const paginationHeight = 60;\n        const slideHeight = windowHeight - paginationHeight;\n\n        this.slidesArray = this.slides.nativeElement.children;\n        this.renderer.setStyle(this.slides.nativeElement, 'width', `${this.slidesArray.length * 100}%`);\n\n        for (const slide of this.slidesArray) {\n            this.renderer.setStyle(slide, 'width', `${100 / this.slidesArray.length}%`);\n            this.renderer.setStyle(slide, 'maxHeight', `${slideHeight}px`);\n            this.renderer.setStyle(slide, 'overflow', 'auto');\n        }\n\n        // to calculate the case when there is only one slide\n        if (!this.isLastItemReached && this.slidesArray.length < 2) {\n            this.isLastItemReached = true;\n        }\n    }\n\n    isPreviousButtonVisible(): void {\n        this.isLeftBtnVisible = this.currentSlide > 0 && this.isPreviousBtn;\n    }\n\n    isNextButtonVisible(): void {\n        this.isRightBtnVisible = this.currentSlide !== this.slidesArray.length - 1 && this.isNextBtn;\n    }\n\n    handleTouchEnd(e): void {\n        const difference = -e.deltaX;\n\n        if (difference > 0 && this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.isLastItemReached = false;\n        } else if (difference < 0 && this.currentSlide > 0) {\n            this.currentSlide--;\n            this.isLastItemReached = false;\n        }\n\n        this.isLastItemReached = this.currentSlide === this.slidesArray.length - 1;\n\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        this.cdr.detectChanges();\n\n    }\n\n    goToSlide(index): void {\n        this.currentSlide = index;\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToPreviousSlide(): void {\n        if (this.currentSlide > 0) {\n            this.currentSlide--;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToNextSlide(): void {\n        if (this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    onAction(event: MouseEvent): void {\n        if (this.isNextBtn) {\n            this.goToNextSlide();\n            return;\n        }\n\n        this.actionClicked.emit(event);\n    }\n\n    onLastStepAction(event: MouseEvent): void {\n        this.lastStepActionClicked.emit(event);\n    }\n\n    onLeftBtnAction(event: MouseEvent): void {\n        if (this.isPreviousBtn) {\n            this.goToPreviousSlide();\n            return;\n        }\n\n        this.leftBtnActionClicked.emit(event);\n    }\n}\n\nexport interface ActionBtnNames {\n    actionBtnName: string;\n    lastStepActionBtnName: string;\n    leftActionBtnName: string;\n}\n","<div #sliderElement class=\"euim-slider__slider-container\">\n  <div #slides class=\"euim-slider__slides\">\n    <ng-content></ng-content>\n  </div>\n  <div class=\"euim-slider__pagination-container\">\n    @if (isLeftBtnVisible) {\n      <ion-button (click)=\"onLeftBtnAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--left\"\n      fill=\"clear\">{{actionBtnNames.leftActionBtnName}}</ion-button>\n    }\n    <div class=\"euim-slider__pagination\">\n      @for (slide of slidesArray; track slide; let i = $index) {\n        <span (click)=\"goToSlide(i)\"\n          [ngClass]=\"{ 'active': currentSlide === i }\"\n        class=\"euim-slider__span\"></span>\n      }\n    </div>\n    @if (!isLastItemReached && !isNextBtn || isNextBtn && isRightBtnVisible) {\n      <ion-button (click)=\"onAction($event)\" class=\"euim-slider__action-button euim-slider__action-button--right\"\n      fill=\"clear\">{{actionBtnNames.actionBtnName}}</ion-button>\n    }\n    @if (isLastItemReached) {\n      <ion-button (click)=\"onLastStepAction($event)\"class=\"euim-slider__action-button euim-slider__action-button--right\"\n      fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n    }\n  </div>\n</div>\n"]}
@@ -1,6 +1,4 @@
1
- import { __decorate } from "tslib";
2
- import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, HostListener, ViewEncapsulation, } from '@angular/core';
3
- import { coerceBoolean } from '@eui/base';
1
+ import { booleanAttribute, Component, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
4
2
  import * as i0 from "@angular/core";
5
3
  import * as i1 from "@ionic/angular";
6
4
  import * as i2 from "@angular/common";
@@ -128,29 +126,8 @@ export class EuimSliderInfoScreenComponent {
128
126
  this.leftActionClicked.emit(event);
129
127
  }
130
128
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSliderInfoScreenComponent, deps: [{ token: i0.Renderer2 }, { token: i1.GestureController }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
131
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSliderInfoScreenComponent, selector: "euim-slider-info-screen", inputs: { isCarousel: "isCarousel", showLeftBtn: "showLeftBtn", showRightBtn: "showRightBtn", isPreviousBtn: "isPreviousBtn", isNextBtn: "isNextBtn", actionBtnNames: "actionBtnNames" }, outputs: { rightActionClicked: "rightActionClicked", lastStepActionClicked: "lastStepActionClicked", leftActionClicked: "leftActionClicked" }, host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "slides", first: true, predicate: ["slides"], descendants: true, static: true }], ngImport: i0, template: "<div #sliderElement class=\"euim-slider-info-screen__slider-container\">\n <div #slides class=\"euim-slider-info-screen__slides\">\n <ng-content></ng-content>\n </div>\n @if (showLeftBtn || showRightBtn || isCarousel || isLastItemReached){\n <div class=\"euim-slider-info-screen__pagination-container\">\n @if (showLeftBtn && !showLeftBtnAsPrevious && !isPreviousBtn) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (showLeftBtnAsPrevious) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (isCarousel){\n <div class=\"euim-slider-info-screen__pagination\">\n <span (click)=\"goToSlide(i)\" *ngFor=\"let slide of slidesArray; let i = index\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider-info-screen__span\"></span>\n </div>\n }\n @if (!isLastItemReached && !isNextBtn || isNextBtn && showRightBtn) {\n <ion-button (click)=\"onRightBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.rightBtnName}}</ion-button>\n }\n\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n }\n\n</div>\n", styles: [".euim-slider-info-screen__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider-info-screen__slides{display:flex;transition:all .5s ease;height:100%;width:100%}.euim-slider-info-screen__slide{width:100%;height:100%}.euim-slider-info-screen__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider-info-screen__pagination{display:flex}.euim-slider-info-screen__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider-info-screen__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider-info-screen__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider-info-screen__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider-info-screen__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}.euim-slider-info-screen__title{font:normal normal 400 1.75rem/2rem var(--eui-base-font-family);font-weight:700;color:var(--eui-base-color-grey-100);margin-top:var(--eui-base-spacing-l);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l)}.euim-slider-info-screen__sub-title{color:var(--eui-base-color-grey-75);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__content{color:var(--eui-base-color-grey-100);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__title+.euim-slider-info-screen__sub-title{margin-top:var(--eui-base-spacing-2xs)}.euim-slider-info-screen__sub-title+.euim-slider-info-screen__content,title+.euim-slider-info-screen__content{margin-top:var(--eui-base-spacing-m)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }], encapsulation: i0.ViewEncapsulation.None }); }
129
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: EuimSliderInfoScreenComponent, selector: "euim-slider-info-screen", inputs: { isCarousel: ["isCarousel", "isCarousel", booleanAttribute], showLeftBtn: ["showLeftBtn", "showLeftBtn", booleanAttribute], showRightBtn: ["showRightBtn", "showRightBtn", booleanAttribute], isPreviousBtn: ["isPreviousBtn", "isPreviousBtn", booleanAttribute], isNextBtn: ["isNextBtn", "isNextBtn", booleanAttribute], actionBtnNames: "actionBtnNames" }, outputs: { rightActionClicked: "rightActionClicked", lastStepActionClicked: "lastStepActionClicked", leftActionClicked: "leftActionClicked" }, host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "slides", first: true, predicate: ["slides"], descendants: true, static: true }], ngImport: i0, template: "<div #sliderElement class=\"euim-slider-info-screen__slider-container\">\n <div #slides class=\"euim-slider-info-screen__slides\">\n <ng-content></ng-content>\n </div>\n @if (showLeftBtn || showRightBtn || isCarousel || isLastItemReached){\n <div class=\"euim-slider-info-screen__pagination-container\">\n @if (showLeftBtn && !showLeftBtnAsPrevious && !isPreviousBtn) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (showLeftBtnAsPrevious) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (isCarousel){\n <div class=\"euim-slider-info-screen__pagination\">\n <span (click)=\"goToSlide(i)\" *ngFor=\"let slide of slidesArray; let i = index\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider-info-screen__span\"></span>\n </div>\n }\n @if (!isLastItemReached && !isNextBtn || isNextBtn && showRightBtn) {\n <ion-button (click)=\"onRightBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.rightBtnName}}</ion-button>\n }\n\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n }\n\n</div>\n", styles: [".euim-slider-info-screen__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider-info-screen__slides{display:flex;transition:all .5s ease;height:100%;width:100%}.euim-slider-info-screen__slide{width:100%;height:100%}.euim-slider-info-screen__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider-info-screen__pagination{display:flex}.euim-slider-info-screen__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider-info-screen__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider-info-screen__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider-info-screen__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider-info-screen__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}.euim-slider-info-screen__title{font:normal normal 400 1.75rem/2rem var(--eui-base-font-family);font-weight:700;color:var(--eui-base-color-grey-100);margin-top:var(--eui-base-spacing-l);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l)}.euim-slider-info-screen__sub-title{color:var(--eui-base-color-grey-75);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__content{color:var(--eui-base-color-grey-100);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__title+.euim-slider-info-screen__sub-title{margin-top:var(--eui-base-spacing-2xs)}.euim-slider-info-screen__sub-title+.euim-slider-info-screen__content,title+.euim-slider-info-screen__content{margin-top:var(--eui-base-spacing-m)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }], encapsulation: i0.ViewEncapsulation.None }); }
132
130
  }
133
- __decorate([
134
- coerceBoolean
135
- ], EuimSliderInfoScreenComponent.prototype, "isLastItemReached", void 0);
136
- __decorate([
137
- coerceBoolean
138
- ], EuimSliderInfoScreenComponent.prototype, "isCarousel", void 0);
139
- __decorate([
140
- coerceBoolean
141
- ], EuimSliderInfoScreenComponent.prototype, "showLeftBtn", void 0);
142
- __decorate([
143
- coerceBoolean
144
- ], EuimSliderInfoScreenComponent.prototype, "showRightBtn", void 0);
145
- __decorate([
146
- coerceBoolean
147
- ], EuimSliderInfoScreenComponent.prototype, "isPreviousBtn", void 0);
148
- __decorate([
149
- coerceBoolean
150
- ], EuimSliderInfoScreenComponent.prototype, "isNextBtn", void 0);
151
- __decorate([
152
- coerceBoolean
153
- ], EuimSliderInfoScreenComponent.prototype, "showLeftBtnAsPrevious", void 0);
154
131
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: EuimSliderInfoScreenComponent, decorators: [{
155
132
  type: Component,
156
133
  args: [{ selector: 'euim-slider-info-screen', encapsulation: ViewEncapsulation.None, template: "<div #sliderElement class=\"euim-slider-info-screen__slider-container\">\n <div #slides class=\"euim-slider-info-screen__slides\">\n <ng-content></ng-content>\n </div>\n @if (showLeftBtn || showRightBtn || isCarousel || isLastItemReached){\n <div class=\"euim-slider-info-screen__pagination-container\">\n @if (showLeftBtn && !showLeftBtnAsPrevious && !isPreviousBtn) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (showLeftBtnAsPrevious) {\n <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n }\n @if (isCarousel){\n <div class=\"euim-slider-info-screen__pagination\">\n <span (click)=\"goToSlide(i)\" *ngFor=\"let slide of slidesArray; let i = index\"\n [ngClass]=\"{ 'active': currentSlide === i }\"\n class=\"euim-slider-info-screen__span\"></span>\n </div>\n }\n @if (!isLastItemReached && !isNextBtn || isNextBtn && showRightBtn) {\n <ion-button (click)=\"onRightBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.rightBtnName}}</ion-button>\n }\n\n @if (isLastItemReached) {\n <ion-button (click)=\"onLastStepAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n }\n </div>\n }\n\n</div>\n", styles: [".euim-slider-info-screen__slider-container{overflow:hidden;position:relative;height:100vh}.euim-slider-info-screen__slides{display:flex;transition:all .5s ease;height:100%;width:100%}.euim-slider-info-screen__slide{width:100%;height:100%}.euim-slider-info-screen__pagination-container{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:60px}.euim-slider-info-screen__pagination{display:flex}.euim-slider-info-screen__span{width:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);height:calc(var(--eui-base-spacing-xs) + var(--eui-base-spacing-2xs) / 2);border-radius:50%;cursor:pointer;border:1px solid var(--eui-base-color-primary-100)}.euim-slider-info-screen__span:not(:last-child){margin-right:var(--eui-base-spacing-xs)}.euim-slider-info-screen__span.active{background-color:var(--eui-base-color-primary-100)}.euim-slider-info-screen__action-button{position:absolute;color:var(--eui-base-color-primary-100);font-weight:700;top:50%;transform:translateY(-50%)}.euim-slider-info-screen__action-button::part(native){padding:0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--right{right:0;margin:0 var(--eui-base-spacing-xs) 0 var(--eui-base-spacing-m)}.euim-slider-info-screen__action-button--left{margin:0 var(--eui-base-spacing-m) 0 var(--eui-base-spacing-xs);left:0}.euim-slider-info-screen__title{font:normal normal 400 1.75rem/2rem var(--eui-base-font-family);font-weight:700;color:var(--eui-base-color-grey-100);margin-top:var(--eui-base-spacing-l);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l)}.euim-slider-info-screen__sub-title{color:var(--eui-base-color-grey-75);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__content{color:var(--eui-base-color-grey-100);padding-left:var(--eui-base-spacing-l);padding-right:var(--eui-base-spacing-l);font:normal normal 400 1.125rem/1.5rem var(--eui-base-font-family)}.euim-slider-info-screen__title+.euim-slider-info-screen__sub-title{margin-top:var(--eui-base-spacing-2xs)}.euim-slider-info-screen__sub-title+.euim-slider-info-screen__content,title+.euim-slider-info-screen__content{margin-top:var(--eui-base-spacing-m)}\n"] }]
@@ -163,23 +140,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
163
140
  type: Output
164
141
  }], leftActionClicked: [{
165
142
  type: Output
166
- }], isLastItemReached: [], isCarousel: [{
167
- type: Input
143
+ }], isCarousel: [{
144
+ type: Input,
145
+ args: [{ transform: booleanAttribute }]
168
146
  }], showLeftBtn: [{
169
- type: Input
147
+ type: Input,
148
+ args: [{ transform: booleanAttribute }]
170
149
  }], showRightBtn: [{
171
- type: Input
150
+ type: Input,
151
+ args: [{ transform: booleanAttribute }]
172
152
  }], isPreviousBtn: [{
173
- type: Input
153
+ type: Input,
154
+ args: [{ transform: booleanAttribute }]
174
155
  }], isNextBtn: [{
175
- type: Input
156
+ type: Input,
157
+ args: [{ transform: booleanAttribute }]
176
158
  }], actionBtnNames: [{
177
159
  type: Input
178
- }], showLeftBtnAsPrevious: [], className: [{
160
+ }], className: [{
179
161
  type: HostBinding,
180
162
  args: ['class']
181
163
  }], onResize: [{
182
164
  type: HostListener,
183
165
  args: ['window:resize', ['$event']]
184
166
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-slider-info-screen.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.ts","../../../../../src/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    HostListener,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { GestureController } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { coerceBoolean } from '@eui/base';\n\n@Component({\n    selector: 'euim-slider-info-screen',\n    templateUrl: './euim-slider-info-screen.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimSliderInfoScreenComponent implements OnInit, AfterViewInit {\n    @ViewChild('slides', { static: true }) slides: ElementRef;\n\n    @Output() rightActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() lastStepActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() leftActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n\n    @coerceBoolean\n    isLastItemReached: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isCarousel: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    showLeftBtn: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    showRightBtn: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isPreviousBtn: BooleanInput = false;\n\n    @Input()\n    @coerceBoolean\n    isNextBtn: BooleanInput = false;\n\n    @Input() actionBtnNames: ActionBtnsNames = {\n        rightBtnName: 'Skip',\n        lastStepActionBtnName: 'Done',\n        leftBtnName: 'Previous',\n    };\n\n    @coerceBoolean\n    showLeftBtnAsPrevious: BooleanInput = false;\n\n    @HostBinding('class') className = 'euim-slider-info-screen';\n\n    slidesArray = [];\n    currentSlide = 0;\n    startX = 0;\n\n    constructor(private renderer: Renderer2,\n                private gestureCtrl: GestureController,\n                private sliderElement: ElementRef,\n                private cdr: ChangeDetectorRef) {\n\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: Event): void {\n        this.setSliderStyles();\n    }\n\n    ngAfterViewInit(): void {\n        this.setSliderStyles();\n    }\n\n    ngOnInit(): void {\n        const gesture = this.gestureCtrl.create({\n            el: this.sliderElement.nativeElement,\n            gestureName: 'on-gesture-end',\n            onEnd: (event) => {\n                this.handleTouchEnd(event);\n                this.isPreviousButtonVisible();\n                this.isNextButtonVisible();\n            },\n        });\n\n        gesture.enable();\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    setSliderStyles(): void {\n        const windowHeight = window.innerHeight;\n        const paginationHeight = 60;\n        const slideHeight = windowHeight - paginationHeight;\n\n        this.slidesArray = this.slides.nativeElement.children;\n        this.renderer.setStyle(this.slides.nativeElement, 'width', `${this.slidesArray.length * 100}%`);\n\n        for (const slide of this.slidesArray) {\n            this.renderer.setStyle(slide, 'width', `${100 / this.slidesArray.length}%`);\n            this.renderer.setStyle(slide, 'maxHeight', `${slideHeight}px`);\n            this.renderer.setStyle(slide, 'overflow', 'auto');\n        }\n\n        // to calculate the case when there is only one slide\n        if (!this.isLastItemReached && this.slidesArray.length < 2) {\n            this.isLastItemReached = true;\n        }\n    }\n\n    handleTouchEnd(e): void {\n        const difference = -e.deltaX;\n\n        if (difference > 0 && this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n        } else if (difference < 0 && this.currentSlide > 0) {\n            this.currentSlide--;\n        }\n\n        this.isLastItemReached = this.currentSlide === this.slidesArray.length - 1;\n\n        const translatePercentage = -this.currentSlide * 100 / this.slidesArray.length;\n        this.renderer.setStyle(this.slides.nativeElement, 'transform', `translateX(${translatePercentage}%)`);\n        this.cdr.detectChanges();\n    }\n\n    goToSlide(index): void {\n        this.currentSlide = index;\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToPreviousSlide(): void {\n        if (this.currentSlide > 0) {\n            this.currentSlide--;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToNextSlide(): void {\n        if (this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    isPreviousButtonVisible(): void {\n        this.showLeftBtnAsPrevious = this.currentSlide > 0 && this.isPreviousBtn;\n    }\n\n    isNextButtonVisible(): void {\n        this.showRightBtn = this.currentSlide !== this.slidesArray.length - 1 && this.isNextBtn;\n    }\n\n    onRightBtnAction(event: MouseEvent): void {\n        if (this.isNextBtn) {\n            this.goToNextSlide();\n            return;\n        }\n\n        this.rightActionClicked.emit(event);\n    }\n\n    onLastStepAction(event: MouseEvent): void {\n        this.lastStepActionClicked.emit(event);\n    }\n\n    onLeftBtnAction(event: MouseEvent): void {\n        if (this.isPreviousBtn) {\n            this.goToPreviousSlide();\n            return;\n        }\n\n        this.leftActionClicked.emit(event);\n    }\n}\n\nexport interface ActionBtnsNames {\n    rightBtnName: string;\n    lastStepActionBtnName: string;\n    leftBtnName: string;\n}\n","<div #sliderElement class=\"euim-slider-info-screen__slider-container\">\n    <div #slides class=\"euim-slider-info-screen__slides\">\n        <ng-content></ng-content>\n    </div>\n    @if (showLeftBtn || showRightBtn || isCarousel || isLastItemReached){\n        <div class=\"euim-slider-info-screen__pagination-container\">\n            @if (showLeftBtn && !showLeftBtnAsPrevious && !isPreviousBtn) {\n                <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n                            fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n            }\n            @if (showLeftBtnAsPrevious) {\n                <ion-button (click)=\"onLeftBtnAction($event)\"  class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n                            fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n            }\n            @if (isCarousel){\n                <div class=\"euim-slider-info-screen__pagination\">\n                <span (click)=\"goToSlide(i)\" *ngFor=\"let slide of slidesArray; let i = index\"\n                      [ngClass]=\"{ 'active': currentSlide === i }\"\n                      class=\"euim-slider-info-screen__span\"></span>\n                </div>\n            }\n            @if (!isLastItemReached && !isNextBtn || isNextBtn && showRightBtn) {\n                <ion-button (click)=\"onRightBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n                            fill=\"clear\">{{actionBtnNames.rightBtnName}}</ion-button>\n            }\n\n            @if (isLastItemReached) {\n                <ion-button (click)=\"onLastStepAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n                            fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n            }\n        </div>\n    }\n\n</div>\n"]}
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-slider-info-screen.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.ts","../../../../../src/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    booleanAttribute,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { GestureController } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'euim-slider-info-screen',\n    templateUrl: './euim-slider-info-screen.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimSliderInfoScreenComponent implements OnInit, AfterViewInit {\n    @ViewChild('slides', { static: true }) slides: ElementRef;\n\n    @Output() rightActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() lastStepActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n    @Output() leftActionClicked: EventEmitter<MouseEvent> =\n        new EventEmitter<MouseEvent>();\n\n    isLastItemReached: BooleanInput = false;\n\n    @Input({ transform: booleanAttribute })\n    isCarousel = false;\n\n    @Input({ transform: booleanAttribute })\n    showLeftBtn = false;\n\n    @Input({ transform: booleanAttribute })\n    showRightBtn = false;\n\n    @Input({ transform: booleanAttribute })\n    isPreviousBtn = false;\n\n    @Input({ transform: booleanAttribute })\n    isNextBtn = false;\n\n    @Input() actionBtnNames: ActionBtnsNames = {\n        rightBtnName: 'Skip',\n        lastStepActionBtnName: 'Done',\n        leftBtnName: 'Previous',\n    };\n\n    showLeftBtnAsPrevious: BooleanInput = false;\n\n    @HostBinding('class') className = 'euim-slider-info-screen';\n\n    slidesArray = [];\n    currentSlide = 0;\n    startX = 0;\n\n    constructor(private renderer: Renderer2,\n                private gestureCtrl: GestureController,\n                private sliderElement: ElementRef,\n                private cdr: ChangeDetectorRef) {\n\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: Event): void {\n        this.setSliderStyles();\n    }\n\n    ngAfterViewInit(): void {\n        this.setSliderStyles();\n    }\n\n    ngOnInit(): void {\n        const gesture = this.gestureCtrl.create({\n            el: this.sliderElement.nativeElement,\n            gestureName: 'on-gesture-end',\n            onEnd: (event) => {\n                this.handleTouchEnd(event);\n                this.isPreviousButtonVisible();\n                this.isNextButtonVisible();\n            },\n        });\n\n        gesture.enable();\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    setSliderStyles(): void {\n        const windowHeight = window.innerHeight;\n        const paginationHeight = 60;\n        const slideHeight = windowHeight - paginationHeight;\n\n        this.slidesArray = this.slides.nativeElement.children;\n        this.renderer.setStyle(this.slides.nativeElement, 'width', `${this.slidesArray.length * 100}%`);\n\n        for (const slide of this.slidesArray) {\n            this.renderer.setStyle(slide, 'width', `${100 / this.slidesArray.length}%`);\n            this.renderer.setStyle(slide, 'maxHeight', `${slideHeight}px`);\n            this.renderer.setStyle(slide, 'overflow', 'auto');\n        }\n\n        // to calculate the case when there is only one slide\n        if (!this.isLastItemReached && this.slidesArray.length < 2) {\n            this.isLastItemReached = true;\n        }\n    }\n\n    handleTouchEnd(e): void {\n        const difference = -e.deltaX;\n\n        if (difference > 0 && this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n        } else if (difference < 0 && this.currentSlide > 0) {\n            this.currentSlide--;\n        }\n\n        this.isLastItemReached = this.currentSlide === this.slidesArray.length - 1;\n\n        const translatePercentage = -this.currentSlide * 100 / this.slidesArray.length;\n        this.renderer.setStyle(this.slides.nativeElement, 'transform', `translateX(${translatePercentage}%)`);\n        this.cdr.detectChanges();\n    }\n\n    goToSlide(index): void {\n        this.currentSlide = index;\n        this.renderer.setStyle(this.slides.nativeElement,\n            'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToPreviousSlide(): void {\n        if (this.currentSlide > 0) {\n            this.currentSlide--;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    goToNextSlide(): void {\n        if (this.currentSlide < this.slidesArray.length - 1) {\n            this.currentSlide++;\n            this.renderer.setStyle(this.slides.nativeElement,\n                'transform', `translateX(-${this.currentSlide * 100 / this.slidesArray.length}%)`);\n        }\n\n        this.handleTouchEnd(event);\n\n        this.isPreviousButtonVisible();\n        this.isNextButtonVisible();\n    }\n\n    isPreviousButtonVisible(): void {\n        this.showLeftBtnAsPrevious = this.currentSlide > 0 && this.isPreviousBtn;\n    }\n\n    isNextButtonVisible(): void {\n        this.showRightBtn = this.currentSlide !== this.slidesArray.length - 1 && this.isNextBtn;\n    }\n\n    onRightBtnAction(event: MouseEvent): void {\n        if (this.isNextBtn) {\n            this.goToNextSlide();\n            return;\n        }\n\n        this.rightActionClicked.emit(event);\n    }\n\n    onLastStepAction(event: MouseEvent): void {\n        this.lastStepActionClicked.emit(event);\n    }\n\n    onLeftBtnAction(event: MouseEvent): void {\n        if (this.isPreviousBtn) {\n            this.goToPreviousSlide();\n            return;\n        }\n\n        this.leftActionClicked.emit(event);\n    }\n}\n\nexport interface ActionBtnsNames {\n    rightBtnName: string;\n    lastStepActionBtnName: string;\n    leftBtnName: string;\n}\n","<div #sliderElement class=\"euim-slider-info-screen__slider-container\">\n    <div #slides class=\"euim-slider-info-screen__slides\">\n        <ng-content></ng-content>\n    </div>\n    @if (showLeftBtn || showRightBtn || isCarousel || isLastItemReached){\n        <div class=\"euim-slider-info-screen__pagination-container\">\n            @if (showLeftBtn && !showLeftBtnAsPrevious && !isPreviousBtn) {\n                <ion-button (click)=\"onLeftBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n                            fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n            }\n            @if (showLeftBtnAsPrevious) {\n                <ion-button (click)=\"onLeftBtnAction($event)\"  class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--left\"\n                            fill=\"clear\">{{actionBtnNames.leftBtnName}}</ion-button>\n            }\n            @if (isCarousel){\n                <div class=\"euim-slider-info-screen__pagination\">\n                <span (click)=\"goToSlide(i)\" *ngFor=\"let slide of slidesArray; let i = index\"\n                      [ngClass]=\"{ 'active': currentSlide === i }\"\n                      class=\"euim-slider-info-screen__span\"></span>\n                </div>\n            }\n            @if (!isLastItemReached && !isNextBtn || isNextBtn && showRightBtn) {\n                <ion-button (click)=\"onRightBtnAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n                            fill=\"clear\">{{actionBtnNames.rightBtnName}}</ion-button>\n            }\n\n            @if (isLastItemReached) {\n                <ion-button (click)=\"onLastStepAction($event)\" class=\"euim-slider-info-screen__action-button euim-slider-info-screen__action-button--right\"\n                            fill=\"clear\">{{actionBtnNames.lastStepActionBtnName}}</ion-button>\n            }\n        </div>\n    }\n\n</div>\n"]}