@eui/ecl 18.0.0-next.60 → 18.0.0-next.61

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.
@@ -1,6 +1,7 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
- import { Directive, HostBinding, Input, Output, EventEmitter, forwardRef, HostListener, } from '@angular/core';
2
+ import { Directive, HostBinding, Input, Output, EventEmitter, forwardRef, HostListener, Inject, PLATFORM_ID, } from '@angular/core';
3
3
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { isPlatformBrowser } from '@angular/common';
4
5
  import Pikaday from 'pikaday';
5
6
  import { EclIconComponent } from '../ecl-icon/ecl-icon.component';
6
7
  import { EclBaseEvent } from '../../model/ecl-base.event';
@@ -34,13 +35,14 @@ export class EclDatePickerDirective extends ECLBaseDirective {
34
35
  get cssClasses() {
35
36
  return [super.getCssClasses('ecl-datepicker__field')].join(' ').trim();
36
37
  }
37
- constructor(el, viewContainerRef, translateService, eclLanguageService, renderer) {
38
+ constructor(el, viewContainerRef, translateService, eclLanguageService, renderer, platformId) {
38
39
  super();
39
40
  this.el = el;
40
41
  this.viewContainerRef = viewContainerRef;
41
42
  this.translateService = translateService;
42
43
  this.eclLanguageService = eclLanguageService;
43
44
  this.renderer = renderer;
45
+ this.platformId = platformId;
44
46
  this.yearRange = 40;
45
47
  this.format = 'DD-MM-YYYY';
46
48
  this.type = 'text';
@@ -50,11 +52,15 @@ export class EclDatePickerDirective extends ECLBaseDirective {
50
52
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
51
53
  this.onChange = noop;
52
54
  this.onTouched = noop;
53
- this.handlei18nEvents();
55
+ if (isPlatformBrowser(this.platformId)) {
56
+ this.handlei18nEvents();
57
+ }
54
58
  }
55
59
  ngOnInit() {
56
- this.initPikaday();
57
- this.handleMarkup();
60
+ if (isPlatformBrowser(this.platformId)) {
61
+ this.initPikaday();
62
+ this.handleMarkup();
63
+ }
58
64
  }
59
65
  ngOnDestroy() {
60
66
  this.destroy$.next(true);
@@ -170,7 +176,7 @@ export class EclDatePickerDirective extends ECLBaseDirective {
170
176
  eclIconComponent.instance.class = 'ecl-datepicker__icon';
171
177
  return eclIconComponent.location.nativeElement;
172
178
  }
173
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.0", ngImport: i0, type: EclDatePickerDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i1.TranslateService }, { token: i2.EclLanguageService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
179
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.0", ngImport: i0, type: EclDatePickerDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i1.TranslateService }, { token: i2.EclLanguageService }, { token: i0.Renderer2 }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
174
180
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.0", type: EclDatePickerDirective, selector: "input[eclDatePicker]", inputs: { yearRange: "yearRange", format: "format" }, outputs: { datePicked: "datePicked" }, host: { listeners: { "click": "onClick()", "blur": "onBlur()" }, properties: { "attr.type": "this.type", "class": "this.cssClasses", "attr.disabled": "this.isDisabled" } }, providers: [ECL_DATE_PICKER_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0 }); }
175
181
  }
176
182
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0", ngImport: i0, type: EclDatePickerDirective, decorators: [{
@@ -179,7 +185,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0", ng
179
185
  selector: 'input[eclDatePicker]',
180
186
  providers: [ECL_DATE_PICKER_VALUE_ACCESSOR],
181
187
  }]
182
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.TranslateService }, { type: i2.EclLanguageService }, { type: i0.Renderer2 }], propDecorators: { yearRange: [{
188
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.TranslateService }, { type: i2.EclLanguageService }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
189
+ type: Inject,
190
+ args: [PLATFORM_ID]
191
+ }] }], propDecorators: { yearRange: [{
183
192
  type: Input
184
193
  }], format: [{
185
194
  type: Input
@@ -201,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0", ng
201
210
  type: HostListener,
202
211
  args: ['blur']
203
212
  }] } });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-date-picker.directive.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-date-picker/ecl-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Directive,\n    HostBinding,\n    Input,\n    ElementRef,\n    OnInit,\n    ViewContainerRef,\n    Output,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    OnDestroy,\n    Provider,\n    Renderer2,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport Pikaday from 'pikaday';\nimport { EclIconComponent } from '../ecl-icon/ecl-icon.component';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { LangChangeEvent, TranslateService } from '@ngx-translate/core';\nimport { Subject, takeUntil } from 'rxjs';\nimport { EclLanguageService } from '../../services';\n\nconst pikadayDefaultI18n = {\n    previousMonth: 'Previous Month',\n    nextMonth: 'Next Month',\n    months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n    weekdays: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n    weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n};\n\nexport class EclDatePickerDatePickedEvent extends EclBaseEvent {\n    constructor(public date: Date) {\n        super();\n    }\n}\n\nexport const ECL_DATE_PICKER_VALUE_ACCESSOR: Provider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => EclDatePickerDirective),\n    multi: true,\n};\n\nconst noop = (): void => {\n    /** empty*/\n};\n\n@Directive({\n    selector: 'input[eclDatePicker]',\n    providers: [ECL_DATE_PICKER_VALUE_ACCESSOR],\n})\nexport class EclDatePickerDirective extends ECLBaseDirective implements OnInit, ControlValueAccessor, OnDestroy {\n    @Input() yearRange = 40;\n    @Input() format = 'DD-MM-YYYY';\n    @HostBinding('attr.type') type = 'text';\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-datepicker__field')].join(' ').trim();\n    }\n\n    @Output() datePicked = new EventEmitter<EclDatePickerDatePickedEvent>();\n\n    @HostBinding('attr.disabled')\n    isDisabled = null;\n\n    private picker: Pikaday;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private onChange: (_: any) => void = noop;\n    private onTouched: () => void = noop;\n\n    private hostEl: HTMLInputElement;\n    private hostParentEl: HTMLElement;\n    private hostWrapperEl: HTMLElement;\n    private eclIconComponentEl: HTMLElement;\n\n    constructor(\n        private el: ElementRef,\n        private viewContainerRef: ViewContainerRef,\n        protected translateService: TranslateService,\n        private eclLanguageService: EclLanguageService,\n        private renderer: Renderer2,\n    ) {\n        super();\n        this.handlei18nEvents();\n    }\n\n    ngOnInit(): void {\n        this.initPikaday();\n        this.handleMarkup();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        this.onTouched();\n    }\n\n    @HostListener('blur')\n    onBlur(): void {\n        const textFieldValue: string = this.hostEl.value;\n\n        if (textFieldValue) {\n            this.onChange(this.picker.getDate());\n        } else {\n            this.onChange(null);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    writeValue(value: any): void {\n        this.picker.setDate(value);\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.isDisabled = isDisabled || null;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    private initPikaday(): void {\n        const i18nKey = 'ecl.date-picker.PIKADAY';\n        let i18nTranslation = this.translateService.instant(i18nKey);\n        const isRTL = this.eclLanguageService.getCurrentLanguage().isRtl;\n        const position = isRTL ? 'bottom right' : 'bottom left';\n\n        if (!i18nTranslation || i18nTranslation === i18nKey) {\n            i18nTranslation = pikadayDefaultI18n;\n        }\n\n        this.picker = new Pikaday({\n            field: this.el.nativeElement,\n            format: this.format,\n            theme: 'ecl-datepicker-theme',\n            yearRange: this.yearRange,\n            reposition: false,\n            i18n: i18nTranslation,\n            isRTL,\n            position,\n            showDaysInNextAndPreviousMonths: true,\n            enableSelectionDaysInNextAndPreviousMonths: true,\n            onSelect: this.onSelectDate.bind(this),\n            onOpen(): void {\n                // Extend picker size on mobile\n                const vw = Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0);\n                const elRect = this.el.getBoundingClientRect();\n\n                if (isRTL) {\n                    const pickerMargin = vw - elRect.right;\n                    if (vw < 768) {\n                        this.el.style.left = `${pickerMargin}px`;\n                    } else {\n                        this.el.style.left = 'auto';\n                    }\n                } else {\n                    const pickerMargin = elRect.left;\n                    if (vw < 768) {\n                            this.el.style.right = `${pickerMargin}px`;\n                    } else {\n                        this.el.style.right = 'auto';\n                    }\n                }\n            },\n        });\n    }\n\n    private handlei18nEvents(): void {\n        this.translateService.onLangChange.pipe(takeUntil(this.destroy$)).subscribe((langChangeEvent: LangChangeEvent) => {\n            this.initPikaday();\n        });\n    }\n\n    private onSelectDate(date: Date): void {\n        this.datePicked.next(new EclDatePickerDatePickedEvent(date));\n        this.onChange(date);\n    }\n\n    private handleMarkup(): void {\n        this.hostEl = this.getHostElement();\n        this.hostParentEl = this.getHostParentElement(this.hostEl);\n        this.hostWrapperEl = this.createHostWrapperContainer();\n        this.eclIconComponentEl = this.createIconComponent();\n\n        if (this.hostParentEl != null) {\n            this.hostParentEl.replaceChild(this.hostWrapperEl, this.hostEl);\n            this.renderer.appendChild(this.hostWrapperEl, this.hostEl);\n            this.renderer.appendChild(this.hostWrapperEl, this.eclIconComponentEl);\n        }\n    }\n\n    private getHostElement(): HTMLInputElement {\n        return this.el.nativeElement;\n    }\n\n    private getHostParentElement(hostEl: HTMLInputElement): HTMLElement {\n        return this.renderer.parentNode(hostEl);\n    }\n\n    private createHostWrapperContainer(): HTMLElement {\n        const wrapperContainer = this.renderer.createElement('div');\n        this.renderer.addClass(wrapperContainer, 'ecl-datepicker');\n\n        return wrapperContainer;\n    }\n\n    private createIconComponent(): HTMLElement {\n        const eclIconComponent = this.viewContainerRef.createComponent(EclIconComponent);\n        eclIconComponent.instance.size = 'xs';\n        eclIconComponent.instance.icon = 'calendar';\n        eclIconComponent.instance.class = 'ecl-datepicker__icon';\n\n        return eclIconComponent.location.nativeElement;\n    }\n}\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-date-picker.directive.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-date-picker/ecl-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Directive,\n    HostBinding,\n    Input,\n    ElementRef,\n    OnInit,\n    ViewContainerRef,\n    Output,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    OnDestroy,\n    Provider,\n    Renderer2,\n    Inject,\n    PLATFORM_ID,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { isPlatformBrowser } from '@angular/common';\nimport Pikaday from 'pikaday';\nimport { EclIconComponent } from '../ecl-icon/ecl-icon.component';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { LangChangeEvent, TranslateService } from '@ngx-translate/core';\nimport { Subject, takeUntil } from 'rxjs';\nimport { EclLanguageService } from '../../services';\n\nconst pikadayDefaultI18n = {\n    previousMonth: 'Previous Month',\n    nextMonth: 'Next Month',\n    months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n    weekdays: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n    weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n};\n\nexport class EclDatePickerDatePickedEvent extends EclBaseEvent {\n    constructor(public date: Date) {\n        super();\n    }\n}\n\nexport const ECL_DATE_PICKER_VALUE_ACCESSOR: Provider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => EclDatePickerDirective),\n    multi: true,\n};\n\nconst noop = (): void => {\n    /** empty*/\n};\n\n@Directive({\n    selector: 'input[eclDatePicker]',\n    providers: [ECL_DATE_PICKER_VALUE_ACCESSOR],\n})\nexport class EclDatePickerDirective extends ECLBaseDirective implements OnInit, ControlValueAccessor, OnDestroy {\n    @Input() yearRange = 40;\n    @Input() format = 'DD-MM-YYYY';\n    @HostBinding('attr.type') type = 'text';\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-datepicker__field')].join(' ').trim();\n    }\n\n    @Output() datePicked = new EventEmitter<EclDatePickerDatePickedEvent>();\n\n    @HostBinding('attr.disabled')\n    isDisabled = null;\n\n    private picker: Pikaday;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private onChange: (_: any) => void = noop;\n    private onTouched: () => void = noop;\n\n    private hostEl: HTMLInputElement;\n    private hostParentEl: HTMLElement;\n    private hostWrapperEl: HTMLElement;\n    private eclIconComponentEl: HTMLElement;\n\n    constructor(\n        private el: ElementRef,\n        private viewContainerRef: ViewContainerRef,\n        protected translateService: TranslateService,\n        private eclLanguageService: EclLanguageService,\n        private renderer: Renderer2,\n        @Inject(PLATFORM_ID) private platformId: object,\n    ) {\n        super();\n        if (isPlatformBrowser(this.platformId)) {\n            this.handlei18nEvents();\n        }\n    }\n\n    ngOnInit(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.initPikaday();\n            this.handleMarkup();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        this.onTouched();\n    }\n\n    @HostListener('blur')\n    onBlur(): void {\n        const textFieldValue: string = this.hostEl.value;\n\n        if (textFieldValue) {\n            this.onChange(this.picker.getDate());\n        } else {\n            this.onChange(null);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    writeValue(value: any): void {\n        this.picker.setDate(value);\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.isDisabled = isDisabled || null;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    private initPikaday(): void {\n        const i18nKey = 'ecl.date-picker.PIKADAY';\n        let i18nTranslation = this.translateService.instant(i18nKey);\n        const isRTL = this.eclLanguageService.getCurrentLanguage().isRtl;\n        const position = isRTL ? 'bottom right' : 'bottom left';\n\n        if (!i18nTranslation || i18nTranslation === i18nKey) {\n            i18nTranslation = pikadayDefaultI18n;\n        }\n\n        this.picker = new Pikaday({\n            field: this.el.nativeElement,\n            format: this.format,\n            theme: 'ecl-datepicker-theme',\n            yearRange: this.yearRange,\n            reposition: false,\n            i18n: i18nTranslation,\n            isRTL,\n            position,\n            showDaysInNextAndPreviousMonths: true,\n            enableSelectionDaysInNextAndPreviousMonths: true,\n            onSelect: this.onSelectDate.bind(this),\n            onOpen(): void {\n                // Extend picker size on mobile\n                const vw = Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0);\n                const elRect = this.el.getBoundingClientRect();\n\n                if (isRTL) {\n                    const pickerMargin = vw - elRect.right;\n                    if (vw < 768) {\n                        this.el.style.left = `${pickerMargin}px`;\n                    } else {\n                        this.el.style.left = 'auto';\n                    }\n                } else {\n                    const pickerMargin = elRect.left;\n                    if (vw < 768) {\n                            this.el.style.right = `${pickerMargin}px`;\n                    } else {\n                        this.el.style.right = 'auto';\n                    }\n                }\n            },\n        });\n    }\n\n    private handlei18nEvents(): void {\n        this.translateService.onLangChange.pipe(takeUntil(this.destroy$)).subscribe((langChangeEvent: LangChangeEvent) => {\n            this.initPikaday();\n        });\n    }\n\n    private onSelectDate(date: Date): void {\n        this.datePicked.next(new EclDatePickerDatePickedEvent(date));\n        this.onChange(date);\n    }\n\n    private handleMarkup(): void {\n        this.hostEl = this.getHostElement();\n        this.hostParentEl = this.getHostParentElement(this.hostEl);\n        this.hostWrapperEl = this.createHostWrapperContainer();\n        this.eclIconComponentEl = this.createIconComponent();\n\n        if (this.hostParentEl != null) {\n            this.hostParentEl.replaceChild(this.hostWrapperEl, this.hostEl);\n            this.renderer.appendChild(this.hostWrapperEl, this.hostEl);\n            this.renderer.appendChild(this.hostWrapperEl, this.eclIconComponentEl);\n        }\n    }\n\n    private getHostElement(): HTMLInputElement {\n        return this.el.nativeElement;\n    }\n\n    private getHostParentElement(hostEl: HTMLInputElement): HTMLElement {\n        return this.renderer.parentNode(hostEl);\n    }\n\n    private createHostWrapperContainer(): HTMLElement {\n        const wrapperContainer = this.renderer.createElement('div');\n        this.renderer.addClass(wrapperContainer, 'ecl-datepicker');\n\n        return wrapperContainer;\n    }\n\n    private createIconComponent(): HTMLElement {\n        const eclIconComponent = this.viewContainerRef.createComponent(EclIconComponent);\n        eclIconComponent.instance.size = 'xs';\n        eclIconComponent.instance.icon = 'calendar';\n        eclIconComponent.instance.class = 'ecl-datepicker__icon';\n\n        return eclIconComponent.location.nativeElement;\n    }\n}\n"]}
@@ -5981,8 +5981,9 @@ i079.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0",
5981
5981
  }] });
5982
5982
 
5983
5983
  // lib/components/ecl-date-picker/ecl-date-picker.directive.mjs
5984
- import { Directive as Directive22, HostBinding as HostBinding54, Input as Input30, Output as Output14, EventEmitter as EventEmitter14, forwardRef as forwardRef30, HostListener as HostListener7 } from "@angular/core";
5984
+ import { Directive as Directive22, HostBinding as HostBinding54, Input as Input30, Output as Output14, EventEmitter as EventEmitter14, forwardRef as forwardRef30, HostListener as HostListener7, Inject as Inject5, PLATFORM_ID } from "@angular/core";
5985
5985
  import { NG_VALUE_ACCESSOR as NG_VALUE_ACCESSOR3 } from "@angular/forms";
5986
+ import { isPlatformBrowser } from "@angular/common";
5986
5987
  import Pikaday from "pikaday";
5987
5988
  import { Subject as Subject12, takeUntil as takeUntil12 } from "rxjs";
5988
5989
  import * as i080 from "@angular/core";
@@ -6011,13 +6012,14 @@ var EclDatePickerDirective = class _EclDatePickerDirective extends ECLBaseDirect
6011
6012
  get cssClasses() {
6012
6013
  return [super.getCssClasses("ecl-datepicker__field")].join(" ").trim();
6013
6014
  }
6014
- constructor(el, viewContainerRef, translateService, eclLanguageService, renderer) {
6015
+ constructor(el, viewContainerRef, translateService, eclLanguageService, renderer, platformId) {
6015
6016
  super();
6016
6017
  this.el = el;
6017
6018
  this.viewContainerRef = viewContainerRef;
6018
6019
  this.translateService = translateService;
6019
6020
  this.eclLanguageService = eclLanguageService;
6020
6021
  this.renderer = renderer;
6022
+ this.platformId = platformId;
6021
6023
  this.yearRange = 40;
6022
6024
  this.format = "DD-MM-YYYY";
6023
6025
  this.type = "text";
@@ -6026,11 +6028,15 @@ var EclDatePickerDirective = class _EclDatePickerDirective extends ECLBaseDirect
6026
6028
  this.destroy$ = new Subject12();
6027
6029
  this.onChange = noop3;
6028
6030
  this.onTouched = noop3;
6029
- this.handlei18nEvents();
6031
+ if (isPlatformBrowser(this.platformId)) {
6032
+ this.handlei18nEvents();
6033
+ }
6030
6034
  }
6031
6035
  ngOnInit() {
6032
- this.initPikaday();
6033
- this.handleMarkup();
6036
+ if (isPlatformBrowser(this.platformId)) {
6037
+ this.initPikaday();
6038
+ this.handleMarkup();
6039
+ }
6034
6040
  }
6035
6041
  ngOnDestroy() {
6036
6042
  this.destroy$.next(true);
@@ -6142,7 +6148,7 @@ var EclDatePickerDirective = class _EclDatePickerDirective extends ECLBaseDirect
6142
6148
  return eclIconComponent.location.nativeElement;
6143
6149
  }
6144
6150
  static {
6145
- this.ɵfac = i080.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.0", ngImport: i080, type: _EclDatePickerDirective, deps: [{ token: i080.ElementRef }, { token: i080.ViewContainerRef }, { token: i114.TranslateService }, { token: EclLanguageService }, { token: i080.Renderer2 }], target: i080.ɵɵFactoryTarget.Directive });
6151
+ this.ɵfac = i080.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.0", ngImport: i080, type: _EclDatePickerDirective, deps: [{ token: i080.ElementRef }, { token: i080.ViewContainerRef }, { token: i114.TranslateService }, { token: EclLanguageService }, { token: i080.Renderer2 }, { token: PLATFORM_ID }], target: i080.ɵɵFactoryTarget.Directive });
6146
6152
  }
6147
6153
  static {
6148
6154
  this.ɵdir = i080.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.0", type: _EclDatePickerDirective, selector: "input[eclDatePicker]", inputs: { yearRange: "yearRange", format: "format" }, outputs: { datePicked: "datePicked" }, host: { listeners: { "click": "onClick()", "blur": "onBlur()" }, properties: { "attr.type": "this.type", "class": "this.cssClasses", "attr.disabled": "this.isDisabled" } }, providers: [ECL_DATE_PICKER_VALUE_ACCESSOR], usesInheritance: true, ngImport: i080 });
@@ -6154,7 +6160,10 @@ i080.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0",
6154
6160
  selector: "input[eclDatePicker]",
6155
6161
  providers: [ECL_DATE_PICKER_VALUE_ACCESSOR]
6156
6162
  }]
6157
- }], ctorParameters: () => [{ type: i080.ElementRef }, { type: i080.ViewContainerRef }, { type: i114.TranslateService }, { type: EclLanguageService }, { type: i080.Renderer2 }], propDecorators: { yearRange: [{
6163
+ }], ctorParameters: () => [{ type: i080.ElementRef }, { type: i080.ViewContainerRef }, { type: i114.TranslateService }, { type: EclLanguageService }, { type: i080.Renderer2 }, { type: void 0, decorators: [{
6164
+ type: Inject5,
6165
+ args: [PLATFORM_ID]
6166
+ }] }], propDecorators: { yearRange: [{
6158
6167
  type: Input30
6159
6168
  }], format: [{
6160
6169
  type: Input30
@@ -17419,7 +17428,7 @@ i0191.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0",
17419
17428
  }] } });
17420
17429
 
17421
17430
  // lib/components/ecl-radio/ecl-radio-input.directive.mjs
17422
- import { Directive as Directive56, HostBinding as HostBinding135, Optional as Optional6, Self as Self4, Inject as Inject5, forwardRef as forwardRef52 } from "@angular/core";
17431
+ import { Directive as Directive56, HostBinding as HostBinding135, Optional as Optional6, Self as Self4, Inject as Inject6, forwardRef as forwardRef52 } from "@angular/core";
17423
17432
  import * as i0192 from "@angular/core";
17424
17433
  import * as i127 from "@angular/forms";
17425
17434
  var EclRadioInputDirective = class _EclRadioInputDirective extends ECLBaseDirective {
@@ -17453,7 +17462,7 @@ i0192.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.0",
17453
17462
  selector: "input[eclRadioInput]"
17454
17463
  }]
17455
17464
  }], ctorParameters: () => [{ type: EclRadioDirective, decorators: [{
17456
- type: Inject5,
17465
+ type: Inject6,
17457
17466
  args: [forwardRef52(() => EclRadioDirective)]
17458
17467
  }] }, { type: i127.NgControl, decorators: [{
17459
17468
  type: Optional6