@colijnit/corecomponents_v12 258.1.25 → 258.1.26

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,4 +1,4 @@
1
- import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Optional, ViewEncapsulation } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from '@angular/core';
2
2
  import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
3
3
  import { OverlayService } from '../../service/overlay.service';
4
4
  import { BaseInputDatePickerDirective } from "../base-input-date-picker/base-input-date-picker.directive";
@@ -16,6 +16,7 @@ export class InputDatePickerComponent extends BaseInputDatePickerDirective {
16
16
  this.formUserChangeListener = formUserChangeListener;
17
17
  this.ngZoneWrapper = ngZoneWrapper;
18
18
  this.elementRef = elementRef;
19
+ this.showClearButton = true;
19
20
  super._markAsOnPush();
20
21
  }
21
22
  showClass() {
@@ -92,25 +93,26 @@ export class InputDatePickerComponent extends BaseInputDatePickerDirective {
92
93
  InputDatePickerComponent.decorators = [
93
94
  { type: Component, args: [{
94
95
  selector: 'co-input-date',
95
- template: `
96
- <co-input-text (clickOutside)="toggleCalendar(false)" overlayParent #parentForOverlay="overlayParent"
97
- [hidden]="hidden"
98
- [readonly]="readonly"
99
- [(model)]="modelAsString"
100
- [rightIcon]="rightIcon"
101
- [leftIcon]="leftIcon"
102
- [leftIconData]="leftIconData"
103
- [pattern]="'yyyy-MM-dd'"
104
- [type]="'date'"
105
- [placeholder]="placeholder"
106
- (leftIconClick)="leftIconClick.emit($event)"
107
- (rightIconClick)="toggleCalendar(true)"
108
- (modelChange)="modelAsString = $event"
109
- (clearIconClick)="handleClearIconClicked()"
110
- [emptyPlace]="true"
111
- (keyup.enter)="finalizeDate()"
112
- (blur)="finalizeDate()"
113
- ></co-input-text>
96
+ template: `
97
+ <co-input-text (clickOutside)="toggleCalendar(false)" overlayParent #parentForOverlay="overlayParent"
98
+ [hidden]="hidden"
99
+ [readonly]="readonly"
100
+ [(model)]="modelAsString"
101
+ [rightIcon]="rightIcon"
102
+ [leftIcon]="leftIcon"
103
+ [leftIconData]="leftIconData"
104
+ [pattern]="'yyyy-MM-dd'"
105
+ [type]="'date'"
106
+ [placeholder]="placeholder"
107
+ [showClearButton]="showClearButton"
108
+ (leftIconClick)="leftIconClick.emit($event)"
109
+ (rightIconClick)="toggleCalendar(true)"
110
+ (modelChange)="modelAsString = $event"
111
+ (clearIconClick)="handleClearIconClicked()"
112
+ [emptyPlace]="true"
113
+ (keyup.enter)="finalizeDate()"
114
+ (blur)="finalizeDate()"
115
+ ></co-input-text>
114
116
  `,
115
117
  providers: [
116
118
  OverlayService, {
@@ -133,6 +135,7 @@ InputDatePickerComponent.ctorParameters = () => [
133
135
  { type: ElementRef }
134
136
  ];
135
137
  InputDatePickerComponent.propDecorators = {
138
+ showClearButton: [{ type: Input }],
136
139
  showClass: [{ type: HostBinding, args: ['class.co-input-date',] }]
137
140
  };
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-picker/input-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component, ComponentFactoryResolver,\r\n  ComponentRef, ElementRef,\r\n  forwardRef,\r\n  HostBinding, Optional, ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {CalendarComponent} from \"../calendar/calendar.component\";\r\nimport {FormComponent} from \"../form/form.component\";\r\nimport {FormInputUserModelChangeListenerService} from \"../../core/service/form-input-user-change-listener.service\";\r\nimport {NgZoneWrapperService} from \"../../core/service/ng-zone-wrapper.service\";\r\n\r\n@Component({\r\n    selector: 'co-input-date',\r\n    template: `\r\n      <co-input-text (clickOutside)=\"toggleCalendar(false)\" overlayParent #parentForOverlay=\"overlayParent\"\r\n                     [hidden]=\"hidden\"\r\n                     [readonly]=\"readonly\"\r\n                     [(model)]=\"modelAsString\"\r\n                     [rightIcon]=\"rightIcon\"\r\n                     [leftIcon]=\"leftIcon\"\r\n                     [leftIconData]=\"leftIconData\"\r\n                     [pattern]=\"'yyyy-MM-dd'\"\r\n                     [type]=\"'date'\"\r\n                     [placeholder]=\"placeholder\"\r\n                     (leftIconClick)=\"leftIconClick.emit($event)\"\r\n                     (rightIconClick)=\"toggleCalendar(true)\"\r\n                     (modelChange)=\"modelAsString = $event\"\r\n                     (clearIconClick)=\"handleClearIconClicked()\"\r\n                     [emptyPlace]=\"true\"\r\n                     (keyup.enter)=\"finalizeDate()\"\r\n                     (blur)=\"finalizeDate()\"\r\n      ></co-input-text>\r\n    `,\r\n    providers: [\r\n        OverlayService, {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputDatePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDatePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDatePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public modelAsString: string;\r\n\r\n  private _calendarComponentRef: ComponentRef<CalendarComponent>;\r\n\r\n  @HostBinding('class.co-input-date')\r\n  public showClass() {\r\n      return true;\r\n  }\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected overlayService: OverlayService,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  public handleDateSelected(date: Date): void {\r\n    this.setModel(date);\r\n    if (this.closeAfterDateSelection || !date) {\r\n      this.toggleCalendar(false);\r\n    }\r\n  }\r\n\r\n  public toggleCalendar(show: boolean): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = show;\r\n\r\n    if (this.showCalendar) {\r\n      this._calendarComponentRef = this.overlayService.createComponent(CalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDate: this.model\r\n      }, {\r\n        dateSelected: (event) => this.handleDateSelected(event),\r\n        clickedOutside: () => this.toggleCalendar(false) // Close when clicked outside\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._calendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public finalizeDate(): void {\r\n    if (this.isValidDateString(this.modelAsString)) {\r\n      const [year, month, day] = this.modelAsString.split('-').map(Number);\r\n      const date = new Date(year, month - 1, day);\r\n      this.setModel(date);\r\n    }\r\n  }\r\n\r\n  public finalize(): void {\r\n    this.finalizeDate?.(); // re-use the same logic from (keyup.enter)\r\n  }\r\n\r\n\r\n  private isValidDateString(value: string): boolean {\r\n    const regex = /^\\d{4}-\\d{2}-\\d{2}$/;\r\n    if (!regex.test(value)) return false;\r\n\r\n    const [year, month, day] = value.split('-').map(Number);\r\n    const date = new Date(year, month - 1, day);\r\n\r\n    return (\r\n      date.getFullYear() === year &&\r\n      date.getMonth() === month - 1 &&\r\n      date.getDate() === day\r\n    );\r\n  }\r\n\r\n  public handleDateChange(value: string): void {\r\n    if (value) {\r\n        this.setModel(new Date(value));\r\n    }\r\n  }\r\n\r\n  protected modelSet(): void {\r\n      this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    if (this.model) {\r\n      const year = this.model.toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model.toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model.toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.modelAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.modelAsString = null;\r\n    }\r\n  }\r\n\r\n  public handleClearIconClicked() {\r\n      this.setModel(undefined);\r\n  }\r\n}\r\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-picker/input-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component, ComponentFactoryResolver,\n  ComponentRef, ElementRef,\n  forwardRef,\n  HostBinding, Input, Optional, ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {OverlayService} from '../../service/overlay.service';\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\nimport {CalendarComponent} from \"../calendar/calendar.component\";\nimport {FormComponent} from \"../form/form.component\";\nimport {FormInputUserModelChangeListenerService} from \"../../core/service/form-input-user-change-listener.service\";\nimport {NgZoneWrapperService} from \"../../core/service/ng-zone-wrapper.service\";\n\n@Component({\n    selector: 'co-input-date',\n    template: `\n      <co-input-text (clickOutside)=\"toggleCalendar(false)\" overlayParent #parentForOverlay=\"overlayParent\"\n                     [hidden]=\"hidden\"\n                     [readonly]=\"readonly\"\n                     [(model)]=\"modelAsString\"\n                     [rightIcon]=\"rightIcon\"\n                     [leftIcon]=\"leftIcon\"\n                     [leftIconData]=\"leftIconData\"\n                     [pattern]=\"'yyyy-MM-dd'\"\n                     [type]=\"'date'\"\n                     [placeholder]=\"placeholder\"\n                     [showClearButton]=\"showClearButton\"\n                     (leftIconClick)=\"leftIconClick.emit($event)\"\n                     (rightIconClick)=\"toggleCalendar(true)\"\n                     (modelChange)=\"modelAsString = $event\"\n                     (clearIconClick)=\"handleClearIconClicked()\"\n                     [emptyPlace]=\"true\"\n                     (keyup.enter)=\"finalizeDate()\"\n                     (blur)=\"finalizeDate()\"\n      ></co-input-text>\n    `,\n    providers: [\n        OverlayService, {\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputDatePickerComponent)\n        }, {\n            provide: BaseInputDatePickerDirective,\n            useExisting: InputDatePickerComponent\n        }],\n    encapsulation: ViewEncapsulation.None\n})\nexport class InputDatePickerComponent extends BaseInputDatePickerDirective {\n\n  public modelAsString: string;\n\n  private _calendarComponentRef: ComponentRef<CalendarComponent>;\n\n  @Input()\n  public showClearButton: boolean = true;\n\n  @HostBinding('class.co-input-date')\n  public showClass() {\n      return true;\n  }\n\n  constructor(\n    @Optional() public formComponent: FormComponent,\n    protected changeDetector: ChangeDetectorRef,\n    protected overlayService: OverlayService,\n    protected componentFactoryResolver: ComponentFactoryResolver,\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\n    protected ngZoneWrapper?: NgZoneWrapperService,\n    public elementRef?: ElementRef,\n  ) {\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\n    super._markAsOnPush();\n  }\n\n  public handleDateSelected(date: Date): void {\n    this.setModel(date);\n    if (this.closeAfterDateSelection || !date) {\n      this.toggleCalendar(false);\n    }\n  }\n\n  public toggleCalendar(show: boolean): void {\n    if (this.readonly) {\n      return;\n    }\n\n    this.showCalendar = show;\n\n    if (this.showCalendar) {\n      this._calendarComponentRef = this.overlayService.createComponent(CalendarComponent, {\n        parentForOverlay: this.parentForOverlay,\n        selectedDate: this.model\n      }, {\n        dateSelected: (event) => this.handleDateSelected(event),\n        clickedOutside: () => this.toggleCalendar(false) // Close when clicked outside\n      });\n    } else {\n      this.overlayService.removeComponent(this._calendarComponentRef);\n    }\n  }\n\n  public finalizeDate(): void {\n    if (this.isValidDateString(this.modelAsString)) {\n      const [year, month, day] = this.modelAsString.split('-').map(Number);\n      const date = new Date(year, month - 1, day);\n      this.setModel(date);\n    }\n  }\n\n  public finalize(): void {\n    this.finalizeDate?.(); // re-use the same logic from (keyup.enter)\n  }\n\n\n  private isValidDateString(value: string): boolean {\n    const regex = /^\\d{4}-\\d{2}-\\d{2}$/;\n    if (!regex.test(value)) return false;\n\n    const [year, month, day] = value.split('-').map(Number);\n    const date = new Date(year, month - 1, day);\n\n    return (\n      date.getFullYear() === year &&\n      date.getMonth() === month - 1 &&\n      date.getDate() === day\n    );\n  }\n\n  public handleDateChange(value: string): void {\n    if (value) {\n        this.setModel(new Date(value));\n    }\n  }\n\n  protected modelSet(): void {\n      this.setModelAsString();\n  }\n\n  private setModelAsString(): void {\n    if (this.model) {\n      const year = this.model.toLocaleString(\"default\", { year: \"numeric\" });\n      const month = this.model.toLocaleString(\"default\", { month: \"2-digit\" });\n      const day = this.model.toLocaleString(\"default\", { day: \"2-digit\" });\n      this.modelAsString = `${year}-${month}-${day}`;\n    } else {\n      this.modelAsString = null;\n    }\n  }\n\n  public handleClearIconClicked() {\n      this.setModel(undefined);\n  }\n}\n"]}
@@ -5431,6 +5431,7 @@ class InputDatePickerComponent extends BaseInputDatePickerDirective {
5431
5431
  this.formUserChangeListener = formUserChangeListener;
5432
5432
  this.ngZoneWrapper = ngZoneWrapper;
5433
5433
  this.elementRef = elementRef;
5434
+ this.showClearButton = true;
5434
5435
  super._markAsOnPush();
5435
5436
  }
5436
5437
  showClass() {
@@ -5507,25 +5508,26 @@ class InputDatePickerComponent extends BaseInputDatePickerDirective {
5507
5508
  InputDatePickerComponent.decorators = [
5508
5509
  { type: Component, args: [{
5509
5510
  selector: 'co-input-date',
5510
- template: `
5511
- <co-input-text (clickOutside)="toggleCalendar(false)" overlayParent #parentForOverlay="overlayParent"
5512
- [hidden]="hidden"
5513
- [readonly]="readonly"
5514
- [(model)]="modelAsString"
5515
- [rightIcon]="rightIcon"
5516
- [leftIcon]="leftIcon"
5517
- [leftIconData]="leftIconData"
5518
- [pattern]="'yyyy-MM-dd'"
5519
- [type]="'date'"
5520
- [placeholder]="placeholder"
5521
- (leftIconClick)="leftIconClick.emit($event)"
5522
- (rightIconClick)="toggleCalendar(true)"
5523
- (modelChange)="modelAsString = $event"
5524
- (clearIconClick)="handleClearIconClicked()"
5525
- [emptyPlace]="true"
5526
- (keyup.enter)="finalizeDate()"
5527
- (blur)="finalizeDate()"
5528
- ></co-input-text>
5511
+ template: `
5512
+ <co-input-text (clickOutside)="toggleCalendar(false)" overlayParent #parentForOverlay="overlayParent"
5513
+ [hidden]="hidden"
5514
+ [readonly]="readonly"
5515
+ [(model)]="modelAsString"
5516
+ [rightIcon]="rightIcon"
5517
+ [leftIcon]="leftIcon"
5518
+ [leftIconData]="leftIconData"
5519
+ [pattern]="'yyyy-MM-dd'"
5520
+ [type]="'date'"
5521
+ [placeholder]="placeholder"
5522
+ [showClearButton]="showClearButton"
5523
+ (leftIconClick)="leftIconClick.emit($event)"
5524
+ (rightIconClick)="toggleCalendar(true)"
5525
+ (modelChange)="modelAsString = $event"
5526
+ (clearIconClick)="handleClearIconClicked()"
5527
+ [emptyPlace]="true"
5528
+ (keyup.enter)="finalizeDate()"
5529
+ (blur)="finalizeDate()"
5530
+ ></co-input-text>
5529
5531
  `,
5530
5532
  providers: [
5531
5533
  OverlayService, {
@@ -5548,6 +5550,7 @@ InputDatePickerComponent.ctorParameters = () => [
5548
5550
  { type: ElementRef }
5549
5551
  ];
5550
5552
  InputDatePickerComponent.propDecorators = {
5553
+ showClearButton: [{ type: Input }],
5551
5554
  showClass: [{ type: HostBinding, args: ['class.co-input-date',] }]
5552
5555
  };
5553
5556