mis-crystal-design-system 18.1.7-signal-16-test → 18.1.7-signal-16-test-2

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.
@@ -74,16 +74,19 @@ export class TzDaterangepickerDirective {
74
74
  backdropClass: "cdk-overlay-transparent-backdrop"
75
75
  });
76
76
  this.overlayRef = this.overlay.create(config);
77
+ // Get current values at the time of opening
78
+ const currentSelectedDates = this.selectedDates();
79
+ const currentSelectedRangeLabel = this.selectedRangeLabel();
77
80
  const tempRef = new ComponentPortal(TzDrpContainerComponent, this.viewContainerRef, Injector.create({
78
81
  providers: [
79
82
  {
80
83
  provide: CONTAINER_DATA,
81
84
  useValue: {
82
85
  messages: this.dateMessages(),
83
- dates: this.selectedDates(),
86
+ dates: currentSelectedDates,
84
87
  dpConfig: this.dpConfig(),
85
88
  datesDisabled: this.datesDisabled(),
86
- selectedRangeLabel: this.selectedRangeLabel(),
89
+ selectedRangeLabel: currentSelectedRangeLabel,
87
90
  dateChange: this.applyDate.bind(this),
88
91
  close: this.close.bind(this)
89
92
  }
@@ -137,4 +140,4 @@ export class TzDaterangepickerDirective {
137
140
  type: HostListener,
138
141
  args: ["keydown.esc"]
139
142
  }] }); })();
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tz-daterangepicker.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/daterangepicker_v2/tz-daterangepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { Directive, ElementRef, HostListener, Injector, Optional, Self, ViewContainerRef, input, output } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { take } from \"rxjs/operators\";\nimport { genPositionPairs } from \"mis-crystal-design-system/utils\";\nimport { CONTAINER_DATA, DATE_FORMAT } from \"./daterangepicker-constants\";\nimport { IDatePickerConfig, IDatePickerToastText, ISelectedDatesConfig } from \"./models/drp-config.model\";\nimport { TzDrpContainerComponent } from \"./tz-drp-container/tz-drp-container.component\";\n\n@Directive({\n  selector: \"input[misTzDrp]\"\n})\nexport class TzDaterangepickerDirective {\n  // Signal-based inputs\n  dpConfig = input<Partial<IDatePickerConfig>>({\n    format: DATE_FORMAT,\n    minDate: \"\",\n    maxDate: \"\",\n    maxAllowedRange: 0,\n    ranges: []\n  });\n  selectedDates = input<ISelectedDatesConfig>({ startDate: null, endDate: null });\n  datesDisabled = input<string[]>([]);\n  selectedRangeLabel = input<string>('Custom Range');\n  dateMessages = input<IDatePickerToastText[]>([]);\n  positionX = input<\"start\" | \"center\" | \"end\">(\"center\");\n  positionY = input<\"top\" | \"center\" | \"bottom\">(\"bottom\");\n  offsetX = input<number>(0);\n  offsetY = input<number>(0);\n  \n  // Signal-based output\n  dateChange = output<ISelectedDatesConfig>();\n  \n  private overlayRef: OverlayRef;\n  private isOpen = false;\n\n  constructor(\n    @Self() @Optional() private control: NgControl,\n    private element: ElementRef,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {}\n\n  @HostListener(\"click\")\n  toggleDatePicker() {\n    if (this.isOpen) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  @HostListener(\"keydown.enter\")\n  toggleDatePickerOnEnter() {\n    if (this.isOpen) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  @HostListener(\"keydown.esc\")\n  closeOnEsc() {\n    if (this.isOpen) {\n      this.close();\n    }\n  }\n\n  private open() {\n    this.isOpen = true;\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.element)\n      .withPositions(\n        genPositionPairs(\n          {\n            positionX: this.positionX(),\n            positionY: this.positionY(),\n            offsetX: this.offsetX(),\n            offsetY: this.offsetY()\n          },\n          true\n        )\n      )\n      .withPush(true);\n    const config = new OverlayConfig({\n      hasBackdrop: true,\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      backdropClass: \"cdk-overlay-transparent-backdrop\"\n    });\n    this.overlayRef = this.overlay.create(config);\n    const tempRef = new ComponentPortal(\n      TzDrpContainerComponent,\n      this.viewContainerRef,\n      Injector.create({\n        providers: [\n          {\n            provide: CONTAINER_DATA,\n            useValue: {\n              messages: this.dateMessages(),\n              dates: this.selectedDates(),\n              dpConfig: this.dpConfig(),\n              datesDisabled: this.datesDisabled(),\n              selectedRangeLabel: this.selectedRangeLabel(),\n              dateChange: this.applyDate.bind(this),\n              close: this.close.bind(this)\n            }\n          }\n        ]\n      })\n    );\n    this.overlayRef.attach(tempRef);\n    this.overlayRef\n      .backdropClick()\n      .pipe(take(1))\n      .subscribe(() => {\n        this.close();\n      });\n  }\n\n  applyDate(dates: ISelectedDatesConfig) {\n    // If selectedRangeLabel is present in the date object, keep it, otherwise it's a custom range\n    const result = {\n      ...dates,\n      selectedRangeLabel: dates['selectedRangeLabel'] || 'Custom Range'\n    };\n    this.dateChange.emit(result);\n    this.control?.control.patchValue(result);\n    this.close();\n  }\n\n  close() {\n    this.isOpen = false;\n    this.overlayRef.detach();\n    this.overlayRef.dispose();\n  }\n}\n"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tz-daterangepicker.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/daterangepicker_v2/tz-daterangepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { Directive, ElementRef, HostListener, Injector, Optional, Self, ViewContainerRef, input, output } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { take } from \"rxjs/operators\";\nimport { genPositionPairs } from \"mis-crystal-design-system/utils\";\nimport { CONTAINER_DATA, DATE_FORMAT } from \"./daterangepicker-constants\";\nimport { IDatePickerConfig, IDatePickerToastText, ISelectedDatesConfig } from \"./models/drp-config.model\";\nimport { TzDrpContainerComponent } from \"./tz-drp-container/tz-drp-container.component\";\n\n@Directive({\n  selector: \"input[misTzDrp]\"\n})\nexport class TzDaterangepickerDirective {\n  // Signal-based inputs\n  dpConfig = input<Partial<IDatePickerConfig>>({\n    format: DATE_FORMAT,\n    minDate: \"\",\n    maxDate: \"\",\n    maxAllowedRange: 0,\n    ranges: []\n  });\n  selectedDates = input<ISelectedDatesConfig>({ startDate: null, endDate: null });\n  datesDisabled = input<string[]>([]);\n  selectedRangeLabel = input<string>('Custom Range');\n  dateMessages = input<IDatePickerToastText[]>([]);\n  positionX = input<\"start\" | \"center\" | \"end\">(\"center\");\n  positionY = input<\"top\" | \"center\" | \"bottom\">(\"bottom\");\n  offsetX = input<number>(0);\n  offsetY = input<number>(0);\n  \n  // Signal-based output\n  dateChange = output<ISelectedDatesConfig>();\n  \n  private overlayRef: OverlayRef;\n  private isOpen = false;\n\n  constructor(\n    @Self() @Optional() private control: NgControl,\n    private element: ElementRef,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {}\n\n  @HostListener(\"click\")\n  toggleDatePicker() {\n    if (this.isOpen) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  @HostListener(\"keydown.enter\")\n  toggleDatePickerOnEnter() {\n    if (this.isOpen) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  @HostListener(\"keydown.esc\")\n  closeOnEsc() {\n    if (this.isOpen) {\n      this.close();\n    }\n  }\n\n  private open() {\n    this.isOpen = true;\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.element)\n      .withPositions(\n        genPositionPairs(\n          {\n            positionX: this.positionX(),\n            positionY: this.positionY(),\n            offsetX: this.offsetX(),\n            offsetY: this.offsetY()\n          },\n          true\n        )\n      )\n      .withPush(true);\n    const config = new OverlayConfig({\n      hasBackdrop: true,\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      backdropClass: \"cdk-overlay-transparent-backdrop\"\n    });\n    this.overlayRef = this.overlay.create(config);\n    \n    // Get current values at the time of opening\n    const currentSelectedDates = this.selectedDates();\n    const currentSelectedRangeLabel = this.selectedRangeLabel();\n    \n    const tempRef = new ComponentPortal(\n      TzDrpContainerComponent,\n      this.viewContainerRef,\n      Injector.create({\n        providers: [\n          {\n            provide: CONTAINER_DATA,\n            useValue: {\n              messages: this.dateMessages(),\n              dates: currentSelectedDates,\n              dpConfig: this.dpConfig(),\n              datesDisabled: this.datesDisabled(),\n              selectedRangeLabel: currentSelectedRangeLabel,\n              dateChange: this.applyDate.bind(this),\n              close: this.close.bind(this)\n            }\n          }\n        ]\n      })\n    );\n    this.overlayRef.attach(tempRef);\n    this.overlayRef\n      .backdropClick()\n      .pipe(take(1))\n      .subscribe(() => {\n        this.close();\n      });\n  }\n\n  applyDate(dates: ISelectedDatesConfig) {\n    // If selectedRangeLabel is present in the date object, keep it, otherwise it's a custom range\n    const result = {\n      ...dates,\n      selectedRangeLabel: dates['selectedRangeLabel'] || 'Custom Range'\n    };\n    this.dateChange.emit(result);\n    this.control?.control.patchValue(result);\n    this.close();\n  }\n\n  close() {\n    this.isOpen = false;\n    this.overlayRef.detach();\n    this.overlayRef.dispose();\n  }\n}\n"]}