ngx-histaff-alpha 3.4.1 → 3.4.3

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.
@@ -120,13 +120,12 @@ export class CoreShiftCellComponent extends CoreFormControlBaseComponent {
120
120
  // Handle drop logic based on data
121
121
  if (data) {
122
122
  // Process dropped data here
123
- this.$shifts.update(x => {
124
- x.push({
125
- ...this.workShiftDndService.draggingShift$.value,
126
- pending: true,
127
- });
128
- return x;
123
+ const newShifts = this.$shifts();
124
+ newShifts.push({
125
+ ...this.workShiftDndService.draggingShift$.value,
126
+ pending: true,
129
127
  });
128
+ this.$shifts.set(newShifts);
130
129
  }
131
130
  });
132
131
  });
@@ -170,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
170
169
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.WorkShiftDndService }, { type: i2.DialogService }], propDecorators: { onDrop: [{
171
170
  type: Output
172
171
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-shift-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-cell/core-shift-cell.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-cell/core-shift-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ElementRef, input, viewChild, ChangeDetectorRef, WritableSignal, signal, Output, EventEmitter } from '@angular/core';\r\nimport { CoreShiftStickerComponent } from '../core-shift-sticker/core-shift-sticker.component';\r\nimport { IAtShift } from '../../interfaces/time-management/IAtShift';\r\nimport { BehaviorSubject, debounceTime, distinctUntilChanged, filter, fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { WorkShiftDndService } from '../../services/work-shift-dnd.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { EnumTranslateKey } from 'alpha-global-constants';\r\n\r\nexport interface IDroppableEventSubscription {\r\n  dragenter: Subscription | undefined,\r\n  dragover: Subscription | undefined,\r\n  dragleave: Subscription | undefined,\r\n  drop: Subscription | undefined\r\n}\r\n\r\n@Component({\r\n  selector: 'core-shift-cell',\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    CoreShiftStickerComponent\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreShiftCellComponent\r\n    }\r\n  ],\r\n  templateUrl: './core-shift-cell.component.html',\r\n  styleUrl: './core-shift-cell.component.scss'\r\n})\r\nexport class CoreShiftCellComponent extends CoreFormControlBaseComponent implements AfterViewInit {\r\n\r\n  @Output() onDrop = new EventEmitter<boolean>();\r\n\r\n  override value!: IAtShift[];\r\n\r\n  override writeValue(obj: IAtShift[]): void {\r\n    this.$shifts.set(obj);\r\n  }\r\n\r\n  $backgroundColor = input<string>('white');\r\n  $container = viewChild<ElementRef>('container');\r\n  shiftCellId: string = crypto.randomUUID();\r\n\r\n  private dragElements: Set<EventTarget> = new Set();\r\n\r\n  dndEventSubscriptions: IDroppableEventSubscription = {\r\n    dragenter: new Subscription(() => null),\r\n    dragover: new Subscription(() => null),\r\n    drop: new Subscription(() => null),\r\n    dragleave: new Subscription(() => null)\r\n  }\r\n\r\n  $shifts: WritableSignal<IAtShift[]> = signal([\r\n    {\r\n      code: 'X',\r\n      name: 'Ca làm việc ngày thường',\r\n      symbol: {\r\n        code: 'X',\r\n        name: 'X',\r\n        isHaveSal: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    },\r\n    {\r\n      code: 'OFF',\r\n      name: 'Ca ngày nghỉ',\r\n      symbol: {\r\n        code: 'OFF',\r\n        name: 'OFF',\r\n        isOff: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    },\r\n    {\r\n      code: 'CT',\r\n      name: 'Ca công tác',\r\n      symbol: {\r\n        code: 'CT',\r\n        name: 'CR',\r\n        isRegister: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    }\r\n  ]);\r\n\r\n  onDropStream$ = new BehaviorSubject<string>('');\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private workShiftDndService: WorkShiftDndService,\r\n    private dialogService: DialogService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      this.onDropStream$.pipe(\r\n        filter(x => !!x.length),\r\n        debounceTime(500)\r\n      ).subscribe(x => {\r\n        this.onDrop.emit(true);\r\n      })\r\n\r\n      const containerElement = this.$container()?.nativeElement;\r\n\r\n      containerElement.style.setProperty('--background-color', this.$backgroundColor());\r\n      this.cdr.markForCheck();\r\n\r\n\r\n      const dragenterEvent = fromEvent(containerElement, 'dragenter');\r\n      const dragoverEvent = fromEvent(containerElement, 'dragover');\r\n      const dropEvent = fromEvent(containerElement, 'drop');\r\n      const dragleaveEvent = fromEvent(containerElement, 'dragleave');\r\n\r\n      this.dndEventSubscriptions.dragenter = dragenterEvent.subscribe((ev: any) => {\r\n        ev.preventDefault();\r\n        if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n        this.dragElements.add(ev.target as EventTarget);\r\n        containerElement.classList.add('valid-drop');\r\n        if (this.workShiftDndService.draggingData$.value.split(':')[0] !== this.shiftCellId) {\r\n          this.$container()?.nativeElement.style.setProperty('--background-color', '#fff4ce');\r\n          this.cdr.markForCheck();\r\n        }\r\n\r\n        // Subscribe to dragover event to allow drop\r\n        this.dndEventSubscriptions.dragover = dragoverEvent.subscribe((ev: any) => {\r\n          ev.preventDefault();\r\n          this.workShiftDndService.dragoverCellId$.next(this.shiftCellId)\r\n        });\r\n\r\n        // Subscribe to drop event\r\n        this.dndEventSubscriptions.drop = dropEvent.subscribe((ev: any) => {\r\n          ev.preventDefault();\r\n          if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n          this.dragElements.clear(); // Clear the set\r\n          containerElement.classList.remove('valid-drop');\r\n\r\n          this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());\r\n\r\n          this.cdr.markForCheck();\r\n\r\n          const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval\r\n\r\n          /*\r\n          this.dialogService.createNew(\r\n            EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,\r\n            undefined,\r\n            undefined,\r\n            undefined,\r\n            EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,\r\n            [\r\n              \"shiftId: \" + this.workShiftDndService.draggingShift$.value?.id,\r\n              \"shiftCode: \" + this.workShiftDndService.draggingShift$.value?.code,\r\n              \"dragoverCellId: \" + this.workShiftDndService.dragoverCellId$.value,\r\n              \"**************\",\r\n              \"WHATEVER LOGIC CAN BE ADDED WITH (onDrop) @Output() AND USING WorkShiftDndService\"\r\n            ]\r\n          )\r\n          */\r\n\r\n          this.onDropStream$.next(this.shiftCellId)\r\n\r\n          // Handle drop logic based on data\r\n          if (data) {\r\n            // Process dropped data here\r\n            this.$shifts.update(x => {\r\n              x.push({\r\n                ...this.workShiftDndService.draggingShift$.value!,\r\n                pending: true,\r\n              })\r\n              return x;\r\n            })\r\n          }\r\n        });\r\n\r\n      });\r\n\r\n      this.dndEventSubscriptions.dragleave = dragleaveEvent.subscribe((ev: any) => {\r\n        ev.preventDefault();\r\n        if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n        this.dragElements.delete(ev.target as EventTarget);\r\n        if (this.dragElements.size === 0) {\r\n          containerElement.classList.remove('valid-drop');\r\n        }\r\n        this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());\r\n        this.cdr.markForCheck();\r\n\r\n        this.dndEventSubscriptions.dragover?.unsubscribe();\r\n        this.dndEventSubscriptions.drop?.unsubscribe();\r\n\r\n        this.dndEventSubscriptions.dragover = undefined;\r\n        this.dndEventSubscriptions.drop = undefined;\r\n\r\n      });\r\n\r\n    });\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-shift-cell-container\">\r\n    @for (shift of $shifts(); track $index) {\r\n        <core-shift-sticker [$shift]=\"shift\" [$shiftCellId]=\"shiftCellId\" [$width]=\"228\"></core-shift-sticker>\r\n    }\r\n</div>\r\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-shift-cell.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-cell/core-shift-cell.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-cell/core-shift-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ElementRef, input, viewChild, ChangeDetectorRef, WritableSignal, signal, Output, EventEmitter } from '@angular/core';\r\nimport { CoreShiftStickerComponent } from '../core-shift-sticker/core-shift-sticker.component';\r\nimport { IAtShift } from '../../interfaces/time-management/IAtShift';\r\nimport { BehaviorSubject, debounceTime, distinctUntilChanged, filter, fromEvent, Observable, Subscription } from 'rxjs';\r\nimport { WorkShiftDndService } from '../../services/work-shift-dnd.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { EnumTranslateKey } from 'alpha-global-constants';\r\n\r\nexport interface IDroppableEventSubscription {\r\n  dragenter: Subscription | undefined,\r\n  dragover: Subscription | undefined,\r\n  dragleave: Subscription | undefined,\r\n  drop: Subscription | undefined\r\n}\r\n\r\n@Component({\r\n  selector: 'core-shift-cell',\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    CoreShiftStickerComponent\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreShiftCellComponent\r\n    }\r\n  ],\r\n  templateUrl: './core-shift-cell.component.html',\r\n  styleUrl: './core-shift-cell.component.scss'\r\n})\r\nexport class CoreShiftCellComponent extends CoreFormControlBaseComponent implements AfterViewInit {\r\n\r\n  @Output() onDrop = new EventEmitter<boolean>();\r\n\r\n  override value!: IAtShift[];\r\n\r\n  override writeValue(obj: IAtShift[]): void {\r\n    this.$shifts.set(obj);\r\n  }\r\n\r\n  $backgroundColor = input<string>('white');\r\n  $container = viewChild<ElementRef>('container');\r\n  shiftCellId: string = crypto.randomUUID();\r\n\r\n  private dragElements: Set<EventTarget> = new Set();\r\n\r\n  dndEventSubscriptions: IDroppableEventSubscription = {\r\n    dragenter: new Subscription(() => null),\r\n    dragover: new Subscription(() => null),\r\n    drop: new Subscription(() => null),\r\n    dragleave: new Subscription(() => null)\r\n  }\r\n\r\n  $shifts: WritableSignal<IAtShift[]> = signal([\r\n    {\r\n      code: 'X',\r\n      name: 'Ca làm việc ngày thường',\r\n      symbol: {\r\n        code: 'X',\r\n        name: 'X',\r\n        isHaveSal: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    },\r\n    {\r\n      code: 'OFF',\r\n      name: 'Ca ngày nghỉ',\r\n      symbol: {\r\n        code: 'OFF',\r\n        name: 'OFF',\r\n        isOff: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    },\r\n    {\r\n      code: 'CT',\r\n      name: 'Ca công tác',\r\n      symbol: {\r\n        code: 'CT',\r\n        name: 'CR',\r\n        isRegister: true,\r\n      },\r\n      hoursStart: new Date(2024, 7, 13, 8, 0, 0),\r\n      hoursStop: new Date(2024, 7, 13, 17, 30, 0)\r\n    }\r\n  ]);\r\n\r\n  onDropStream$ = new BehaviorSubject<string>('');\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private workShiftDndService: WorkShiftDndService,\r\n    private dialogService: DialogService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      this.onDropStream$.pipe(\r\n        filter(x => !!x.length),\r\n        debounceTime(500)\r\n      ).subscribe(x => {\r\n        this.onDrop.emit(true);\r\n      })\r\n\r\n      const containerElement = this.$container()?.nativeElement;\r\n\r\n      containerElement.style.setProperty('--background-color', this.$backgroundColor());\r\n      this.cdr.markForCheck();\r\n\r\n\r\n      const dragenterEvent = fromEvent(containerElement, 'dragenter');\r\n      const dragoverEvent = fromEvent(containerElement, 'dragover');\r\n      const dropEvent = fromEvent(containerElement, 'drop');\r\n      const dragleaveEvent = fromEvent(containerElement, 'dragleave');\r\n\r\n      this.dndEventSubscriptions.dragenter = dragenterEvent.subscribe((ev: any) => {\r\n        ev.preventDefault();\r\n        if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n        this.dragElements.add(ev.target as EventTarget);\r\n        containerElement.classList.add('valid-drop');\r\n        if (this.workShiftDndService.draggingData$.value.split(':')[0] !== this.shiftCellId) {\r\n          this.$container()?.nativeElement.style.setProperty('--background-color', '#fff4ce');\r\n          this.cdr.markForCheck();\r\n        }\r\n\r\n        // Subscribe to dragover event to allow drop\r\n        this.dndEventSubscriptions.dragover = dragoverEvent.subscribe((ev: any) => {\r\n          ev.preventDefault();\r\n          this.workShiftDndService.dragoverCellId$.next(this.shiftCellId)\r\n        });\r\n\r\n        // Subscribe to drop event\r\n        this.dndEventSubscriptions.drop = dropEvent.subscribe((ev: any) => {\r\n          ev.preventDefault();\r\n          if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n          this.dragElements.clear(); // Clear the set\r\n          containerElement.classList.remove('valid-drop');\r\n\r\n          this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());\r\n\r\n          this.cdr.markForCheck();\r\n\r\n          const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval\r\n\r\n          /*\r\n          this.dialogService.createNew(\r\n            EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,\r\n            undefined,\r\n            undefined,\r\n            undefined,\r\n            EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,\r\n            [\r\n              \"shiftId: \" + this.workShiftDndService.draggingShift$.value?.id,\r\n              \"shiftCode: \" + this.workShiftDndService.draggingShift$.value?.code,\r\n              \"dragoverCellId: \" + this.workShiftDndService.dragoverCellId$.value,\r\n              \"**************\",\r\n              \"WHATEVER LOGIC CAN BE ADDED WITH (onDrop) @Output() AND USING WorkShiftDndService\"\r\n            ]\r\n          )\r\n          */\r\n\r\n          this.onDropStream$.next(this.shiftCellId)\r\n\r\n          // Handle drop logic based on data\r\n          if (data) {\r\n            // Process dropped data here\r\n            const newShifts = this.$shifts();\r\n            newShifts.push(\r\n              {\r\n                ...this.workShiftDndService.draggingShift$.value!,\r\n                pending: true,\r\n              }\r\n            )\r\n            this.$shifts.set(newShifts);\r\n          }\r\n        });\r\n\r\n      });\r\n\r\n      this.dndEventSubscriptions.dragleave = dragleaveEvent.subscribe((ev: any) => {\r\n        ev.preventDefault();\r\n        if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId) return\r\n        this.dragElements.delete(ev.target as EventTarget);\r\n        if (this.dragElements.size === 0) {\r\n          containerElement.classList.remove('valid-drop');\r\n        }\r\n        this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());\r\n        this.cdr.markForCheck();\r\n\r\n        this.dndEventSubscriptions.dragover?.unsubscribe();\r\n        this.dndEventSubscriptions.drop?.unsubscribe();\r\n\r\n        this.dndEventSubscriptions.dragover = undefined;\r\n        this.dndEventSubscriptions.drop = undefined;\r\n\r\n      });\r\n\r\n    });\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-shift-cell-container\">\r\n    @for (shift of $shifts(); track $index) {\r\n        <core-shift-sticker [$shift]=\"shift\" [$shiftCellId]=\"shiftCellId\" [$width]=\"228\"></core-shift-sticker>\r\n    }\r\n</div>\r\n"]}
@@ -24034,13 +24034,12 @@ class CoreShiftCellComponent extends CoreFormControlBaseComponent {
24034
24034
  // Handle drop logic based on data
24035
24035
  if (data) {
24036
24036
  // Process dropped data here
24037
- this.$shifts.update(x => {
24038
- x.push({
24039
- ...this.workShiftDndService.draggingShift$.value,
24040
- pending: true,
24041
- });
24042
- return x;
24037
+ const newShifts = this.$shifts();
24038
+ newShifts.push({
24039
+ ...this.workShiftDndService.draggingShift$.value,
24040
+ pending: true,
24043
24041
  });
24042
+ this.$shifts.set(newShifts);
24044
24043
  }
24045
24044
  });
24046
24045
  });