@testgorilla/tgo-ui 2.16.4 → 2.16.6
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.
|
@@ -225,6 +225,10 @@ export class DatepickerComponent {
|
|
|
225
225
|
this.range.controls.end.setValue(new Date(end));
|
|
226
226
|
}
|
|
227
227
|
}
|
|
228
|
+
if (!this.value) {
|
|
229
|
+
this.range.controls.start.setValue(null);
|
|
230
|
+
this.range.controls.end.setValue(null);
|
|
231
|
+
}
|
|
228
232
|
}
|
|
229
233
|
getRange(start, end) {
|
|
230
234
|
return `${start}-${end}`;
|
|
@@ -299,4 +303,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
299
303
|
}], changed: [{
|
|
300
304
|
type: Output
|
|
301
305
|
}] } });
|
|
302
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.ts","../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Self,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, FormGroup, NgControl } from '@angular/forms';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class DatepickerComponent implements OnChanges, ControlValueAccessor, DoCheck {\n  @HostBinding() class = 'ui-datepicker';\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() value?: string | Date;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is date range\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() isRange: boolean;\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() hintMessage: string;\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof DatepickerComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * Show reserved content below form field\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Set full width DatepickerComponent\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Set min date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() minDate: Date | undefined;\n\n  /**\n   * Set max date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() maxDate: Date | undefined;\n\n  /**\n   * Show and pick date without day\n   * @default false\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() monthPicker = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof DatepickerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Prevent user input\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() preventUserInput = false;\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  /**\n   * Event emitted when the value is change - when used outside of form\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Output() changed = new EventEmitter<Date | string>();\n\n  range = new FormGroup({\n    start: new FormControl<Date | null>(null),\n    end: new FormControl<Date | null>(null),\n  });\n\n  errorsLength: boolean;\n  protected translationContext = 'DATEPICKER.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private cdr: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  get hint(): string {\n    if (this.hintMessage === undefined) {\n      return this.isRange ? 'MM/DD/YYYY - MM/DD/YYYY' : this.monthPicker ? 'MM/YYYY' : 'MM/DD/YYYY';\n    }\n\n    return this.hintMessage;\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\n   * to display validation errors that might happen (e.g. required)\n   */\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.ngControl?.touched || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnInit() {\n    document.body.setAttribute('theme', this.applicationTheme);\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(): void {\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  onValueChange(value: Date | string) {\n    this.writeValue(value);\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    this.onChange(value);\n    this.changed.emit(value);\n  }\n\n  writeValue(value?: Date | string): void {\n    this.value = value;\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  dateRangeChange(start: string, end: string) {\n    if (start && end) {\n      this.onValueChange(this.getRange(start, end));\n    }\n  }\n\n  setMonthAndYear(normalizedMonthAndYear: any, datepicker: MatDatepicker<Date>) {\n    const ctrlValue = typeof this.value === 'string' ? new Date(this.value) : this.value || new Date();\n\n    ctrlValue.setMonth(normalizedMonthAndYear.getMonth());\n    ctrlValue.setFullYear(normalizedMonthAndYear.getFullYear());\n\n    datepicker.close();\n\n    this.onValueChange(new Date(ctrlValue));\n  }\n\n  private setRange() {\n    if (typeof this.value === 'string') {\n      const [start, end] = this.value?.split('-');\n      if (start) {\n        this.range.controls.start.setValue(new Date(start));\n      }\n      if (end) {\n        this.range.controls.end.setValue(new Date(end));\n      }\n    }\n  }\n\n  private getRange(start: string, end: string): string {\n    return `${start}-${end}`;\n  }\n\n  onInput(event: Event) {\n    const target = event.target as EventTarget & { value: string };\n    const [month, year] = target.value.split('/');\n    const date = new Date().getDate();\n    const fullDateString = `${month}/${date}/${year}`;\n    const fullDate = new Date(fullDateString);\n    this.onValueChange(fullDate);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    *ngIf=\"!monthPicker; else dateYearPicker\"\n    #uiDatepicker\n    appearance=\"outline\"\n    [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n    [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n  >\n    <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n    <ng-container *ngIf=\"!isRange\">\n      <input *ngIf=\"!isRange\" matInput\n             [matDatepicker]=\"picker\"\n             (blur)=\"onTouch()\"\n             (dateChange)=\"onValueChange($event.value)\"\n             [id]=\"id!\"\n             [placeholder]=\"placeholder!\"\n             [value]=\"value\"\n             [disabled]=\"disabled\"\n             [name]=\"fieldName!\"\n             [readonly]=\"preventUserInput\"\n             [min]=\"minDate\"\n             [max]=\"maxDate\"\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRange\">\n      <mat-date-range-input *ngIf=\"isRange\" [formGroup]=\"range\" [rangePicker]=\"rangePicker\" [min]=\"minDate\" [max]=\"maxDate\" >\n        <input matStartDate #dateRangeStart formControlName=\"start\" [placeholder]=\"(translationContext + 'START_DATE') | uiTranslate : language\" >\n        <input matEndDate  #dateRangeEnd formControlName=\"end\" [placeholder]=\"(translationContext + 'END_DATE') | uiTranslate : language\" (dateChange)=\"dateRangeChange(dateRangeStart.value, dateRangeEnd.value)\">\n      </mat-date-range-input>\n      <mat-datepicker-toggle matIconSuffix [for]=\"rangePicker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-date-range-picker #rangePicker></mat-date-range-picker>\n    </ng-container>\n\n    <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n      <ng-container *ngIf=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-container>\n      <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\" [language]=\"language\"></ui-validation-error>\n    </mat-hint>\n  </mat-form-field>\n\n  <ng-template #dateYearPicker>\n    <mat-form-field\n      appNoDateFormat\n      #uiDatepicker\n      appearance=\"outline\"\n      [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n      [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n\n      <ng-container >\n        <input matInput\n               [id]=\"id!\"\n               (blur)=\"onTouch()\"\n               [placeholder]=\"placeholder!\"\n               [matDatepicker]=\"dp\"\n               [value]=\"value\"\n               [disabled]=\"disabled\"\n               [name]=\"fieldName!\"\n               [min]=\"minDate\"\n               [max]=\"maxDate\"\n               [readonly]=\"preventUserInput\"\n               (change)=\"onInput($event)\"\n               (dateChange)=\"onValueChange($event.value)\"\n        >\n        <mat-datepicker-toggle matIconSuffix [for]=\"dp\">\n          <ui-icon *ngIf=\"applicationTheme !== 'classic'\" matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n        </mat-datepicker-toggle>\n        <mat-datepicker panelClass=\"month-picker\" #dp startView=\"multi-year\" (monthSelected)=\"setMonthAndYear($event, dp)\"></mat-datepicker>\n      </ng-container>\n\n      <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n      <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n        <ng-container *ngIf=\"errorsLength\">\n          <div class=\"errors\" *ngFor=\"let error of _errors\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\" [language]=\"language\"></ui-validation-error>\n      </mat-hint>\n\n    </mat-form-field>\n  </ng-template>\n\n</ng-container>\n"]}
|
|
306
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.ts","../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Self,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, FormGroup, NgControl } from '@angular/forms';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class DatepickerComponent implements OnChanges, ControlValueAccessor, DoCheck {\n  @HostBinding() class = 'ui-datepicker';\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() value?: string | Date;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is date range\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() isRange: boolean;\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() hintMessage: string;\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * The language to be used\n   *\n   * @type {Language}\n   * @memberof DatepickerComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * Show reserved content below form field\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Set full width DatepickerComponent\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Set min date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() minDate: Date | undefined;\n\n  /**\n   * Set max date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() maxDate: Date | undefined;\n\n  /**\n   * Show and pick date without day\n   * @default false\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() monthPicker = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof DatepickerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Prevent user input\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() preventUserInput = false;\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  /**\n   * Event emitted when the value is change - when used outside of form\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Output() changed = new EventEmitter<Date | string>();\n\n  range = new FormGroup({\n    start: new FormControl<Date | null>(null),\n    end: new FormControl<Date | null>(null),\n  });\n\n  errorsLength: boolean;\n  protected translationContext = 'DATEPICKER.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private cdr: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  get hint(): string {\n    if (this.hintMessage === undefined) {\n      return this.isRange ? 'MM/DD/YYYY - MM/DD/YYYY' : this.monthPicker ? 'MM/YYYY' : 'MM/DD/YYYY';\n    }\n\n    return this.hintMessage;\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\n   * to display validation errors that might happen (e.g. required)\n   */\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.ngControl?.touched || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnInit() {\n    document.body.setAttribute('theme', this.applicationTheme);\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(): void {\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  onValueChange(value: Date | string) {\n    this.writeValue(value);\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    this.onChange(value);\n    this.changed.emit(value);\n  }\n\n  writeValue(value?: Date | string): void {\n    this.value = value;\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  dateRangeChange(start: string, end: string) {\n    if (start && end) {\n      this.onValueChange(this.getRange(start, end));\n    }\n  }\n\n  setMonthAndYear(normalizedMonthAndYear: any, datepicker: MatDatepicker<Date>) {\n    const ctrlValue = typeof this.value === 'string' ? new Date(this.value) : this.value || new Date();\n\n    ctrlValue.setMonth(normalizedMonthAndYear.getMonth());\n    ctrlValue.setFullYear(normalizedMonthAndYear.getFullYear());\n\n    datepicker.close();\n\n    this.onValueChange(new Date(ctrlValue));\n  }\n\n  private setRange() {\n    if (typeof this.value === 'string') {\n      const [start, end] = this.value?.split('-');\n      if (start) {\n        this.range.controls.start.setValue(new Date(start));\n      }\n      if (end) {\n        this.range.controls.end.setValue(new Date(end));\n      }\n    }\n\n    if (!this.value) {\n      this.range.controls.start.setValue(null);\n      this.range.controls.end.setValue(null);\n    }\n  }\n\n  private getRange(start: string, end: string): string {\n    return `${start}-${end}`;\n  }\n\n  onInput(event: Event) {\n    const target = event.target as EventTarget & { value: string };\n    const [month, year] = target.value.split('/');\n    const date = new Date().getDate();\n    const fullDateString = `${month}/${date}/${year}`;\n    const fullDate = new Date(fullDateString);\n    this.onValueChange(fullDate);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    *ngIf=\"!monthPicker; else dateYearPicker\"\n    #uiDatepicker\n    appearance=\"outline\"\n    [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n    [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n  >\n    <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n    <ng-container *ngIf=\"!isRange\">\n      <input *ngIf=\"!isRange\" matInput\n             [matDatepicker]=\"picker\"\n             (blur)=\"onTouch()\"\n             (dateChange)=\"onValueChange($event.value)\"\n             [id]=\"id!\"\n             [placeholder]=\"placeholder!\"\n             [value]=\"value\"\n             [disabled]=\"disabled\"\n             [name]=\"fieldName!\"\n             [readonly]=\"preventUserInput\"\n             [min]=\"minDate\"\n             [max]=\"maxDate\"\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRange\">\n      <mat-date-range-input *ngIf=\"isRange\" [formGroup]=\"range\" [rangePicker]=\"rangePicker\" [min]=\"minDate\" [max]=\"maxDate\" >\n        <input matStartDate #dateRangeStart formControlName=\"start\" [placeholder]=\"(translationContext + 'START_DATE') | uiTranslate : language\" >\n        <input matEndDate  #dateRangeEnd formControlName=\"end\" [placeholder]=\"(translationContext + 'END_DATE') | uiTranslate : language\" (dateChange)=\"dateRangeChange(dateRangeStart.value, dateRangeEnd.value)\">\n      </mat-date-range-input>\n      <mat-datepicker-toggle matIconSuffix [for]=\"rangePicker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-date-range-picker #rangePicker></mat-date-range-picker>\n    </ng-container>\n\n    <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n      <ng-container *ngIf=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-container>\n      <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\" [language]=\"language\"></ui-validation-error>\n    </mat-hint>\n  </mat-form-field>\n\n  <ng-template #dateYearPicker>\n    <mat-form-field\n      appNoDateFormat\n      #uiDatepicker\n      appearance=\"outline\"\n      [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n      [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n\n      <ng-container >\n        <input matInput\n               [id]=\"id!\"\n               (blur)=\"onTouch()\"\n               [placeholder]=\"placeholder!\"\n               [matDatepicker]=\"dp\"\n               [value]=\"value\"\n               [disabled]=\"disabled\"\n               [name]=\"fieldName!\"\n               [min]=\"minDate\"\n               [max]=\"maxDate\"\n               [readonly]=\"preventUserInput\"\n               (change)=\"onInput($event)\"\n               (dateChange)=\"onValueChange($event.value)\"\n        >\n        <mat-datepicker-toggle matIconSuffix [for]=\"dp\">\n          <ui-icon *ngIf=\"applicationTheme !== 'classic'\" matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n        </mat-datepicker-toggle>\n        <mat-datepicker panelClass=\"month-picker\" #dp startView=\"multi-year\" (monthSelected)=\"setMonthAndYear($event, dp)\"></mat-datepicker>\n      </ng-container>\n\n      <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n      <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n        <ng-container *ngIf=\"errorsLength\">\n          <div class=\"errors\" *ngFor=\"let error of _errors\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\" [language]=\"language\"></ui-validation-error>\n      </mat-hint>\n\n    </mat-form-field>\n  </ng-template>\n\n</ng-container>\n"]}
|