@pepperi-addons/ngx-lib 0.4.2-beta.296 → 0.4.2-beta.298

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.
@@ -133,7 +133,7 @@ export class PepDateComponent {
133
133
  readonly: this.readonly,
134
134
  disabled: this.disabled,
135
135
  });
136
- this.form = this.customizationService.getDefaultFromGroup(pepField);
136
+ this.form = this.customizationService.getDefaultFromGroup(pepField, this.renderError);
137
137
  }
138
138
  ngOnInit() {
139
139
  if (this.form === null) {
@@ -331,4 +331,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
331
331
  type: ViewChild,
332
332
  args: ['input']
333
333
  }] } });
334
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/date/date.component.ts","../../../../projects/ngx-lib/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    OnInit,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectionStrategy,\n    ViewChild,\n    Renderer2,\n    OnDestroy,\n    OnChanges,\n    Optional,\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { MomentDateAdapter } from '@angular/material-moment-adapter';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport {\n    DatetimeAdapter,\n    MatDatetimepickerInputEvent,\n    MAT_DATETIME_FORMATS,\n} from '@mat-datetimepicker/core';\nimport { MomentDatetimeAdapter } from '@mat-datetimepicker/moment';\nimport {\n    PepLayoutService,\n    PepUtilitiesService,\n    PepLayoutType,\n    PepCustomizationService,\n    PepHorizontalAlignment,\n    DEFAULT_HORIZONTAL_ALIGNMENT,\n    PepDateFieldType,\n    PepDateField,\n} from '@pepperi-addons/ngx-lib';\nimport { Moment, utc } from 'moment/moment';\nimport { MomentUtcDateAdapter, MomentUtcDateTimeAdapter, MY_DATE_FORMATS } from './date.model';\n\n// Set the calture for the adapter.\nexport function getCalture(layoutService: PepLayoutService) {\n    const culture = layoutService.getCurrentLanguage();\n    return culture;\n}\n\n@Component({\n    selector: 'pep-date',\n    templateUrl: './date.component.html',\n    styleUrls: ['./date.component.scss', './date.component.theme.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        // CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR,\n        // The locale would typically be provided on the root module of your application. We do it at\n        // the component level here, due to limitations of our example generation script.\n        // { provide: MAT_DATE_LOCALE, useValue: 'he' },\n        { provide: MAT_DATE_LOCALE, useFactory: getCalture, deps:[PepLayoutService] },\n\n        // `MomentDateAdapter` and `MAT_MOMENT_DATE_FORMATS` can be automatically provided by importing\n        // `MatMomentDateModule` in your applications root module. We provide it at the component level\n        // here, due to limitations of our example generation script.\n        //{ provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\n        //{ provide: MAT_DATE_FORMATS, useValue: MAT_MOMENT_DATE_FORMATS },\n        { provide: DateAdapter, useClass: MomentUtcDateAdapter },\n        { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMATS },\n        { provide: DatetimeAdapter, useClass: MomentUtcDateTimeAdapter },\n        //{ provide: MAT_DATETIME_FORMATS, useValue: MAT_NATIVE_DATETIME_FORMATS }\n        { provide: MAT_DATETIME_FORMATS, useValue: MY_DATE_FORMATS },\n    ],\n})\nexport class PepDateComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() key = '';\n\n    private _value = '';\n    @Input()\n    set value(value: string) {\n        this._value = value;\n        this.setDateModel();\n    }\n    get value() {\n        return this._value;\n    }\n\n    protected formattedValue = '';\n    // private _formattedValue = '';\n    // @Input()\n    // set formattedValue(value: string) {\n    //     // if (!value) {\n    //     //     value = '';\n    //     // }\n\n    //     // if (this._calculateFormattedValue) {\n    //     //     this._calculateFormattedValue = false;\n    //     // }\n\n    //     // this.setFormattedValue(value);\n    // }\n    // get formattedValue(): string {\n    //     return this._formattedValue;\n    // }\n\n    @Input() label = '';\n\n    private _type: PepDateFieldType = 'date';\n    @Input()\n    set type(type: PepDateFieldType) {\n        this._type = type;\n        this.isDateTime = type === 'datetime';\n    }\n    get type(): PepDateFieldType {\n        return this._type;\n    }\n\n    @Input() mandatory = false;\n    @Input() disabled = false;\n    @Input() readonly = false;\n    @Input() textColor = '';\n    @Input() xAlignment: PepHorizontalAlignment = DEFAULT_HORIZONTAL_ALIGNMENT;\n    @Input() rowSpan = 1;\n    @Input() chooseTime = true; // In case of datetime picker, it will show the time picker as well.\n\n    private _visible = true;\n    @Input()\n    set visible(visible: boolean) {\n        this._visible = visible;\n        if (visible) {\n            this.renderer.removeClass(\n                this.element.nativeElement,\n                'hidden-element'\n            );\n        } else {\n            this.renderer.addClass(\n                this.element.nativeElement,\n                'hidden-element'\n            );\n        }\n    }\n    get visible(): boolean {\n        return this._visible;\n    }\n\n    // Minimum in thicks\n    @Input()\n    set minValue(value: number) {\n        if (value > 0) {\n            this.minDate = new Date(value * 1000 * 60 * 60 * 24);\n        } else {\n            this.minDate = null;\n        }\n    }\n\n    // Maximum in thicks\n    @Input()\n    set maxValue(value: number) {\n        if (value > 0) {\n            this.maxDate = new Date(value * 1000 * 60 * 60 * 24);\n        } else {\n            this.maxDate = null;\n        }\n    }\n\n    // Minimum in date\n    @Input()\n    set minDateValue(date: string) {\n        this.minDate = date ? new Date(date) : null;\n    }\n\n    // Maximum in date\n    @Input()\n    set maxDateValue(date: string) {\n        this.maxDate = date ? new Date(date) : null;\n    }\n\n    controlType = 'date';\n\n    @Input() form: FormGroup = null;\n    @Input() isActive = false;\n    @Input() showTitle = true;\n    @Input() renderTitle = true;\n    @Input() renderError = true;\n    @Input() renderSymbol = true;\n    @Input() layoutType: PepLayoutType = 'form';\n\n    @Output()\n    valueChange: EventEmitter<string> = new EventEmitter<string>();\n\n    @Output()\n    validationChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    @ViewChild('datetimePicker') datetimePicker: any;\n\n    @ViewChild('input') input: ElementRef;\n\n    standAlone = false;\n    isInEditMode = false;\n    dateModel: Moment;\n    minDate: Date;\n    maxDate: Date;\n    showDatepicker = false;\n    isDateTime = false;\n\n    constructor(\n        private adapter: DateAdapter<any>,\n        private element: ElementRef,\n        private layoutService: PepLayoutService,\n        private utilitiesService: PepUtilitiesService,\n        private customizationService: PepCustomizationService,\n        private renderer: Renderer2\n    ) { }\n\n    private setDefaultForm(): void {\n        const pepField = new PepDateField({\n            key: this.key,\n            value: this.value,\n            mandatory: this.mandatory,\n            readonly: this.readonly,\n            disabled: this.disabled,\n        });\n        this.form = this.customizationService.getDefaultFromGroup(pepField);\n    }\n\n    ngOnInit(): void {\n        if (this.form === null) {\n            this.standAlone = true;\n            this.setDefaultForm();\n\n            this.renderer.addClass(\n                this.element.nativeElement,\n                PepCustomizationService.STAND_ALONE_FIELD_CLASS_NAME\n            );\n\n            if (!this.renderTitle) {\n                this.renderer.addClass(\n                    this.element.nativeElement,\n                    PepCustomizationService.STAND_ALONE_FIELD_NO_SPACING_CLASS_NAME\n                );\n            }\n        }\n\n        // This is not working for the dateModel so I use set calture in the useFactory: getCalture function.\n        // const culture = this.layoutService.getCurrentLanguage();\n        // this.adapter.setLocale(culture);\n\n        this.setDateModel();\n        this.updateFormFieldValue();\n    }\n\n    ngOnChanges(changes: any): void {\n        if (this.standAlone) {\n            this.setDefaultForm();\n        }\n    }\n\n    ngOnDestroy(): void {\n        //\n    }\n\n    private setFormattedValueFromModel(): void {\n        if (this.dateModel === null || !this.dateModel.isValid()) {\n            this.formattedValue = '';\n        } else {\n            const formatString = this.isDateTime\n                ? MY_DATE_FORMATS.display.datetimeInput\n                : MY_DATE_FORMATS.display.dateInput;\n            this.formattedValue = this.adapter.format(this.dateModel, formatString);\n        }\n    }\n\n    private setDateModel(): void {\n        if (\n            !this.value ||\n            this.value === '' ||\n            this.value.indexOf('1900-1-1') >= 0 ||\n            this.value.indexOf('1900-01-01') >= 0 ||\n            this.value.indexOf('1970-1-1') >= 0 ||\n            this.value.indexOf('1970-01-01') >= 0\n        ) {\n            this._value = '';\n            this.dateModel = null;\n        } else {\n            const parseDate = this.utilitiesService.parseDate(this.value, this.isDateTime);\n            this.dateModel = utc(parseDate);\n        }\n\n        this.setFormattedValueFromModel();\n    }\n\n    openDatetimePicker(datetimePicker): void {\n        datetimePicker.opened = false;\n        datetimePicker.open();\n    }\n\n    onBlur(event: any): void {\n        // Don't remove the timeout cause a bug DI-17819.\n        setTimeout(() => {\n            if (this.isInEditMode && !this.datetimePicker.opened) {\n                this.isInEditMode = false;\n            }\n        }, 0);\n    }\n\n    private updateFormFieldValue() {\n        this.customizationService.updateFormFieldValue(\n            this.form,\n            this.key,\n            // this.formattedValue\n            this.value\n        );\n\n        // Raise this only for stand alone fields, If false then the usage for this field is inside a form. \n        // Then the form will take care of raising the (onFormValidationChanged) event\n        if (this.standAlone) {\n            const inputValue = this.input?.nativeElement.value || '';\n            // If the value is empty or valid date, isValueValid is true.\n            const isValueValid = !inputValue || this.utilitiesService.parseDate(inputValue, this.isDateTime) !== null;\n            // this.form.valid will handle when the field is mandatory.\n            const isValid = (this.disabled || this.readonly) ? true : this.form.valid && isValueValid; \n            this.validationChange.emit(isValid);\n        }\n    }\n\n    onDateChange(event: MatDatetimepickerInputEvent<Moment>): void {\n        let value = '';\n        if (event.value != null) {\n            const date: Date = event.value.toDate();\n\n            value = this.utilitiesService.stringifyDate(date, this.isDateTime);\n        }\n\n        this._value = value;\n\n        // Update the formatted value.\n        this.setFormattedValueFromModel();\n        this.updateFormFieldValue();\n        \n        this.valueChange.emit(value);\n\n        setTimeout(() => {\n            if (this.isInEditMode) {\n                this.isInEditMode = false;\n            }\n        }, 0);\n    }\n\n    cardTemplateClicked(event): void {\n        this.isInEditMode = true;\n\n        setTimeout(() => {\n            this.input.nativeElement.focus();\n            this.openDatetimePicker(this.datetimePicker);\n        }, 0);\n    }\n}\n","<ng-container *ngIf=\"form\" [formGroup]=\"form\">\n    <ng-template #pepTemplate let-showIcon=\"showIcon\">\n        <mat-form-field appearance=\"outline\">\n            <input #input [id]=\"key\" title=\"{{ formattedValue }}\" matInput class=\"body-sm\" autocomplete=\"false\"\n                [ngStyle]=\"{ color: textColor, 'text-align': xAlignment == 'center' ? 'center' : xAlignment == 'right' ? 'right' : 'left'}\"\n                [(ngModel)]=\"dateModel\" [ngModelOptions]=\"{standalone: true}\" [matDatetimepicker]=\"datetimePicker\"\n                [min]=\"minDate\" [max]=\"maxDate\" [required]=\"mandatory\" [disabled]=\"disabled\"\n                (dateChange)=\"onDateChange($event)\" (click)=\"openDatetimePicker(datetimePicker)\"\n                (blur)=\"onBlur($event)\" />\n            <mat-error *ngIf=\"renderError\"><span class=\"body-xs\"\n                    [title]=\"mandatory && formattedValue?.length == 0 ? ('MESSAGES.ERROR_IS_REQUIRED' | translate: {field: label}) : ('MESSAGES.ERROR_IS_NOT_VALID' | translate: {field: label})\"\n                    [innerText]=\"mandatory && formattedValue?.length == 0 ? ('MESSAGES.ERROR_IS_REQUIRED' | translate: {field: label}) : ('MESSAGES.ERROR_IS_NOT_VALID' | translate: {field: label})\"></span>\n            </mat-error>\n            <pep-textbox-icon *ngIf=\"renderSymbol && showIcon && xAlignment == 'right'\" matPrefix [value]=\"value\"\n                [label]=\"label\" [type]=\"type\" [disabled]=\"disabled\" (iconClick)=\"openDatetimePicker(datetimePicker)\">\n            </pep-textbox-icon>\n            <pep-textbox-icon *ngIf=\"renderSymbol && showIcon && xAlignment == 'left'\" matSuffix [value]=\"value\"\n                [label]=\"label\" [type]=\"type\" [disabled]=\"disabled\" (iconClick)=\"openDatetimePicker(datetimePicker)\">\n            </pep-textbox-icon>\n            <mat-datetimepicker #datetimePicker [type]=\"chooseTime && isDateTime ? 'datetime' : 'date'\" [openOnFocus]=\"false\"\n                [touchUi]=\"true\" [timeInterval]=\"1\"></mat-datetimepicker>\n        </mat-form-field>\n    </ng-template>\n\n    <ng-container *ngIf=\"layoutType === 'form'\">\n        <pep-field-title *ngIf=\"renderTitle\" [label]=\"label\" [mandatory]=\"mandatory\" [disabled]=\"disabled\"\n            [xAlignment]=\"xAlignment\" [showTitle]=\"showTitle\">\n        </pep-field-title>\n        <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: true}\"></ng-container>\n    </ng-container>\n\n    <ng-container *ngIf=\"layoutType === 'card'\">\n        <ng-container *ngIf=\"isInEditMode; then editBlock; else readOnlyBlock\"></ng-container>\n        <ng-template #editBlock>\n            <div [ngClass]=\"{'one-row': rowSpan === 1}\">\n                <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: false}\"></ng-container>\n            </div>\n        </ng-template>\n        <ng-template #readOnlyBlock>\n            <div class=\"pep-card-input card-flex-container\"\n                [ngClass]=\"{'one-row': rowSpan === 1, 'pep-button weak': isActive && !disabled }\"\n                [ngStyle]=\"{ color: textColor }\" [class]=\"'text-align-' + xAlignment\"\n                (click)=\"!disabled ? cardTemplateClicked($event) : ''\">\n                <span *ngIf=\"showTitle && label != ''\" class=\"body-xs title\" title=\"{{ label }}\">{{ label\n                    }}&nbsp;</span>\n                <span [id]=\"key\" title=\"{{ formattedValue }}\" class=\"body-sm value\">{{ formattedValue }}</span>\n                <button *ngIf=\"isActive && !disabled\" class=\"pep-button weak card-edit-button\" mat-button>\n                    <mat-icon>\n                        <pep-icon name=\"system_edit\">\n                        </pep-icon>\n                    </mat-icon>\n                </button>\n            </div>\n        </ng-template>\n    </ng-container>\n\n    <ng-container *ngIf=\"layoutType === 'table'\">\n        <ng-container *ngIf=\"isActive && !disabled; then selectedBlock; else notSelectedBlock\"></ng-container>\n        <ng-template #selectedBlock>\n            <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: true}\"></ng-container>\n        </ng-template>\n        <ng-template #notSelectedBlock>\n            <ng-container *ngIf=\"formattedValue?.length > 0; then notEmptyBlock; else emptyBlock\"></ng-container>\n            <ng-template #notEmptyBlock>\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchDefault>\n                        <span [id]=\"key\" class=\"body-sm pep-report-input\" [ngStyle]=\"{ color: textColor }\"\n                            [ngClass]=\"{readonly: disabled}\" title=\"{{ formattedValue }}\">{{ formattedValue }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-template>\n            <ng-template #emptyBlock>\n                <span [id]=\"key\">&nbsp;</span>\n            </ng-template>\n        </ng-template>\n    </ng-container>\n</ng-container>"]}
334
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/date/date.component.ts","../../../../projects/ngx-lib/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    OnInit,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectionStrategy,\n    ViewChild,\n    Renderer2,\n    OnDestroy,\n    OnChanges,\n    Optional,\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { MomentDateAdapter } from '@angular/material-moment-adapter';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport {\n    DatetimeAdapter,\n    MatDatetimepickerInputEvent,\n    MAT_DATETIME_FORMATS,\n} from '@mat-datetimepicker/core';\nimport { MomentDatetimeAdapter } from '@mat-datetimepicker/moment';\nimport {\n    PepLayoutService,\n    PepUtilitiesService,\n    PepLayoutType,\n    PepCustomizationService,\n    PepHorizontalAlignment,\n    DEFAULT_HORIZONTAL_ALIGNMENT,\n    PepDateFieldType,\n    PepDateField,\n} from '@pepperi-addons/ngx-lib';\nimport { Moment, utc } from 'moment/moment';\nimport { MomentUtcDateAdapter, MomentUtcDateTimeAdapter, MY_DATE_FORMATS } from './date.model';\n\n// Set the calture for the adapter.\nexport function getCalture(layoutService: PepLayoutService) {\n    const culture = layoutService.getCurrentLanguage();\n    return culture;\n}\n\n@Component({\n    selector: 'pep-date',\n    templateUrl: './date.component.html',\n    styleUrls: ['./date.component.scss', './date.component.theme.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        // CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR,\n        // The locale would typically be provided on the root module of your application. We do it at\n        // the component level here, due to limitations of our example generation script.\n        // { provide: MAT_DATE_LOCALE, useValue: 'he' },\n        { provide: MAT_DATE_LOCALE, useFactory: getCalture, deps:[PepLayoutService] },\n\n        // `MomentDateAdapter` and `MAT_MOMENT_DATE_FORMATS` can be automatically provided by importing\n        // `MatMomentDateModule` in your applications root module. We provide it at the component level\n        // here, due to limitations of our example generation script.\n        //{ provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },\n        //{ provide: MAT_DATE_FORMATS, useValue: MAT_MOMENT_DATE_FORMATS },\n        { provide: DateAdapter, useClass: MomentUtcDateAdapter },\n        { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMATS },\n        { provide: DatetimeAdapter, useClass: MomentUtcDateTimeAdapter },\n        //{ provide: MAT_DATETIME_FORMATS, useValue: MAT_NATIVE_DATETIME_FORMATS }\n        { provide: MAT_DATETIME_FORMATS, useValue: MY_DATE_FORMATS },\n    ],\n})\nexport class PepDateComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() key = '';\n\n    private _value = '';\n    @Input()\n    set value(value: string) {\n        this._value = value;\n        this.setDateModel();\n    }\n    get value() {\n        return this._value;\n    }\n\n    protected formattedValue = '';\n    // private _formattedValue = '';\n    // @Input()\n    // set formattedValue(value: string) {\n    //     // if (!value) {\n    //     //     value = '';\n    //     // }\n\n    //     // if (this._calculateFormattedValue) {\n    //     //     this._calculateFormattedValue = false;\n    //     // }\n\n    //     // this.setFormattedValue(value);\n    // }\n    // get formattedValue(): string {\n    //     return this._formattedValue;\n    // }\n\n    @Input() label = '';\n\n    private _type: PepDateFieldType = 'date';\n    @Input()\n    set type(type: PepDateFieldType) {\n        this._type = type;\n        this.isDateTime = type === 'datetime';\n    }\n    get type(): PepDateFieldType {\n        return this._type;\n    }\n\n    @Input() mandatory = false;\n    @Input() disabled = false;\n    @Input() readonly = false;\n    @Input() textColor = '';\n    @Input() xAlignment: PepHorizontalAlignment = DEFAULT_HORIZONTAL_ALIGNMENT;\n    @Input() rowSpan = 1;\n    @Input() chooseTime = true; // In case of datetime picker, it will show the time picker as well.\n\n    private _visible = true;\n    @Input()\n    set visible(visible: boolean) {\n        this._visible = visible;\n        if (visible) {\n            this.renderer.removeClass(\n                this.element.nativeElement,\n                'hidden-element'\n            );\n        } else {\n            this.renderer.addClass(\n                this.element.nativeElement,\n                'hidden-element'\n            );\n        }\n    }\n    get visible(): boolean {\n        return this._visible;\n    }\n\n    // Minimum in thicks\n    @Input()\n    set minValue(value: number) {\n        if (value > 0) {\n            this.minDate = new Date(value * 1000 * 60 * 60 * 24);\n        } else {\n            this.minDate = null;\n        }\n    }\n\n    // Maximum in thicks\n    @Input()\n    set maxValue(value: number) {\n        if (value > 0) {\n            this.maxDate = new Date(value * 1000 * 60 * 60 * 24);\n        } else {\n            this.maxDate = null;\n        }\n    }\n\n    // Minimum in date\n    @Input()\n    set minDateValue(date: string) {\n        this.minDate = date ? new Date(date) : null;\n    }\n\n    // Maximum in date\n    @Input()\n    set maxDateValue(date: string) {\n        this.maxDate = date ? new Date(date) : null;\n    }\n\n    controlType = 'date';\n\n    @Input() form: FormGroup = null;\n    @Input() isActive = false;\n    @Input() showTitle = true;\n    @Input() renderTitle = true;\n    @Input() renderError = true;\n    @Input() renderSymbol = true;\n    @Input() layoutType: PepLayoutType = 'form';\n\n    @Output()\n    valueChange: EventEmitter<string> = new EventEmitter<string>();\n\n    @Output()\n    validationChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    @ViewChild('datetimePicker') datetimePicker: any;\n\n    @ViewChild('input') input: ElementRef;\n\n    standAlone = false;\n    isInEditMode = false;\n    dateModel: Moment;\n    minDate: Date;\n    maxDate: Date;\n    showDatepicker = false;\n    isDateTime = false;\n\n    constructor(\n        private adapter: DateAdapter<any>,\n        private element: ElementRef,\n        private layoutService: PepLayoutService,\n        private utilitiesService: PepUtilitiesService,\n        private customizationService: PepCustomizationService,\n        private renderer: Renderer2\n    ) { }\n\n    private setDefaultForm(): void {\n        const pepField = new PepDateField({\n            key: this.key,\n            value: this.value,\n            mandatory: this.mandatory,\n            readonly: this.readonly,\n            disabled: this.disabled,\n        });\n        this.form = this.customizationService.getDefaultFromGroup(\n            pepField, \n            this.renderError\n        );\n    }\n\n    ngOnInit(): void {\n        if (this.form === null) {\n            this.standAlone = true;\n            this.setDefaultForm();\n\n            this.renderer.addClass(\n                this.element.nativeElement,\n                PepCustomizationService.STAND_ALONE_FIELD_CLASS_NAME\n            );\n\n            if (!this.renderTitle) {\n                this.renderer.addClass(\n                    this.element.nativeElement,\n                    PepCustomizationService.STAND_ALONE_FIELD_NO_SPACING_CLASS_NAME\n                );\n            }\n        }\n\n        // This is not working for the dateModel so I use set calture in the useFactory: getCalture function.\n        // const culture = this.layoutService.getCurrentLanguage();\n        // this.adapter.setLocale(culture);\n\n        this.setDateModel();\n        this.updateFormFieldValue();\n    }\n\n    ngOnChanges(changes: any): void {\n        if (this.standAlone) {\n            this.setDefaultForm();\n        }\n    }\n\n    ngOnDestroy(): void {\n        //\n    }\n\n    private setFormattedValueFromModel(): void {\n        if (this.dateModel === null || !this.dateModel.isValid()) {\n            this.formattedValue = '';\n        } else {\n            const formatString = this.isDateTime\n                ? MY_DATE_FORMATS.display.datetimeInput\n                : MY_DATE_FORMATS.display.dateInput;\n            this.formattedValue = this.adapter.format(this.dateModel, formatString);\n        }\n    }\n\n    private setDateModel(): void {\n        if (\n            !this.value ||\n            this.value === '' ||\n            this.value.indexOf('1900-1-1') >= 0 ||\n            this.value.indexOf('1900-01-01') >= 0 ||\n            this.value.indexOf('1970-1-1') >= 0 ||\n            this.value.indexOf('1970-01-01') >= 0\n        ) {\n            this._value = '';\n            this.dateModel = null;\n        } else {\n            const parseDate = this.utilitiesService.parseDate(this.value, this.isDateTime);\n            this.dateModel = utc(parseDate);\n        }\n\n        this.setFormattedValueFromModel();\n    }\n\n    openDatetimePicker(datetimePicker): void {\n        datetimePicker.opened = false;\n        datetimePicker.open();\n    }\n\n    onBlur(event: any): void {\n        // Don't remove the timeout cause a bug DI-17819.\n        setTimeout(() => {\n            if (this.isInEditMode && !this.datetimePicker.opened) {\n                this.isInEditMode = false;\n            }\n        }, 0);\n    }\n\n    private updateFormFieldValue() {\n        this.customizationService.updateFormFieldValue(\n            this.form,\n            this.key,\n            // this.formattedValue\n            this.value\n        );\n\n        // Raise this only for stand alone fields, If false then the usage for this field is inside a form. \n        // Then the form will take care of raising the (onFormValidationChanged) event\n        if (this.standAlone) {\n            const inputValue = this.input?.nativeElement.value || '';\n            // If the value is empty or valid date, isValueValid is true.\n            const isValueValid = !inputValue || this.utilitiesService.parseDate(inputValue, this.isDateTime) !== null;\n            // this.form.valid will handle when the field is mandatory.\n            const isValid = (this.disabled || this.readonly) ? true : this.form.valid && isValueValid; \n            this.validationChange.emit(isValid);\n        }\n    }\n\n    onDateChange(event: MatDatetimepickerInputEvent<Moment>): void {\n        let value = '';\n        if (event.value != null) {\n            const date: Date = event.value.toDate();\n\n            value = this.utilitiesService.stringifyDate(date, this.isDateTime);\n        }\n\n        this._value = value;\n\n        // Update the formatted value.\n        this.setFormattedValueFromModel();\n        this.updateFormFieldValue();\n        \n        this.valueChange.emit(value);\n\n        setTimeout(() => {\n            if (this.isInEditMode) {\n                this.isInEditMode = false;\n            }\n        }, 0);\n    }\n\n    cardTemplateClicked(event): void {\n        this.isInEditMode = true;\n\n        setTimeout(() => {\n            this.input.nativeElement.focus();\n            this.openDatetimePicker(this.datetimePicker);\n        }, 0);\n    }\n}\n","<ng-container *ngIf=\"form\" [formGroup]=\"form\">\n    <ng-template #pepTemplate let-showIcon=\"showIcon\">\n        <mat-form-field appearance=\"outline\">\n            <input #input [id]=\"key\" title=\"{{ formattedValue }}\" matInput class=\"body-sm\" autocomplete=\"false\"\n                [ngStyle]=\"{ color: textColor, 'text-align': xAlignment == 'center' ? 'center' : xAlignment == 'right' ? 'right' : 'left'}\"\n                [(ngModel)]=\"dateModel\" [ngModelOptions]=\"{standalone: true}\" [matDatetimepicker]=\"datetimePicker\"\n                [min]=\"minDate\" [max]=\"maxDate\" [required]=\"mandatory\" [disabled]=\"disabled\"\n                (dateChange)=\"onDateChange($event)\" (click)=\"openDatetimePicker(datetimePicker)\"\n                (blur)=\"onBlur($event)\" />\n            <mat-error *ngIf=\"renderError\"><span class=\"body-xs\"\n                    [title]=\"mandatory && formattedValue?.length == 0 ? ('MESSAGES.ERROR_IS_REQUIRED' | translate: {field: label}) : ('MESSAGES.ERROR_IS_NOT_VALID' | translate: {field: label})\"\n                    [innerText]=\"mandatory && formattedValue?.length == 0 ? ('MESSAGES.ERROR_IS_REQUIRED' | translate: {field: label}) : ('MESSAGES.ERROR_IS_NOT_VALID' | translate: {field: label})\"></span>\n            </mat-error>\n            <pep-textbox-icon *ngIf=\"renderSymbol && showIcon && xAlignment == 'right'\" matPrefix [value]=\"value\"\n                [label]=\"label\" [type]=\"type\" [disabled]=\"disabled\" (iconClick)=\"openDatetimePicker(datetimePicker)\">\n            </pep-textbox-icon>\n            <pep-textbox-icon *ngIf=\"renderSymbol && showIcon && xAlignment == 'left'\" matSuffix [value]=\"value\"\n                [label]=\"label\" [type]=\"type\" [disabled]=\"disabled\" (iconClick)=\"openDatetimePicker(datetimePicker)\">\n            </pep-textbox-icon>\n            <mat-datetimepicker #datetimePicker [type]=\"chooseTime && isDateTime ? 'datetime' : 'date'\" [openOnFocus]=\"false\"\n                [touchUi]=\"true\" [timeInterval]=\"1\"></mat-datetimepicker>\n        </mat-form-field>\n    </ng-template>\n\n    <ng-container *ngIf=\"layoutType === 'form'\">\n        <pep-field-title *ngIf=\"renderTitle\" [label]=\"label\" [mandatory]=\"mandatory\" [disabled]=\"disabled\"\n            [xAlignment]=\"xAlignment\" [showTitle]=\"showTitle\">\n        </pep-field-title>\n        <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: true}\"></ng-container>\n    </ng-container>\n\n    <ng-container *ngIf=\"layoutType === 'card'\">\n        <ng-container *ngIf=\"isInEditMode; then editBlock; else readOnlyBlock\"></ng-container>\n        <ng-template #editBlock>\n            <div [ngClass]=\"{'one-row': rowSpan === 1}\">\n                <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: false}\"></ng-container>\n            </div>\n        </ng-template>\n        <ng-template #readOnlyBlock>\n            <div class=\"pep-card-input card-flex-container\"\n                [ngClass]=\"{'one-row': rowSpan === 1, 'pep-button weak': isActive && !disabled }\"\n                [ngStyle]=\"{ color: textColor }\" [class]=\"'text-align-' + xAlignment\"\n                (click)=\"!disabled ? cardTemplateClicked($event) : ''\">\n                <span *ngIf=\"showTitle && label != ''\" class=\"body-xs title\" title=\"{{ label }}\">{{ label\n                    }}&nbsp;</span>\n                <span [id]=\"key\" title=\"{{ formattedValue }}\" class=\"body-sm value\">{{ formattedValue }}</span>\n                <button *ngIf=\"isActive && !disabled\" class=\"pep-button weak card-edit-button\" mat-button>\n                    <mat-icon>\n                        <pep-icon name=\"system_edit\">\n                        </pep-icon>\n                    </mat-icon>\n                </button>\n            </div>\n        </ng-template>\n    </ng-container>\n\n    <ng-container *ngIf=\"layoutType === 'table'\">\n        <ng-container *ngIf=\"isActive && !disabled; then selectedBlock; else notSelectedBlock\"></ng-container>\n        <ng-template #selectedBlock>\n            <ng-container *ngTemplateOutlet=\"pepTemplate; context: {showIcon: true}\"></ng-container>\n        </ng-template>\n        <ng-template #notSelectedBlock>\n            <ng-container *ngIf=\"formattedValue?.length > 0; then notEmptyBlock; else emptyBlock\"></ng-container>\n            <ng-template #notEmptyBlock>\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchDefault>\n                        <span [id]=\"key\" class=\"body-sm pep-report-input\" [ngStyle]=\"{ color: textColor }\"\n                            [ngClass]=\"{readonly: disabled}\" title=\"{{ formattedValue }}\">{{ formattedValue }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-template>\n            <ng-template #emptyBlock>\n                <span [id]=\"key\">&nbsp;</span>\n            </ng-template>\n        </ng-template>\n    </ng-container>\n</ng-container>"]}