ngx-histaff-alpha 3.3.7 → 3.3.9
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.
- package/esm2022/lib/app/interfaces/time-management/IAtShift.mjs +1 -1
- package/esm2022/lib/app/libraries/core-shift-cell/core-shift-cell.component.mjs +19 -5
- package/esm2022/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.mjs +4 -3
- package/fesm2022/ngx-histaff-alpha.mjs +21 -5
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/interfaces/time-management/IAtShift.d.ts +1 -0
- package/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUF0U2hpZnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9pbnRlcmZhY2VzL3RpbWUtbWFuYWdlbWVudC9JQXRTaGlmdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUF0U3ltYm9sIH0gZnJvbSBcIi4vSUF0U3ltYm9sXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElBdFNoaWZ0IHtcclxuICAgIGlkPzogbnVtYmVyO1xyXG4gICAgY29kZTogc3RyaW5nO1xyXG4gICAgbmFtZTogc3RyaW5nO1xyXG4gICAgc3ltYm9sOiBJQXRTeW1ib2w7XHJcbiAgICBob3Vyc1N0YXJ0OiBEYXRlO1xyXG4gICAgaG91cnNTdG9wOiBEYXRlO1xyXG4gICAgYnJlYWtzRnJvbT86IERhdGU7XHJcbiAgICBicmVha3NUbz86IERhdGU7XHJcbiAgICB0aW1lTGF0ZT86IG51bWJlcjtcclxuICAgIHRpbWVFYXJseT86IG51bWJlcjtcclxuICAgIGlzQWN0aXZlPzogYm9vbGVhbjtcclxuICAgIHRpbWVTdGFydD86IERhdGU7XHJcbiAgICB0aW1lU3RvcD86IERhdGU7XHJcbiAgICBtaW5Ib3Vyc1dvcms/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUF0U2hpZnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9pbnRlcmZhY2VzL3RpbWUtbWFuYWdlbWVudC9JQXRTaGlmdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUF0U3ltYm9sIH0gZnJvbSBcIi4vSUF0U3ltYm9sXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElBdFNoaWZ0IHtcclxuICAgIGlkPzogbnVtYmVyO1xyXG4gICAgY29kZTogc3RyaW5nO1xyXG4gICAgbmFtZTogc3RyaW5nO1xyXG4gICAgc3ltYm9sOiBJQXRTeW1ib2w7XHJcbiAgICBob3Vyc1N0YXJ0OiBEYXRlO1xyXG4gICAgaG91cnNTdG9wOiBEYXRlO1xyXG4gICAgYnJlYWtzRnJvbT86IERhdGU7XHJcbiAgICBicmVha3NUbz86IERhdGU7XHJcbiAgICB0aW1lTGF0ZT86IG51bWJlcjtcclxuICAgIHRpbWVFYXJseT86IG51bWJlcjtcclxuICAgIGlzQWN0aXZlPzogYm9vbGVhbjtcclxuICAgIHRpbWVTdGFydD86IERhdGU7XHJcbiAgICB0aW1lU3RvcD86IERhdGU7XHJcbiAgICBtaW5Ib3Vyc1dvcms/OiBudW1iZXI7ICAgIFxyXG4gICAgcGVuZGluZz86IGJvb2xlYW47XHJcbn0iXX0=
|
|
@@ -3,7 +3,6 @@ import { CoreShiftStickerComponent } from '../core-shift-sticker/core-shift-stic
|
|
|
3
3
|
import { BehaviorSubject, debounceTime, filter, fromEvent, Subscription } from 'rxjs';
|
|
4
4
|
import { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';
|
|
5
5
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
6
|
-
import { EnumTranslateKey } from 'alpha-global-constants';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
import * as i1 from "../../services/work-shift-dnd.service";
|
|
9
8
|
import * as i2 from "../../services/dialog.service";
|
|
@@ -101,18 +100,33 @@ export class CoreShiftCellComponent extends CoreFormControlBaseComponent {
|
|
|
101
100
|
this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
102
101
|
this.cdr.markForCheck();
|
|
103
102
|
const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval
|
|
104
|
-
|
|
103
|
+
/*
|
|
104
|
+
this.dialogService.createNew(
|
|
105
|
+
EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,
|
|
106
|
+
undefined,
|
|
107
|
+
undefined,
|
|
108
|
+
undefined,
|
|
109
|
+
EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,
|
|
110
|
+
[
|
|
105
111
|
"shiftId: " + this.workShiftDndService.draggingShift$.value?.id,
|
|
106
112
|
"shiftCode: " + this.workShiftDndService.draggingShift$.value?.code,
|
|
107
113
|
"dragoverCellId: " + this.workShiftDndService.dragoverCellId$.value,
|
|
108
114
|
"**************",
|
|
109
115
|
"WHATEVER LOGIC CAN BE ADDED WITH (onDrop) @Output() AND USING WorkShiftDndService"
|
|
110
|
-
|
|
116
|
+
]
|
|
117
|
+
)
|
|
118
|
+
*/
|
|
111
119
|
this.onDropStream$.next(this.shiftCellId);
|
|
112
120
|
// Handle drop logic based on data
|
|
113
121
|
if (data) {
|
|
114
122
|
// Process dropped data here
|
|
115
|
-
|
|
123
|
+
this.$shifts.update(x => {
|
|
124
|
+
x.push({
|
|
125
|
+
...this.workShiftDndService.draggingShift$.value,
|
|
126
|
+
pending: true,
|
|
127
|
+
});
|
|
128
|
+
return x;
|
|
129
|
+
});
|
|
116
130
|
}
|
|
117
131
|
});
|
|
118
132
|
});
|
|
@@ -156,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
156
170
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.WorkShiftDndService }, { type: i2.DialogService }], propDecorators: { onDrop: [{
|
|
157
171
|
type: Output
|
|
158
172
|
}] } });
|
|
159
|
-
//# 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          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          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            console.log('Dropped data:', data);\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"]}
|
|
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"]}
|
|
@@ -34,6 +34,7 @@ export class CoreShiftStickerComponent extends BaseComponent {
|
|
|
34
34
|
this.$isHaveSal = computed(() => this.$shift().symbol.isHaveSal);
|
|
35
35
|
this.$isInsArising = computed(() => this.$shift().symbol.isInsArising);
|
|
36
36
|
this.$duration = computed(() => (!!this.$hoursStart() && !!this.$hoursStop()) ? (this.$hoursStop().getTime() - this.$hoursStart().getTime()) / 1000 / 60 / 60 : undefined);
|
|
37
|
+
this.$pending = computed(() => this.$shift().pending);
|
|
37
38
|
// Dynamic style property
|
|
38
39
|
this.height = '36.59px';
|
|
39
40
|
this.borderRadius = '2px';
|
|
@@ -86,7 +87,7 @@ export class CoreShiftStickerComponent extends BaseComponent {
|
|
|
86
87
|
});
|
|
87
88
|
}
|
|
88
89
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftStickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
89
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftStickerComponent, isStandalone: true, selector: "core-shift-sticker", inputs: { $shift: { classPropertyName: "$shift", publicName: "$shift", isSignal: true, isRequired: true, transformFunction: null }, $shiftCellId: { classPropertyName: "$shiftCellId", publicName: "$shiftCellId", isSignal: true, isRequired: true, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: false, isRequired: false, transformFunction: null }, $height: { classPropertyName: "$height", publicName: "$height", isSignal: true, isRequired: false, transformFunction: null }, $width: { classPropertyName: "$width", publicName: "$width", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "$shiftDetails", first: true, predicate: ["shiftDetails"], descendants: true, isSignal: true }, { propertyName: "$check", first: true, predicate: ["check"], descendants: true, isSignal: true }, { propertyName: "$plus", first: true, predicate: ["plus"], descendants: true, isSignal: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [
|
|
90
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftStickerComponent, isStandalone: true, selector: "core-shift-sticker", inputs: { $shift: { classPropertyName: "$shift", publicName: "$shift", isSignal: true, isRequired: true, transformFunction: null }, $shiftCellId: { classPropertyName: "$shiftCellId", publicName: "$shiftCellId", isSignal: true, isRequired: true, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: false, isRequired: false, transformFunction: null }, $height: { classPropertyName: "$height", publicName: "$height", isSignal: true, isRequired: false, transformFunction: null }, $width: { classPropertyName: "$width", publicName: "$width", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "$shiftDetails", first: true, predicate: ["shiftDetails"], descendants: true, isSignal: true }, { propertyName: "$check", first: true, predicate: ["check"], descendants: true, isSignal: true }, { propertyName: "$plus", first: true, predicate: ["plus"], descendants: true, isSignal: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [class.checked]=\"checked\" [class.pending]=\"$pending()\">\r\n <div #check class=\"check p-absolute\">\r\n <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n </div>\r\n <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM \u2022 2h\"\r\n ng-class=\"{'icon-on-right': !event.showBigIcon && event.rrule && event.type !== 'availability'}\">\r\n {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} \u2022\r\n {{ $duration() }}\r\n </div>\r\n <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon && event.summary}\">\r\n <span>\r\n {{ $symbolCode() }} \u2022\r\n\r\n @if ($isOff()) {\r\n <i class=\"fas fa-plug-circle-minus\"></i>\r\n }\r\n @if ($isHolidayCal()) {\r\n <i class=\"fas fa-champagne-glasses\"></i>\r\n }\r\n @if ($isHaveSal()) {\r\n <i class=\"fas fa-sack-dollar\"></i>\r\n }\r\n @if ($isInsArising()) {\r\n <i class=\"fas fa-car-burst\"></i>\r\n }\r\n </span>\r\n </div>\r\n\r\n <div #plus class=\"plus p-absolute\">\r\n <i class=\"feather-plus\"></i>\r\n </div>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-shift-sticker-container{--height: 36.59px;--width: 228px;--border: none;--opacity: 1;--color: white;--background-color: box-sizing: border-box;min-width:105px;max-width:228px;opacity:var(--opacity);border:var(--border)}.core-shift-sticker-container *{box-sizing:border-box}.core-shift-sticker-container .shift-details{padding:4px 6px;font-size:11px;line-height:1.3;width:100%;border-radius:2px;color:var(--color);background-color:var(--background-color)}.core-shift-sticker-container .shift-details .first-line{height:14.3px;font-weight:600}.core-shift-sticker-container .shift-details .second-line{height:14.3;font-weight:400}.core-shift-sticker-container .shift-details.checked{border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container .shift-details.checked .check{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .shift-details.pending{color:gray;background-color:#fff;border:3px solid dashed}.core-shift-sticker-container:hover{opacity:.8}.core-shift-sticker-container:hover .shift-details{width:calc(100% - var(--height) - 2px);border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container:hover .shift-details .check,.core-shift-sticker-container:hover .shift-details .plus{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .check,.core-shift-sticker-container .plus{width:var(--height);height:var(--height);top:0;display:none}.core-shift-sticker-container .check{left:0}.core-shift-sticker-container .plus{font-size:24px;border:solid 2px #646464;border-radius:2px;right:calc(var(--height) * -1 - 2px);color:#646464}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: TableCellPipe, name: "tableCell" }, { kind: "component", type: CoreCheckboxComponent, selector: "core-checkbox", inputs: ["text", "tooltipPosition", "tooltip", "inputValue", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
90
91
|
}
|
|
91
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftStickerComponent, decorators: [{
|
|
92
93
|
type: Component,
|
|
@@ -97,8 +98,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
97
98
|
TableCellPipe,
|
|
98
99
|
CoreCheckboxComponent,
|
|
99
100
|
FormsModule
|
|
100
|
-
], template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [
|
|
101
|
+
], template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [class.checked]=\"checked\" [class.pending]=\"$pending()\">\r\n <div #check class=\"check p-absolute\">\r\n <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n </div>\r\n <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM \u2022 2h\"\r\n ng-class=\"{'icon-on-right': !event.showBigIcon && event.rrule && event.type !== 'availability'}\">\r\n {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} \u2022\r\n {{ $duration() }}\r\n </div>\r\n <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon && event.summary}\">\r\n <span>\r\n {{ $symbolCode() }} \u2022\r\n\r\n @if ($isOff()) {\r\n <i class=\"fas fa-plug-circle-minus\"></i>\r\n }\r\n @if ($isHolidayCal()) {\r\n <i class=\"fas fa-champagne-glasses\"></i>\r\n }\r\n @if ($isHaveSal()) {\r\n <i class=\"fas fa-sack-dollar\"></i>\r\n }\r\n @if ($isInsArising()) {\r\n <i class=\"fas fa-car-burst\"></i>\r\n }\r\n </span>\r\n </div>\r\n\r\n <div #plus class=\"plus p-absolute\">\r\n <i class=\"feather-plus\"></i>\r\n </div>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-shift-sticker-container{--height: 36.59px;--width: 228px;--border: none;--opacity: 1;--color: white;--background-color: box-sizing: border-box;min-width:105px;max-width:228px;opacity:var(--opacity);border:var(--border)}.core-shift-sticker-container *{box-sizing:border-box}.core-shift-sticker-container .shift-details{padding:4px 6px;font-size:11px;line-height:1.3;width:100%;border-radius:2px;color:var(--color);background-color:var(--background-color)}.core-shift-sticker-container .shift-details .first-line{height:14.3px;font-weight:600}.core-shift-sticker-container .shift-details .second-line{height:14.3;font-weight:400}.core-shift-sticker-container .shift-details.checked{border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container .shift-details.checked .check{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .shift-details.pending{color:gray;background-color:#fff;border:3px solid dashed}.core-shift-sticker-container:hover{opacity:.8}.core-shift-sticker-container:hover .shift-details{width:calc(100% - var(--height) - 2px);border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container:hover .shift-details .check,.core-shift-sticker-container:hover .shift-details .plus{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .check,.core-shift-sticker-container .plus{width:var(--height);height:var(--height);top:0;display:none}.core-shift-sticker-container .check{left:0}.core-shift-sticker-container .plus{font-size:24px;border:solid 2px #646464;border-radius:2px;right:calc(var(--height) * -1 - 2px);color:#646464}\n"] }]
|
|
101
102
|
}], propDecorators: { checked: [{
|
|
102
103
|
type: Input
|
|
103
104
|
}] } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-shift-sticker.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, ElementRef, inject, input, Input, OnChanges, OnInit, signal, SimpleChanges, viewChild, WritableSignal } from '@angular/core';\r\nimport { IAtShift } from '../../interfaces/time-management/IAtShift';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { NgStyle } from '@angular/common';\r\nimport { CoreCheckboxComponent } from '../core-checkbox/core-checkbox/core-checkbox.component';\r\nimport { debounceTime, fromEvent, Observable } from 'rxjs';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { WorkShiftDndService } from '../../services/work-shift-dnd.service';\r\n\r\n@Component({\r\n  selector: 'core-shift-sticker',\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    NgStyle,\r\n    TranslatePipe,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    CoreCheckboxComponent,\r\n    FormsModule\r\n  ],\r\n  templateUrl: './core-shift-sticker.component.html',\r\n  styleUrl: './core-shift-sticker.component.scss'\r\n})\r\nexport class CoreShiftStickerComponent extends BaseComponent implements OnChanges, OnInit, AfterViewInit {\r\n\r\n  $container = viewChild<ElementRef>('container');\r\n  $shiftDetails = viewChild<ElementRef>('shiftDetails');\r\n  $check = viewChild<ElementRef>('check');\r\n  $plus = viewChild<ElementRef>('plus');\r\n\r\n  $shift = input.required<IAtShift>();\r\n  $shiftCellId = input.required<string>()\r\n\r\n  cdr = inject(ChangeDetectorRef);\r\n  workShiftDndService = inject(WorkShiftDndService);\r\n\r\n  @Input() checked!: boolean;\r\n\r\n  $height = input<number>(36.59);\r\n  $width = input<number>();\r\n\r\n  $code = computed(() => this.$shift().code);\r\n  $name = computed(() => this.$shift().name);\r\n  $hoursStart = computed(() => new Date(this.$shift().hoursStart));\r\n  $hoursStop = computed(() => new Date(this.$shift().hoursStop));\r\n  $symbolCode = computed(() => this.$shift().symbol.code);\r\n  $symbolName = computed(() => this.$shift().symbol.name);\r\n  $isOff = computed(() => this.$shift().symbol.isOff);\r\n  $isHolidayCal = computed(() => this.$shift().symbol.isHolidayCal);\r\n  $isHaveSal = computed(() => this.$shift().symbol.isHaveSal);\r\n  $isInsArising = computed(() => this.$shift().symbol.isInsArising);\r\n  $duration = computed(() => (!!this.$hoursStart() && !!this.$hoursStop()) ? (this.$hoursStop().getTime() - this.$hoursStart().getTime()) / 1000 / 60 / 60 : undefined)\r\n\r\n  // Dynamic style property\r\n  height: string = '36.59px';\r\n  borderRadius: string = '2px';\r\n  fontSize: string = '11px';\r\n  lineHeight: number = 1.3;\r\n  firstLinefontWeight: number = 600;\r\n  cursor: string = 'pointer';\r\n  padding: string = '4px 6px';\r\n  color: string = 'white';\r\n  backgroundColor: string = '#F76B6A';\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!changes['checked']) {\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'dragstart')\r\n        .subscribe((ev: any) => {\r\n          ev.dataTransfer.setData(\"text/plain\", `${this.$shiftCellId()}:${this.$shift().code}`);\r\n          this.workShiftDndService.draggingData$.next(ev.dataTransfer.getData(\"text/plain\"));\r\n          this.workShiftDndService.draggingShift$.next(this.$shift());\r\n          this.workShiftDndService.draggingFromCellId$.next(this.$shiftCellId());\r\n          this.$shiftDetails()?.nativeElement.style.setProperty('width', '100%');\r\n          this.$shiftDetails()?.nativeElement.style.setProperty('padding-left', '6px');\r\n          this.$check()?.nativeElement.style.setProperty('display', 'none');\r\n          this.$plus()?.nativeElement.style.setProperty('display', 'none');\r\n        })\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'drag')\r\n        .pipe(\r\n          debounceTime(200)\r\n        )\r\n        .subscribe((ev: any) => {\r\n\r\n        })\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'dragend')\r\n        .subscribe((ev: any) => {\r\n          // According to the HTML5 Drag and Drop API, \r\n          // dataTransfer is cleared or reset at the end of the drag operation. \r\n          // This means that the data you set in dragstart is no longer available in dragend.\r\n          this.workShiftDndService.draggingData$.next('');\r\n          this.workShiftDndService.draggingShift$.next(undefined);\r\n          this.workShiftDndService.draggingFromCellId$.next('')\r\n          this.$shiftDetails()?.nativeElement.style.removeProperty('width');\r\n          this.$shiftDetails()?.nativeElement.style.removeProperty('padding-left');\r\n          this.$check()?.nativeElement.style.removeProperty('display');\r\n          this.$plus()?.nativeElement.style.removeProperty('display');\r\n        })\r\n    })\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n    position: 'relative',\r\n    height,\r\n    fontSize,\r\n    cursor,\r\n    width: $width() + 'px',\r\n    margin: '2px'\r\n}\" draggable=\"true\">\r\n    <div #shiftDetails class=\"shift-details p-relative\" [ngStyle]=\"{\r\n        color,\r\n        backgroundColor\r\n    }\" [class.checked]=\"checked\">\r\n        <div #check class=\"check p-absolute\">\r\n            <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n        </div>\r\n        <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM • 2h\"\r\n            ng-class=\"{'icon-on-right': !event.showBigIcon &amp;&amp; event.rrule &amp;&amp; event.type !== 'availability'}\">\r\n            {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} •\r\n            {{ $duration() }}\r\n        </div>\r\n        <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon &amp;&amp; event.summary}\">\r\n            <span>\r\n                {{ $symbolCode() }} •\r\n\r\n                @if ($isOff()) {\r\n                <i class=\"fas fa-plug-circle-minus\"></i>\r\n                }\r\n                @if ($isHolidayCal()) {\r\n                <i class=\"fas fa-champagne-glasses\"></i>\r\n                }\r\n                @if ($isHaveSal()) {\r\n                <i class=\"fas fa-sack-dollar\"></i>\r\n                }\r\n                @if ($isInsArising()) {\r\n                <i class=\"fas fa-car-burst\"></i>\r\n                }\r\n            </span>\r\n        </div>\r\n\r\n        <div #plus class=\"plus p-absolute\">\r\n            <i class=\"feather-plus\"></i>\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-shift-sticker.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, computed, ElementRef, inject, input, Input, OnChanges, OnInit, signal, SimpleChanges, viewChild, WritableSignal } from '@angular/core';\r\nimport { IAtShift } from '../../interfaces/time-management/IAtShift';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { NgStyle } from '@angular/common';\r\nimport { CoreCheckboxComponent } from '../core-checkbox/core-checkbox/core-checkbox.component';\r\nimport { debounceTime, fromEvent, Observable } from 'rxjs';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { WorkShiftDndService } from '../../services/work-shift-dnd.service';\r\n\r\n@Component({\r\n  selector: 'core-shift-sticker',\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    NgStyle,\r\n    TranslatePipe,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    CoreCheckboxComponent,\r\n    FormsModule\r\n  ],\r\n  templateUrl: './core-shift-sticker.component.html',\r\n  styleUrl: './core-shift-sticker.component.scss'\r\n})\r\nexport class CoreShiftStickerComponent extends BaseComponent implements OnChanges, OnInit, AfterViewInit {\r\n\r\n  $container = viewChild<ElementRef>('container');\r\n  $shiftDetails = viewChild<ElementRef>('shiftDetails');\r\n  $check = viewChild<ElementRef>('check');\r\n  $plus = viewChild<ElementRef>('plus');\r\n\r\n  $shift = input.required<IAtShift>();\r\n  $shiftCellId = input.required<string>()\r\n\r\n  cdr = inject(ChangeDetectorRef);\r\n  workShiftDndService = inject(WorkShiftDndService);\r\n\r\n  @Input() checked!: boolean;\r\n\r\n  $height = input<number>(36.59);\r\n  $width = input<number>();\r\n\r\n  $code = computed(() => this.$shift().code);\r\n  $name = computed(() => this.$shift().name);\r\n  $hoursStart = computed(() => new Date(this.$shift().hoursStart));\r\n  $hoursStop = computed(() => new Date(this.$shift().hoursStop));\r\n  $symbolCode = computed(() => this.$shift().symbol.code);\r\n  $symbolName = computed(() => this.$shift().symbol.name);\r\n  $isOff = computed(() => this.$shift().symbol.isOff);\r\n  $isHolidayCal = computed(() => this.$shift().symbol.isHolidayCal);\r\n  $isHaveSal = computed(() => this.$shift().symbol.isHaveSal);\r\n  $isInsArising = computed(() => this.$shift().symbol.isInsArising);\r\n  $duration = computed(() => (!!this.$hoursStart() && !!this.$hoursStop()) ? (this.$hoursStop().getTime() - this.$hoursStart().getTime()) / 1000 / 60 / 60 : undefined)\r\n  $pending = computed(() => this.$shift().pending);\r\n\r\n  // Dynamic style property\r\n  height: string = '36.59px';\r\n  borderRadius: string = '2px';\r\n  fontSize: string = '11px';\r\n  lineHeight: number = 1.3;\r\n  firstLinefontWeight: number = 600;\r\n  cursor: string = 'pointer';\r\n  padding: string = '4px 6px';\r\n  color: string = 'white';\r\n  backgroundColor: string = '#F76B6A';\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!changes['checked']) {\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'dragstart')\r\n        .subscribe((ev: any) => {\r\n          ev.dataTransfer.setData(\"text/plain\", `${this.$shiftCellId()}:${this.$shift().code}`);\r\n          this.workShiftDndService.draggingData$.next(ev.dataTransfer.getData(\"text/plain\"));\r\n          this.workShiftDndService.draggingShift$.next(this.$shift());\r\n          this.workShiftDndService.draggingFromCellId$.next(this.$shiftCellId());\r\n          this.$shiftDetails()?.nativeElement.style.setProperty('width', '100%');\r\n          this.$shiftDetails()?.nativeElement.style.setProperty('padding-left', '6px');\r\n          this.$check()?.nativeElement.style.setProperty('display', 'none');\r\n          this.$plus()?.nativeElement.style.setProperty('display', 'none');\r\n        })\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'drag')\r\n        .pipe(\r\n          debounceTime(200)\r\n        )\r\n        .subscribe((ev: any) => {\r\n\r\n        })\r\n\r\n      fromEvent(this.$container()?.nativeElement, 'dragend')\r\n        .subscribe((ev: any) => {\r\n          // According to the HTML5 Drag and Drop API, \r\n          // dataTransfer is cleared or reset at the end of the drag operation. \r\n          // This means that the data you set in dragstart is no longer available in dragend.\r\n          this.workShiftDndService.draggingData$.next('');\r\n          this.workShiftDndService.draggingShift$.next(undefined);\r\n          this.workShiftDndService.draggingFromCellId$.next('')\r\n          this.$shiftDetails()?.nativeElement.style.removeProperty('width');\r\n          this.$shiftDetails()?.nativeElement.style.removeProperty('padding-left');\r\n          this.$check()?.nativeElement.style.removeProperty('display');\r\n          this.$plus()?.nativeElement.style.removeProperty('display');\r\n        })\r\n    })\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n    position: 'relative',\r\n    height,\r\n    fontSize,\r\n    cursor,\r\n    width: $width() + 'px',\r\n    margin: '2px'\r\n}\" draggable=\"true\">\r\n    <div #shiftDetails class=\"shift-details p-relative\" [class.checked]=\"checked\" [class.pending]=\"$pending()\">\r\n        <div #check class=\"check p-absolute\">\r\n            <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n        </div>\r\n        <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM • 2h\"\r\n            ng-class=\"{'icon-on-right': !event.showBigIcon &amp;&amp; event.rrule &amp;&amp; event.type !== 'availability'}\">\r\n            {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} •\r\n            {{ $duration() }}\r\n        </div>\r\n        <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon &amp;&amp; event.summary}\">\r\n            <span>\r\n                {{ $symbolCode() }} •\r\n\r\n                @if ($isOff()) {\r\n                <i class=\"fas fa-plug-circle-minus\"></i>\r\n                }\r\n                @if ($isHolidayCal()) {\r\n                <i class=\"fas fa-champagne-glasses\"></i>\r\n                }\r\n                @if ($isHaveSal()) {\r\n                <i class=\"fas fa-sack-dollar\"></i>\r\n                }\r\n                @if ($isInsArising()) {\r\n                <i class=\"fas fa-car-burst\"></i>\r\n                }\r\n            </span>\r\n        </div>\r\n\r\n        <div #plus class=\"plus p-absolute\">\r\n            <i class=\"feather-plus\"></i>\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -23851,6 +23851,7 @@ class CoreShiftStickerComponent extends BaseComponent {
|
|
|
23851
23851
|
this.$isHaveSal = computed(() => this.$shift().symbol.isHaveSal);
|
|
23852
23852
|
this.$isInsArising = computed(() => this.$shift().symbol.isInsArising);
|
|
23853
23853
|
this.$duration = computed(() => (!!this.$hoursStart() && !!this.$hoursStop()) ? (this.$hoursStop().getTime() - this.$hoursStart().getTime()) / 1000 / 60 / 60 : undefined);
|
|
23854
|
+
this.$pending = computed(() => this.$shift().pending);
|
|
23854
23855
|
// Dynamic style property
|
|
23855
23856
|
this.height = '36.59px';
|
|
23856
23857
|
this.borderRadius = '2px';
|
|
@@ -23903,7 +23904,7 @@ class CoreShiftStickerComponent extends BaseComponent {
|
|
|
23903
23904
|
});
|
|
23904
23905
|
}
|
|
23905
23906
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftStickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
23906
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftStickerComponent, isStandalone: true, selector: "core-shift-sticker", inputs: { $shift: { classPropertyName: "$shift", publicName: "$shift", isSignal: true, isRequired: true, transformFunction: null }, $shiftCellId: { classPropertyName: "$shiftCellId", publicName: "$shiftCellId", isSignal: true, isRequired: true, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: false, isRequired: false, transformFunction: null }, $height: { classPropertyName: "$height", publicName: "$height", isSignal: true, isRequired: false, transformFunction: null }, $width: { classPropertyName: "$width", publicName: "$width", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "$shiftDetails", first: true, predicate: ["shiftDetails"], descendants: true, isSignal: true }, { propertyName: "$check", first: true, predicate: ["check"], descendants: true, isSignal: true }, { propertyName: "$plus", first: true, predicate: ["plus"], descendants: true, isSignal: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [
|
|
23907
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftStickerComponent, isStandalone: true, selector: "core-shift-sticker", inputs: { $shift: { classPropertyName: "$shift", publicName: "$shift", isSignal: true, isRequired: true, transformFunction: null }, $shiftCellId: { classPropertyName: "$shiftCellId", publicName: "$shiftCellId", isSignal: true, isRequired: true, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: false, isRequired: false, transformFunction: null }, $height: { classPropertyName: "$height", publicName: "$height", isSignal: true, isRequired: false, transformFunction: null }, $width: { classPropertyName: "$width", publicName: "$width", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "$shiftDetails", first: true, predicate: ["shiftDetails"], descendants: true, isSignal: true }, { propertyName: "$check", first: true, predicate: ["check"], descendants: true, isSignal: true }, { propertyName: "$plus", first: true, predicate: ["plus"], descendants: true, isSignal: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [class.checked]=\"checked\" [class.pending]=\"$pending()\">\r\n <div #check class=\"check p-absolute\">\r\n <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n </div>\r\n <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM \u2022 2h\"\r\n ng-class=\"{'icon-on-right': !event.showBigIcon && event.rrule && event.type !== 'availability'}\">\r\n {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} \u2022\r\n {{ $duration() }}\r\n </div>\r\n <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon && event.summary}\">\r\n <span>\r\n {{ $symbolCode() }} \u2022\r\n\r\n @if ($isOff()) {\r\n <i class=\"fas fa-plug-circle-minus\"></i>\r\n }\r\n @if ($isHolidayCal()) {\r\n <i class=\"fas fa-champagne-glasses\"></i>\r\n }\r\n @if ($isHaveSal()) {\r\n <i class=\"fas fa-sack-dollar\"></i>\r\n }\r\n @if ($isInsArising()) {\r\n <i class=\"fas fa-car-burst\"></i>\r\n }\r\n </span>\r\n </div>\r\n\r\n <div #plus class=\"plus p-absolute\">\r\n <i class=\"feather-plus\"></i>\r\n </div>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-shift-sticker-container{--height: 36.59px;--width: 228px;--border: none;--opacity: 1;--color: white;--background-color: box-sizing: border-box;min-width:105px;max-width:228px;opacity:var(--opacity);border:var(--border)}.core-shift-sticker-container *{box-sizing:border-box}.core-shift-sticker-container .shift-details{padding:4px 6px;font-size:11px;line-height:1.3;width:100%;border-radius:2px;color:var(--color);background-color:var(--background-color)}.core-shift-sticker-container .shift-details .first-line{height:14.3px;font-weight:600}.core-shift-sticker-container .shift-details .second-line{height:14.3;font-weight:400}.core-shift-sticker-container .shift-details.checked{border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container .shift-details.checked .check{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .shift-details.pending{color:gray;background-color:#fff;border:3px solid dashed}.core-shift-sticker-container:hover{opacity:.8}.core-shift-sticker-container:hover .shift-details{width:calc(100% - var(--height) - 2px);border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container:hover .shift-details .check,.core-shift-sticker-container:hover .shift-details .plus{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .check,.core-shift-sticker-container .plus{width:var(--height);height:var(--height);top:0;display:none}.core-shift-sticker-container .check{left:0}.core-shift-sticker-container .plus{font-size:24px;border:solid 2px #646464;border-radius:2px;right:calc(var(--height) * -1 - 2px);color:#646464}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: TableCellPipe, name: "tableCell" }, { kind: "component", type: CoreCheckboxComponent, selector: "core-checkbox", inputs: ["text", "tooltipPosition", "tooltip", "inputValue", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
23907
23908
|
}
|
|
23908
23909
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftStickerComponent, decorators: [{
|
|
23909
23910
|
type: Component,
|
|
@@ -23914,7 +23915,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
23914
23915
|
TableCellPipe,
|
|
23915
23916
|
CoreCheckboxComponent,
|
|
23916
23917
|
FormsModule
|
|
23917
|
-
], template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [
|
|
23918
|
+
], template: "<div #container class=\"core-shift-sticker-container d-flex d-flex-between open-font\" [ngStyle]=\"{\r\n position: 'relative',\r\n height,\r\n fontSize,\r\n cursor,\r\n width: $width() + 'px',\r\n margin: '2px'\r\n}\" draggable=\"true\">\r\n <div #shiftDetails class=\"shift-details p-relative\" [class.checked]=\"checked\" [class.pending]=\"$pending()\">\r\n <div #check class=\"check p-absolute\">\r\n <core-checkbox [(ngModel)]=\"checked\"></core-checkbox>\r\n </div>\r\n <div class=\"ellipsis p-relative first-line\" title=\"9:00 AM - 11:00 AM \u2022 2h\"\r\n ng-class=\"{'icon-on-right': !event.showBigIcon && event.rrule && event.type !== 'availability'}\">\r\n {{ $hoursStart() | tableCell : 'TIME_HHMM' : lang }} - {{ $hoursStop() | tableCell : 'TIME_HHMM' : lang }} \u2022\r\n {{ $duration() }}\r\n </div>\r\n <div class=\"ellipsis second-line\" ng-class=\"{'icon-on-right': !event.showBigIcon && event.summary}\">\r\n <span>\r\n {{ $symbolCode() }} \u2022\r\n\r\n @if ($isOff()) {\r\n <i class=\"fas fa-plug-circle-minus\"></i>\r\n }\r\n @if ($isHolidayCal()) {\r\n <i class=\"fas fa-champagne-glasses\"></i>\r\n }\r\n @if ($isHaveSal()) {\r\n <i class=\"fas fa-sack-dollar\"></i>\r\n }\r\n @if ($isInsArising()) {\r\n <i class=\"fas fa-car-burst\"></i>\r\n }\r\n </span>\r\n </div>\r\n\r\n <div #plus class=\"plus p-absolute\">\r\n <i class=\"feather-plus\"></i>\r\n </div>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-shift-sticker-container{--height: 36.59px;--width: 228px;--border: none;--opacity: 1;--color: white;--background-color: box-sizing: border-box;min-width:105px;max-width:228px;opacity:var(--opacity);border:var(--border)}.core-shift-sticker-container *{box-sizing:border-box}.core-shift-sticker-container .shift-details{padding:4px 6px;font-size:11px;line-height:1.3;width:100%;border-radius:2px;color:var(--color);background-color:var(--background-color)}.core-shift-sticker-container .shift-details .first-line{height:14.3px;font-weight:600}.core-shift-sticker-container .shift-details .second-line{height:14.3;font-weight:400}.core-shift-sticker-container .shift-details.checked{border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container .shift-details.checked .check{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .shift-details.pending{color:gray;background-color:#fff;border:3px solid dashed}.core-shift-sticker-container:hover{opacity:.8}.core-shift-sticker-container:hover .shift-details{width:calc(100% - var(--height) - 2px);border-top-right-radius:0;border-bottom-right-radius:0;padding-left:var(--height)}.core-shift-sticker-container:hover .shift-details .check,.core-shift-sticker-container:hover .shift-details .plus{display:flex;align-items:center;justify-content:center}.core-shift-sticker-container .check,.core-shift-sticker-container .plus{width:var(--height);height:var(--height);top:0;display:none}.core-shift-sticker-container .check{left:0}.core-shift-sticker-container .plus{font-size:24px;border:solid 2px #646464;border-radius:2px;right:calc(var(--height) * -1 - 2px);color:#646464}\n"] }]
|
|
23918
23919
|
}], propDecorators: { checked: [{
|
|
23919
23920
|
type: Input
|
|
23920
23921
|
}] } });
|
|
@@ -24013,18 +24014,33 @@ class CoreShiftCellComponent extends CoreFormControlBaseComponent {
|
|
|
24013
24014
|
this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
24014
24015
|
this.cdr.markForCheck();
|
|
24015
24016
|
const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval
|
|
24016
|
-
|
|
24017
|
+
/*
|
|
24018
|
+
this.dialogService.createNew(
|
|
24019
|
+
EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,
|
|
24020
|
+
undefined,
|
|
24021
|
+
undefined,
|
|
24022
|
+
undefined,
|
|
24023
|
+
EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION,
|
|
24024
|
+
[
|
|
24017
24025
|
"shiftId: " + this.workShiftDndService.draggingShift$.value?.id,
|
|
24018
24026
|
"shiftCode: " + this.workShiftDndService.draggingShift$.value?.code,
|
|
24019
24027
|
"dragoverCellId: " + this.workShiftDndService.dragoverCellId$.value,
|
|
24020
24028
|
"**************",
|
|
24021
24029
|
"WHATEVER LOGIC CAN BE ADDED WITH (onDrop) @Output() AND USING WorkShiftDndService"
|
|
24022
|
-
|
|
24030
|
+
]
|
|
24031
|
+
)
|
|
24032
|
+
*/
|
|
24023
24033
|
this.onDropStream$.next(this.shiftCellId);
|
|
24024
24034
|
// Handle drop logic based on data
|
|
24025
24035
|
if (data) {
|
|
24026
24036
|
// Process dropped data here
|
|
24027
|
-
|
|
24037
|
+
this.$shifts.update(x => {
|
|
24038
|
+
x.push({
|
|
24039
|
+
...this.workShiftDndService.draggingShift$.value,
|
|
24040
|
+
pending: true,
|
|
24041
|
+
});
|
|
24042
|
+
return x;
|
|
24043
|
+
});
|
|
24028
24044
|
}
|
|
24029
24045
|
});
|
|
24030
24046
|
});
|