ngx-histaff-alpha 3.3.5 → 3.3.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/app/libraries/core-shift-cell/core-shift-cell.component.mjs +64 -35
- package/esm2022/lib/app/libraries/core-table/core-table.component.mjs +5 -4
- package/fesm2022/ngx-histaff-alpha.mjs +64 -36
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/core-shift-cell/core-shift-cell.component.d.ts +15 -3
- package/package.json +1 -1
|
@@ -1,22 +1,32 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, input, viewChild, signal } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, input, viewChild, signal, Output, EventEmitter } from '@angular/core';
|
|
2
2
|
import { CoreShiftStickerComponent } from '../core-shift-sticker/core-shift-sticker.component';
|
|
3
|
-
import { fromEvent } from 'rxjs';
|
|
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';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../services/work-shift-dnd.service";
|
|
9
|
+
import * as i2 from "../../services/dialog.service";
|
|
8
10
|
export class CoreShiftCellComponent extends CoreFormControlBaseComponent {
|
|
9
11
|
writeValue(obj) {
|
|
10
12
|
this.$shifts.set(obj);
|
|
11
13
|
}
|
|
12
|
-
constructor(cdr, workShiftDndService) {
|
|
14
|
+
constructor(cdr, workShiftDndService, dialogService) {
|
|
13
15
|
super();
|
|
14
16
|
this.cdr = cdr;
|
|
15
17
|
this.workShiftDndService = workShiftDndService;
|
|
18
|
+
this.dialogService = dialogService;
|
|
19
|
+
this.onDrop = new EventEmitter();
|
|
16
20
|
this.$backgroundColor = input('white');
|
|
17
21
|
this.$container = viewChild('container');
|
|
18
22
|
this.shiftCellId = crypto.randomUUID();
|
|
19
23
|
this.dragElements = new Set();
|
|
24
|
+
this.dndEventSubscriptions = {
|
|
25
|
+
dragenter: new Subscription(() => null),
|
|
26
|
+
dragover: new Subscription(() => null),
|
|
27
|
+
drop: new Subscription(() => null),
|
|
28
|
+
dragleave: new Subscription(() => null)
|
|
29
|
+
};
|
|
20
30
|
this.$shifts = signal([
|
|
21
31
|
{
|
|
22
32
|
code: 'X',
|
|
@@ -52,68 +62,85 @@ export class CoreShiftCellComponent extends CoreFormControlBaseComponent {
|
|
|
52
62
|
hoursStop: new Date(2024, 7, 13, 17, 30, 0)
|
|
53
63
|
}
|
|
54
64
|
]);
|
|
65
|
+
this.onDropStream$ = new BehaviorSubject('');
|
|
55
66
|
}
|
|
56
67
|
ngAfterViewInit() {
|
|
57
68
|
setTimeout(() => {
|
|
69
|
+
this.onDropStream$.pipe(filter(x => !!x.length), debounceTime(500)).subscribe(x => {
|
|
70
|
+
this.onDrop.emit(true);
|
|
71
|
+
});
|
|
58
72
|
const containerElement = this.$container()?.nativeElement;
|
|
59
73
|
containerElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
60
74
|
this.cdr.markForCheck();
|
|
61
|
-
fromEvent(containerElement, 'dragenter')
|
|
75
|
+
const dragenterEvent = fromEvent(containerElement, 'dragenter');
|
|
76
|
+
const dragoverEvent = fromEvent(containerElement, 'dragover');
|
|
77
|
+
const dropEvent = fromEvent(containerElement, 'drop');
|
|
78
|
+
const dragleaveEvent = fromEvent(containerElement, 'dragleave');
|
|
79
|
+
this.dndEventSubscriptions.dragenter = dragenterEvent.subscribe((ev) => {
|
|
62
80
|
ev.preventDefault();
|
|
63
81
|
if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId)
|
|
64
82
|
return;
|
|
65
83
|
this.dragElements.add(ev.target);
|
|
66
84
|
containerElement.classList.add('valid-drop');
|
|
67
|
-
//containerElement.classList.remove('invalid-drop');
|
|
68
85
|
if (this.workShiftDndService.draggingData$.value.split(':')[0] !== this.shiftCellId) {
|
|
69
86
|
this.$container()?.nativeElement.style.setProperty('--background-color', '#fff4ce');
|
|
70
87
|
this.cdr.markForCheck();
|
|
71
88
|
}
|
|
89
|
+
// Subscribe to dragover event to allow drop
|
|
90
|
+
this.dndEventSubscriptions.dragover = dragoverEvent.subscribe((ev) => {
|
|
91
|
+
ev.preventDefault();
|
|
92
|
+
this.workShiftDndService.dragoverCellId$.next(this.shiftCellId);
|
|
93
|
+
});
|
|
94
|
+
// Subscribe to drop event
|
|
95
|
+
this.dndEventSubscriptions.drop = dropEvent.subscribe((ev) => {
|
|
96
|
+
ev.preventDefault();
|
|
97
|
+
if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId)
|
|
98
|
+
return;
|
|
99
|
+
this.dragElements.clear(); // Clear the set
|
|
100
|
+
containerElement.classList.remove('valid-drop');
|
|
101
|
+
this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
102
|
+
this.cdr.markForCheck();
|
|
103
|
+
const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval
|
|
104
|
+
this.dialogService.createNew(EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION, undefined, undefined, undefined, EnumTranslateKey.UI_GRID_FORM_BUTTON_INFORMATION, [
|
|
105
|
+
"shiftId: " + this.workShiftDndService.draggingShift$.value?.id,
|
|
106
|
+
"shiftCode: " + this.workShiftDndService.draggingShift$.value?.code,
|
|
107
|
+
"dragoverCellId: " + this.workShiftDndService.dragoverCellId$.value,
|
|
108
|
+
"**************",
|
|
109
|
+
"WHATEVER LOGIC CAN BE ADDED WITH (onDrop) @Output() AND USING WorkShiftDndService"
|
|
110
|
+
]);
|
|
111
|
+
this.onDropStream$.next(this.shiftCellId);
|
|
112
|
+
// Handle drop logic based on data
|
|
113
|
+
if (data) {
|
|
114
|
+
// Process dropped data here
|
|
115
|
+
console.log('Dropped data:', data);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
72
118
|
});
|
|
73
|
-
|
|
74
|
-
fromEvent(containerElement, 'dragover').subscribe((ev) => {
|
|
75
|
-
ev.preventDefault();
|
|
76
|
-
});
|
|
77
|
-
fromEvent(containerElement, 'dragleave')
|
|
78
|
-
.subscribe((ev) => {
|
|
119
|
+
this.dndEventSubscriptions.dragleave = dragleaveEvent.subscribe((ev) => {
|
|
79
120
|
ev.preventDefault();
|
|
80
121
|
if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId)
|
|
81
122
|
return;
|
|
82
123
|
this.dragElements.delete(ev.target);
|
|
83
124
|
if (this.dragElements.size === 0) {
|
|
84
125
|
containerElement.classList.remove('valid-drop');
|
|
85
|
-
//containerElement.classList.add('invalid-drop');
|
|
86
126
|
}
|
|
87
127
|
this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
88
128
|
this.cdr.markForCheck();
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
if (this.workShiftDndService.draggingFromCellId$.value === this.shiftCellId)
|
|
94
|
-
return;
|
|
95
|
-
this.dragElements.clear(); // Clear the set
|
|
96
|
-
//containerElement.classList.remove('valid-drop', 'invalid-drop');
|
|
97
|
-
containerElement.classList.remove('valid-drop');
|
|
98
|
-
this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());
|
|
99
|
-
this.cdr.markForCheck();
|
|
100
|
-
const data = ev.dataTransfer?.getData('text/plain'); // Example data retrieval
|
|
101
|
-
// Handle drop logic based on data
|
|
102
|
-
if (data) {
|
|
103
|
-
// Process dropped data here
|
|
104
|
-
console.log('Dropped data:', data);
|
|
105
|
-
}
|
|
129
|
+
this.dndEventSubscriptions.dragover?.unsubscribe();
|
|
130
|
+
this.dndEventSubscriptions.drop?.unsubscribe();
|
|
131
|
+
this.dndEventSubscriptions.dragover = undefined;
|
|
132
|
+
this.dndEventSubscriptions.drop = undefined;
|
|
106
133
|
});
|
|
107
134
|
});
|
|
108
135
|
}
|
|
109
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftCellComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.WorkShiftDndService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftCellComponent, isStandalone: true, selector: "core-shift-cell", inputs: { $backgroundColor: { classPropertyName: "$backgroundColor", publicName: "$backgroundColor", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
|
|
136
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftCellComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.WorkShiftDndService }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
137
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreShiftCellComponent, isStandalone: true, selector: "core-shift-cell", inputs: { $backgroundColor: { classPropertyName: "$backgroundColor", publicName: "$backgroundColor", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDrop: "onDrop" }, providers: [
|
|
111
138
|
{
|
|
112
139
|
provide: NG_VALUE_ACCESSOR,
|
|
113
140
|
multi: true,
|
|
114
141
|
useExisting: CoreShiftCellComponent
|
|
115
142
|
}
|
|
116
|
-
], viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<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", styles: [".core-shift-cell-container{--background-color: #000000;padding:15px;background-color:var(--background-color)}.core-shift-cell-container.valid-drop{background-color:#90ee90}.core-shift-cell-container.invalid-drop{background-color:#f08080}\n"], dependencies: [{ kind: "component", type: CoreShiftStickerComponent, selector: "core-shift-sticker", inputs: ["$shift", "$shiftCellId", "checked", "$height", "$width"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
143
|
+
], viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<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", styles: [".core-shift-cell-container{--background-color: #000000;padding:15px;background-color:var(--background-color);animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.core-shift-cell-container.valid-drop{background-color:#90ee90}.core-shift-cell-container.invalid-drop{background-color:#f08080}\n"], dependencies: [{ kind: "component", type: CoreShiftStickerComponent, selector: "core-shift-sticker", inputs: ["$shift", "$shiftCellId", "checked", "$height", "$width"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
117
144
|
}
|
|
118
145
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreShiftCellComponent, decorators: [{
|
|
119
146
|
type: Component,
|
|
@@ -125,6 +152,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
125
152
|
multi: true,
|
|
126
153
|
useExisting: CoreShiftCellComponent
|
|
127
154
|
}
|
|
128
|
-
], template: "<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", styles: [".core-shift-cell-container{--background-color: #000000;padding:15px;background-color:var(--background-color)}.core-shift-cell-container.valid-drop{background-color:#90ee90}.core-shift-cell-container.invalid-drop{background-color:#f08080}\n"] }]
|
|
129
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.WorkShiftDndService }]
|
|
130
|
-
//# 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 } from '@angular/core';\r\nimport { CoreShiftStickerComponent } from '../core-shift-sticker/core-shift-sticker.component';\r\nimport { IAtShift } from '../../interfaces/time-management/IAtShift';\r\nimport { debounceTime, 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\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  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  $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  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private workShiftDndService: WorkShiftDndService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\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      fromEvent(containerElement, 'dragenter').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        //containerElement.classList.remove('invalid-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\r\n      // Subscribe to dragover event to allow drop\r\n      fromEvent(containerElement, 'dragover').subscribe((ev: any) => {\r\n        ev.preventDefault();\r\n      });\r\n\r\n      fromEvent(containerElement, 'dragleave')\r\n        .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            //containerElement.classList.add('invalid-drop');\r\n          }\r\n          this.$container()?.nativeElement.style.setProperty('--background-color', this.$backgroundColor());\r\n          this.cdr.markForCheck();\r\n        });\r\n\r\n      // Subscribe to drop event\r\n      fromEvent(containerElement, 'drop').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', 'invalid-drop');\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        // 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}\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"]}
|
|
155
|
+
], template: "<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", styles: [".core-shift-cell-container{--background-color: #000000;padding:15px;background-color:var(--background-color);animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.core-shift-cell-container.valid-drop{background-color:#90ee90}.core-shift-cell-container.invalid-drop{background-color:#f08080}\n"] }]
|
|
156
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.WorkShiftDndService }, { type: i2.DialogService }], propDecorators: { onDrop: [{
|
|
157
|
+
type: Output
|
|
158
|
+
}] } });
|
|
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"]}
|
|
@@ -207,9 +207,10 @@ export class CoreTableComponent extends CoreFormControlBaseComponent {
|
|
|
207
207
|
if (isDevMode()) {
|
|
208
208
|
if (changes['data'].currentValue?.length) {
|
|
209
209
|
const arr = changes['data'].currentValue;
|
|
210
|
-
let
|
|
211
|
-
|
|
212
|
-
|
|
210
|
+
let findDuplicateIds = (arr) => arr.filter((item) => arr.filter((x) => x.id === item.id).length > 1);
|
|
211
|
+
let findDuplicateVirtualIds = (arr) => arr.filter((item) => arr.filter((x) => x.virtualId === item.virtualId).length > 1);
|
|
212
|
+
if (!!findDuplicateIds(arr).length && !!findDuplicateVirtualIds(arr).length) {
|
|
213
|
+
this.alertService.error("CoreTable requires unique id/virtualId values!", noneAutoClosedAlertOptions);
|
|
213
214
|
}
|
|
214
215
|
}
|
|
215
216
|
}
|
|
@@ -504,4 +505,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
504
505
|
type: ViewChild,
|
|
505
506
|
args: ['firstHeaderRow']
|
|
506
507
|
}] } });
|
|
507
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, AfterViewInit, OnChanges, ViewChild, SimpleChanges, Output, EventEmitter, isDevMode } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport enum ECoreTableToolCode {\r\n  edit = 'edit',\r\n  delete = 'delete',\r\n  complete = 'complete',\r\n  navigate = 'navigate',\r\n}\r\n\r\nexport enum ECoreTableToolClass {\r\n  edit = 'edit-icon',\r\n  delete = 'delete-icon',\r\n  repeat = 'repeat-icon',\r\n  navigate = 'navigate-icon'\r\n}\r\n\r\nexport interface ICoreTableToolItem {\r\n  code: ECoreTableToolCode;\r\n  class: ECoreTableToolClass;\r\n  caption?: EnumTranslateKey | string; // Later we will remove \"| string\"\r\n\r\n  /* callbacks to calculate disabled and hiden based on row*/\r\n  disabledFn?: (row: any) => boolean;\r\n  hiddenFn?: (row: any) => boolean;\r\n}\r\n\r\nexport interface ICoreTableToolClickEventEmitterData {\r\n  code: ECoreTableToolCode;\r\n  id: string | number;\r\n}\r\n\r\n/*\r\nexport interface ICoreTableRowDoubleClickEventEmitterData {\r\n  id: string | number;\r\n}\r\n*/\r\n\r\ninterface IDoubleTouchendData {\r\n  previous: number;\r\n  current: number;\r\n}\r\n\r\nimport { Subscription, BehaviorSubject, filter, debounceTime, Observable, fromEvent } from 'rxjs';\r\nimport { CorePageListService } from '../core-page-list/core-page-list.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { ICoreButtonVNS } from '../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { ISearchItem } from '../../interfaces/IQueryListRequest';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { AlertService } from '../alert/alert.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { noneAutoClosedAlertOptions } from '../../constants/alertOptions';\r\nimport { ICoreTableColumnItem } from './ICoreTableColumnItem';\r\nimport { EnumSortDirection } from '../../enum/EnumSortDirection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreButtonGroupComponent } from '../core-button-group/core-button-group/core-button-group.component';\r\nimport { ThreedotsComponent } from '../threedots/threedots.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { CoreLoadingSurfaceComponent } from '../core-loading-surface/core-loading-surface/core-loading-surface.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreButtonGroupComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    TranslatePipe,\r\n    CoreLoadingSurfaceComponent,\r\n    CoreButtonGroupVnsComponent,\r\n  ],\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreTableComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreTableComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n\r\n  /*\r\n  This component displays input data without pagination.\r\n  For paginating please organize from parents\r\n  */\r\n\r\n  @Input() id!: string; // for html id identifying\r\n  @Input() width!: string;\r\n  @Input() height!: number;\r\n  @Input() showCheckbox!: boolean;\r\n  @Input() checkboxSize!: number;\r\n  @Input() outerButtons!: ICoreButtonVNS[];\r\n  @Input() showTools!: boolean;\r\n  @Input() tools!: ICoreTableToolItem[];\r\n  @Input() checkingResetFlag!: boolean;\r\n  @Input() borderRadius: number = 0;\r\n  @Input() headerBackgroundColor: string = '#666666';\r\n\r\n  /* change these 2 props to wrap header texts */\r\n  @Input() headerWrap!: boolean;\r\n  @Input() headerFirstRowHeight!: number;\r\n  /** */\r\n\r\n  @Input() headerSecondRowHeight!: number;\r\n  @Input() wrap!: boolean;\r\n  @Input() allowCellScrollY!: boolean;\r\n  @Input() loading!: boolean;\r\n  @Input() rowHeight!: string; // VERY IMPORTANT PROPERTY\r\n  @Input() frozen!: number;\r\n  @Input() footer!: any;\r\n  @Input({ required: true }) columns!: ICoreTableColumnItem[]; // required\r\n  @Input({ required: true }) data: any[] = [];\r\n  @Input() selectedIds!: string[] | number[];\r\n  @Input() corePageListInstanceNumber!: number;\r\n  @Input() disableHighlightOnClick!: boolean;\r\n  @Input() freeMode!: boolean;\r\n  @Input() searchSwitchDisabled: boolean = false; // ???\r\n  @Input() disableSorting!: boolean;\r\n  @Input() inlineToolItems!: EnumCoreButtonVNSCode[];\r\n  @Input() columnSearchDefaultOpen!: boolean;\r\n  @Input() lazyLoading!: boolean;\r\n\r\n  @Input() noPaddingCell!: boolean;\r\n\r\n  @Output() onSearching = new EventEmitter<ISearchItem[]>();\r\n  @Output() onToolClick = new EventEmitter<ICoreTableToolClickEventEmitterData>();\r\n  @Output() onRowClick = new EventEmitter();\r\n  @Output() onRowDoubleClick = new EventEmitter();\r\n  @Output() onSelectedIdsChange = new EventEmitter<string[] | number[]>();\r\n  @Output() onSelectedDataChange = new EventEmitter<any[]>();\r\n  @Output() onColumnCaptionClick = new EventEmitter<ICoreTableColumnItem>();\r\n\r\n  checkboxColumnWidth: number = 30; // (--checkbox-size)* 2 Please do not change this\r\n\r\n  searchActive!: boolean;\r\n  visibleColumns!: ICoreTableColumnItem[];\r\n  frozenLefts: number[] = [];\r\n  checkingModel: boolean[] = [];\r\n  headerCheckboxState!: boolean;\r\n  checkingState!: number; // 0=none; 1=all; 2=mixed\r\n  tbodyheight!: number;\r\n  visibleRowCount!: number;\r\n\r\n  rowTouchendStream$: BehaviorSubject<IDoubleTouchendData> = new BehaviorSubject<IDoubleTouchendData>({ previous: -2, current: -1 });\r\n  subscriptions: Subscription[] = [];\r\n\r\n  searchObject!: ISearchItem[];\r\n\r\n  lang!: string;\r\n\r\n  activeRow!: any; // number | string\r\n\r\n  mouseDown = false;\r\n  startX: any;\r\n  endX: any;\r\n\r\n  scrollStream$!: Observable<any>;\r\n\r\n  /* FOR LAZY UI LOADING */\r\n  renderAhread: number = 0;\r\n  hiddenTopHeight: number = 0;\r\n  hiddenBottomHeight: number = 0;\r\n  scrollTop: number = 0;\r\n  offsetY: number = 0;\r\n  visibleData!: any[];\r\n  startNode: number = 0;\r\n  /***********************/\r\n\r\n  @ViewChild('coreTable') coreTable!: ElementRef;\r\n  @ViewChild('table') table!: ElementRef;\r\n  @ViewChild('firstHeaderRow') firstHeaderRow!: ElementRef;\r\n\r\n  constructor(\r\n    private layoutService: LayoutService,\r\n    private corePageListService: CorePageListService,\r\n    private mls: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private authService: AuthService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  calculateScroll(): void {\r\n\r\n    try {\r\n\r\n      if (!!!this.coreTable) return;\r\n      if (!!!this.lazyLoading) return;\r\n      if (!!!this.data) return;\r\n\r\n      const height = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--height').replace('px', ''));\r\n      const rowHeight = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--row-height').split('px')[0]);\r\n\r\n      if (!!!rowHeight) throw new Error(\"Could not get --row-height property\");\r\n\r\n      let startNode = Math.floor(this.scrollTop / rowHeight) - this.renderAhread;\r\n      startNode = Math.max(0, startNode);\r\n      this.startNode = startNode || 0;\r\n      let visibleNodeCount = Math.ceil(height / rowHeight) + 2 * this.renderAhread;\r\n      visibleNodeCount = Math.min(this.data.length - startNode, visibleNodeCount);\r\n      this.offsetY = startNode * rowHeight;\r\n      const newVisibleData: any[] = [];\r\n\r\n      this.hiddenTopHeight = startNode * rowHeight;\r\n      this.hiddenBottomHeight = (this.data.length - startNode - visibleNodeCount) * rowHeight;\r\n      for (let i = startNode; i < startNode + visibleNodeCount; i++) {\r\n        newVisibleData.push(this.data[i])\r\n      }\r\n\r\n      this.visibleData = newVisibleData;\r\n\r\n      /* OPEN COMMENTS TO SEE CONTROL VALUES */\r\n      console.log(\"startNode\", startNode)\r\n      /*\r\n      console.log(\"this.offsetY\", this.offsetY)\r\n      console.log(\"this.hiddenTopHeight\", this.hiddenTopHeight)\r\n      console.log(\"this.hiddenBottomHeight\", this.hiddenBottomHeight)\r\n      console.log(\"this.visibleData.length\", this.visibleData.length)\r\n      const controlValue = (this.hiddenTopHeight + this.hiddenBottomHeight + this.visibleData.length * rowHeight) / rowHeight\r\n      console.log(\"controlValue\", controlValue) // Must equeal pageSize\r\n      */\r\n    } catch (error: any) {\r\n      if (isDevMode() && this.authService.data$.value?.id === '8c24683d-7d52-4f5a-8090-31c777e8869d') {\r\n        this.alertService.error(error.message, noneAutoClosedAlertOptions);\r\n      }\r\n\r\n      if (!!this.data) {\r\n        this.visibleData = JSON.parse(JSON.stringify(this.data));\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  startDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (e.buttons === 1) {\r\n      this.startX = e.pageX;\r\n      if (!!!this.mouseDown) {\r\n\r\n      }\r\n      this.mouseDown = true;\r\n    }\r\n  }\r\n\r\n  stopDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (!!this.mouseDown) {\r\n      this.endX = e.pageX;\r\n      let offset = this.endX - this.startX;\r\n      col.width! += offset;\r\n      this.mouseDown = false;\r\n      this.endX = 0;\r\n      this.startX = 0;\r\n    }\r\n  }\r\n\r\n  moveEvent(e: any, col: ICoreTableColumnItem) {\r\n    e.preventDefault();\r\n    if (!this.mouseDown) {\r\n      return;\r\n    }\r\n    const x = e.pageX;\r\n    console.log(\"moveEvent\", e.pageX)\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.showCheckbox) {\r\n      if (!this.checkboxSize) {\r\n        this.checkboxSize = 15;\r\n      }\r\n    }\r\n\r\n    if (this.headerFirstRowHeight === undefined) this.headerFirstRowHeight = 40;\r\n    if (this.headerSecondRowHeight === undefined) this.headerSecondRowHeight = 40;\r\n\r\n\r\n    /* Validate columns input to make sure one of fields is 'id' */\r\n    if (!!!this.columns) {\r\n      this.alertService.error(this.id + \": Columns are not defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    if (this.columns?.filter((c: ICoreTableColumnItem) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": The columns must have one with 'field' property === 'id'\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden)\r\n    if (!!!this.visibleColumns?.length && isDevMode() && this.columns?.length) {\r\n      this.alertService.error(this.id + \": No visible column defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    // add default sort direction to visibleColumns\r\n    this.visibleColumns?.map(c => c.sortDirection = EnumSortDirection.NONE)\r\n\r\n    /* START: Initializing searchObject */\r\n    const newSearchObject: ISearchItem[] = [];\r\n    this.visibleColumns?.map(c => {\r\n      newSearchObject.push({\r\n        field: c.field,\r\n        searchFor: ''\r\n      })\r\n    })\r\n    this.searchObject = newSearchObject;\r\n    /* END: Initializing searchObject */\r\n\r\n    const frozenColumns = this.visibleColumns?.filter((_, index) => index < this.frozen);\r\n\r\n    let left = this.checkboxSize! * 2 || 0; // the first size is for checkbox\r\n    frozenColumns?.map(c => {\r\n      if (!!!c.width) console.error(this.id + \": Each frozen column must have its number property 'width'.\");\r\n      this.frozenLefts.push(left);\r\n      left = left + c.width!\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.rowTouchendStream$.pipe(\r\n        filter((x: any) => x.current === x.previous),\r\n        debounceTime(200),\r\n      ).subscribe((y: any) => {\r\n        this.onRowDoubleClick.emit({\r\n          id: this.data[y.current].id\r\n        })\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n    /* Check if any of columns is templateRef */\r\n    const templateRefFilter = this.columns?.filter(x => !!x.templateRef)\r\n    if (!!templateRefFilter?.length) {\r\n      templateRefFilter.map(x => {\r\n        if (x.templateRef?.elementRef?.nativeElement?.height > Number(this.rowHeight.replace('px', ''))) {\r\n          this.alertService.error(`Chiều cao của ${this.mls.trans(x.caption)} templateRef là ${x.templateRef?.elementRef?.nativeElement?.height}, lớn hơn chiều cao của dòng lưới ${this.rowHeight}`, noneAutoClosedAlertOptions)\r\n        }\r\n      })\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (changes['checkingResetFlag']) {\r\n      if (!!this.data) {\r\n        this.toggleCheckAll(false)\r\n        this.headerCheckboxState = false;\r\n      }\r\n    }\r\n\r\n    if (changes['data']) {\r\n\r\n      // Check unique of \"id\"\r\n      if (isDevMode()) {\r\n        if (changes['data'].currentValue?.length) {\r\n          const arr = changes['data'].currentValue\r\n          let findDuplicates = arr => arr.filter(item => arr.filter(x => x.id === item.id).length > 1)\r\n          if (!!findDuplicates(arr).length) {\r\n            this.alertService.error(\"CoreTable requires unique id values!\", noneAutoClosedAlertOptions)\r\n          }\r\n        }\r\n      }\r\n\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['data'].currentValue?.map((_: any) => {\r\n        newCheckingModel.push(false)\r\n      });\r\n      this.checkingModel = newCheckingModel;\r\n\r\n      if (!!this.lazyLoading) {\r\n        if (!!this.coreTable) {\r\n          this.calculateScroll();\r\n        }\r\n      } else {\r\n        this.visibleData = changes['data'].currentValue;\r\n      }\r\n    }\r\n\r\n    if (changes['checkedIds']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['checkedIds'].currentValue?.map((checkedId: any) => {\r\n        this.data.map((item) => {\r\n          if (item['id'] === checkedId) {\r\n            newCheckingModel.push(true);\r\n          } else {\r\n            newCheckingModel.push(false);\r\n          }\r\n        })\r\n      })\r\n      this.checkingModel = newCheckingModel;\r\n    }\r\n    // if (changes['loading']) {\r\n    //   this.loading = changes['loading'].currentValue;\r\n    // }\r\n    if (changes['columns']) {\r\n      this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden) || []\r\n    }\r\n    if (changes['columnSearchDefaultOpen']) {\r\n      this.searchActive = !!changes['columnSearchDefaultOpen'].currentValue\r\n    }\r\n  }\r\n\r\n  private resetHeaderFirstRowHeight(): void {\r\n    setTimeout(() => {\r\n      const firstHeaderRowHeight = this.firstHeaderRow.nativeElement.getBoundingClientRect().height;\r\n      this.coreTable.nativeElement.style.setProperty('--header-1st-row-height',\r\n        firstHeaderRowHeight + 'px'\r\n      );\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (this.corePageListInstanceNumber) {\r\n      const callerFilter = this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber);\r\n      if (!!callerFilter.length) {\r\n        const caller = callerFilter[0];\r\n        caller.coreTableRef = this.coreTable;\r\n      }\r\n\r\n      if (!!!this.freeMode) {\r\n        this.subscriptions.push(\r\n          this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].id$.subscribe(x => {\r\n            this.activeRow = x;\r\n          })\r\n        )\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].tbodyHeight$.subscribe(x => {\r\n          if (!!x) {\r\n            this.tbodyheight = x;\r\n          }\r\n        })\r\n      )\r\n\r\n      const rect = this.coreTable.nativeElement.getBoundingClientRect();\r\n      this.coreTable.nativeElement.style.setProperty('--table-width', rect.width + 'px')\r\n\r\n    }\r\n\r\n    this.scrollStream$ = fromEvent(this.table.nativeElement, 'scroll');\r\n\r\n    setTimeout(() => {\r\n\r\n      if (!!this.width) this.coreTable.nativeElement.style.setProperty('--width', this.width + 'px');\r\n      if (!!this.rowHeight) this.coreTable.nativeElement.style.setProperty('--row-height', this.rowHeight + 'px');\r\n      if (!!this.height) this.coreTable.nativeElement.style.setProperty('--height', this.height + 'px');\r\n\r\n      // Chỉ subscride sau khi các lệnh trên đã được thực hiện\r\n      this.subscriptions.push(\r\n        this.scrollStream$\r\n          .pipe(\r\n            debounceTime(50)\r\n          )\r\n          .subscribe(event => {\r\n            this.scrollTop = event.srcElement.scrollTop;\r\n            this.calculateScroll();\r\n          })\r\n      )\r\n\r\n    }, 0)\r\n\r\n    this.resetHeaderFirstRowHeight();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.resetHeaderFirstRowHeight();\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  onToolClickLocal(row: any, toolIndex: number): void {\r\n    this.onToolClick.emit({\r\n      code: this.tools[toolIndex].code,\r\n      id: row['id']\r\n    })\r\n  }\r\n\r\n  toggleCheckAll(args: boolean) {\r\n    const newCheckingModel: boolean[] = [];\r\n    const newSelectedIds: any[] = [];\r\n    const newSelectedData: any[] = [];\r\n\r\n    this.data.map(item => {\r\n      newCheckingModel.push(args);\r\n      if (args) {\r\n        newSelectedIds.push(item.id);\r\n        newSelectedData.push(item);\r\n      }\r\n    });\r\n\r\n    this.checkingModel = newCheckingModel;\r\n    this.checkingState = args ? 1 : 0;\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n  }\r\n\r\n  onCheckingNgModelChange() {\r\n    const newSelectedIds: number[] = [];\r\n    const newSelectedData: any[] = [];\r\n    this.data.filter((_: any, index: number) => !!this.checkingModel[index]).map(item => {\r\n      newSelectedIds.push(item.id)\r\n      newSelectedData.push(item)\r\n    })\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n\r\n    if (newSelectedIds.length === 0) {\r\n      this.checkingState = 0; // none\r\n    } else if (newSelectedIds.length === this.checkingModel.length) {\r\n      this.checkingState = 1; // all\r\n    } else {\r\n      this.checkingState = 2; // mixed\r\n    }\r\n\r\n  }\r\n\r\n  onDoubleClickLocal(rowIndex: number) {\r\n    this.onRowDoubleClick.emit(this.data[rowIndex])\r\n  }\r\n\r\n  onClickLocal(row: any, event: any) {\r\n\r\n    console.log(\"onClickLocal row\", row, \"event\", event)\r\n\r\n    if (event.detail === 1) {\r\n      this.activeRow = row.id;\r\n      this.onRowClick.emit(row);\r\n    } else if (event.detail === 2) {\r\n      this.onRowDoubleClick.emit(row)\r\n    }\r\n\r\n  }\r\n\r\n  onRowTouchend(rowIndex: number) {\r\n    this.rowTouchendStream$.next({\r\n      previous: this.rowTouchendStream$.value.current,\r\n      current: rowIndex\r\n    });\r\n  }\r\n\r\n  onSearch(e: string, searchColumnIndex: number): void {\r\n    this.searchObject.filter((_, i) => i === searchColumnIndex)[0].searchFor = e;\r\n    this.onSearching.emit(this.searchObject);\r\n  }\r\n\r\n  onColumnCaptionClickLocal(column: ICoreTableColumnItem) {\r\n\r\n    if (!!this.disableSorting || !!column.templateRef) return; // no action for templateRef type\r\n\r\n    this.onColumnCaptionClick.emit(column);\r\n\r\n    // update sort dicrection property of this column\r\n    // and clear up the property for the other visibleColumns\r\n    this.visibleColumns.map(vc => {\r\n      if (vc.field === column.field) {\r\n        vc.sortDirection = vc.sortDirection === EnumSortDirection.NONE ? EnumSortDirection.ASC : vc.sortDirection === EnumSortDirection.ASC ? EnumSortDirection.DESC : EnumSortDirection.NONE;\r\n      } else {\r\n        vc.sortDirection = EnumSortDirection.NONE\r\n      }\r\n    })\r\n  }\r\n\r\n  toggleAllowSearch(): void {\r\n    this.searchActive = !!!this.searchActive\r\n  }\r\n\r\n  onInlineToolClick(e: ICoreButtonVNS, row: any): void {\r\n    console.log(\"onInlineToolClick\", e, row)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n  }\r\n\r\n}\r\n","<div #coreTable class=\"core-table-container\" [class.hide-search]=\"!!!searchActive\">\r\n\r\n    <!-- \r\n        Cần truyền chính xác height của CoreTable\r\n        Tuy nhiên chiều cao của CoreTable cần được tính dựa vào chiều cao của các phần tử DOM lần lượt từ lớp ngoài vào lớp trong\r\n        Anh em chưa tính khi triển khai code, nên đang cần có con số default là 400px\r\n    -->\r\n    <table [class.wrap]=\"!!wrap\" #table [ngStyle]=\"{ height: (height || 400) + 'px' }\">\r\n        <colgroup>\r\n            @if (showCheckbox) {\r\n            <col> }\r\n            @for (col of visibleColumns; track col) {\r\n            <col> }\r\n            @if (showTools) {\r\n            <col> }\r\n        </colgroup>\r\n        <thead>\r\n            <tr #firstHeaderRow data-row=\"1\" [ngStyle]=\"{\r\n                height: headerFirstRowHeight + 'px'\r\n            }\">\r\n                @if (showCheckbox) {\r\n                <th class=\"check-col-header check-cell frozen-col\" style=\"left: 0px\"\r\n                    [attr.rowspan]=\"searchActive ? 2 : 1\" [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\">\r\n                    <!-- please do not change -->\r\n                    <div [ngStyle]=\"{\r\n                            width: checkboxSize * 2 + 'px'\r\n                        }\">\r\n                        <label class=\"checkwrap\" [ngStyle]=\"{\r\n                                height: searchActive ? headerFirstRowHeight + headerSecondRowHeight + 'px' : headerFirstRowHeight + 'px'\r\n                            }\">\r\n                            <input type=\"checkbox\" [id]=\"'check-col-header' + id\" [(ngModel)]=\"headerCheckboxState\"\r\n                                (ngModelChange)=\"toggleCheckAll($event)\">\r\n                            <span class=\"checkmark\" [class.mixed]=\"checkingState===2\" [ngStyle]=\"{\r\n                                    top: ((headerFirstRowHeight + headerSecondRowHeight * (searchActive ? 1 : 0)) /2 - checkboxSize/2) + 'px'\r\n                                }\"></span>\r\n                        </label>\r\n                    </div>\r\n                </th>\r\n                }\r\n                @for (col of visibleColumns; track col) {\r\n                <th [class.frozen-col]=\"$index < frozen\"\r\n                    [style]=\"$index < frozen ? 'left: ' + frozenLefts[$index] + 'px' : ''\" [ngStyle]=\"{\r\n                            backgroundColor: headerBackgroundColor,\r\n                            color: 'white',\r\n                            padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                        }\">\r\n                    <!-- -1px for borderBottom of header first row -->\r\n                    <div class=\"column-caption\" [class.ascending]=\"col.sortDirection===-1\"\r\n                        [class.descending]=\"col.sortDirection===1\" (click)=\"onColumnCaptionClickLocal(col)\"\r\n                        [appTooltip]=\"col.caption | translate : lang\" [ngStyle]=\"{\r\n                                width: col.width + 'px',\r\n                                height: (headerFirstRowHeight - 1) + 'px',\r\n                                display: 'flex',\r\n                                alignItems: 'center',\r\n                                whiteSpace: !!headerWrap ? 'initial' : 'inherit'\r\n                            }\">{{ col.caption | translate : lang }}</div>\r\n                    <div class=\"resizer\" (mousedown)=\"startDragging($event, col, false)\"\r\n                        (mouseup)=\"stopDragging($event, col, false)\" (mousemove)=\"moveEvent($event, col)\"></div>\r\n                </th>\r\n                }\r\n                @if (showTools && visibleColumns?.length) {\r\n                <th class=\"check-col-header check-cell\" [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\">\r\n                    <div style=\"width: 100px;\">\r\n                    </div>\r\n                </th>\r\n                }\r\n                @if (!searchSwitchDisabled) {\r\n                <th [ngStyle]=\"{\r\n                    backgroundColor: headerBackgroundColor,\r\n                    width: '50px'\r\n                }\">\r\n                    <ng-container *ngTemplateOutlet=\"searchSwitcher\"></ng-container>\r\n                </th>\r\n                }\r\n            </tr>\r\n            @if (searchActive) {\r\n            <tr data-row=\"2\" [class.hiden]=\"!!!searchActive\">\r\n                @for (col of visibleColumns; track col) {\r\n                <th [class.frozen-col]=\"$index < frozen\"\r\n                    [style]=\"$index < frozen ? 'left: ' + frozenLefts[$index] + 'px' : ''\" [ngStyle]=\"{\r\n                                backgroundColor: headerBackgroundColor,\r\n                                color: 'white',\r\n                                padding: '0px 12px'\r\n                            }\">\r\n                    @if (!col.hideSearchBox) {\r\n                    <div [style]=\"'width: ' + col.width + 'px;'\">\r\n                        <input type=\"text\" class=\"form-control search\" [(ngModel)]=\"searchObject[$index].searchFor\"\r\n                            (ngModelChange)=\"onSearch($event, $index)\">\r\n                    </div>\r\n                    }\r\n                </th>\r\n                }\r\n                <th [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\"></th>\r\n            </tr>\r\n            }\r\n        </thead>\r\n\r\n        <tbody [class.loading]=\"loading\">\r\n            <core-loading-surface [loading]=\"loading\" [height]=\"tbodyheight || 500\"></core-loading-surface>\r\n\r\n            <ng-container>\r\n                @if (!!lazyLoading) {\r\n                <tr [ngStyle]=\"{ height: hiddenTopHeight + 'px' }\">\r\n                    <td>\r\n                        <div [ngStyle]=\"{ height: hiddenTopHeight + 'px' }\"></div>\r\n                    </td>\r\n                </tr>\r\n                }\r\n\r\n                @for (row of visibleData; track row) {\r\n                <tr (click)=\"onClickLocal(row, $event)\" (touchend)=\"onRowTouchend($index+startNode)\"\r\n                    [class.active]=\"row.id === activeRow && !!!disableHighlightOnClick\">\r\n\r\n                    <!-- <div class=\"row-item-tools\">\r\n                                    <div class=\"row-item-tool\">\r\n                                        <div class=\"row-item-tool-wrapper\">\r\n                                            <core-button-group-vns [shownItems]=\"inlineToolItems\"\r\n                                                (buttonClick)=\"onInlineToolClick($event, row)\"></core-button-group-vns>\r\n                                        </div>\r\n                                    </div>\r\n                                </div> -->\r\n\r\n                    @if (showCheckbox) {\r\n                    <td class=\"check-cell frozen-col\" style=\"left: 0px;\">\r\n                        <label class=\"checkwrap\">\r\n                            <input type=\"checkbox\" class=\"check-row\" [id]=\"'check-row' + ($index + startNode)\"\r\n                                [(ngModel)]=\"checkingModel[$index+startNode]\"\r\n                                (ngModelChange)=\"onCheckingNgModelChange()\">\r\n                            <span class=\"checkmark\"></span>\r\n                        </label>\r\n                    </td>\r\n                    }\r\n\r\n                    @for (col of visibleColumns; track col) {\r\n                    <td [class.frozen-col]=\"$index < frozen\" [ngStyle]=\"{\r\n                                                left: $index < frozen ? frozenLefts[$index] + 'px' : '0px',\r\n                                                padding: !!noPaddingCell ? '0px 0px' : '2px 0px'\r\n                                            }\">\r\n\r\n                        @if (!col?.templateRef) {\r\n                        <!-- IN MOST CASES WE NEED TO RENDER THE CELL WITH PRIMITIVE TYPE -->\r\n                        <div [class.scroll-y]=\"allowCellScrollY\" [ngStyle]=\"{\r\n                                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                                    lineHeight: rowHeight,\r\n                                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                                }\" [appTooltip]=\"row[col.field] | tableCell: col.pipe : lang\">{{\r\n                            row[col.field] | tableCell: col.pipe : lang }}</div>\r\n                        <!------------------------------------------------------------------>\r\n                        } @else {\r\n                        <!-- BUT SOME TIME WE NEED TO RENDER THE CELL WITH TEMPLATE -->\r\n                        <div [ngStyle]=\"{\r\n                                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                                }\">\r\n                            @if (!col?.templateRefAllowEditOnRowActived) {\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"col?.templateRef!; context: { context: row }\"></ng-container>\r\n                            } @else {\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"col?.templateRef!; context: { context: row, allowEdit: row.id === activeRow }\"></ng-container>\r\n                            }\r\n                        </div>\r\n                        <!------------------------------------------------------------------>\r\n                        }\r\n                    </td>\r\n                    }\r\n\r\n\r\n                    @if (showTools) {\r\n                    <td>\r\n                        <div class=\"tools-group d-flex-center\">\r\n                            @for (tool of tools; track tool) {\r\n                            <div [class]=\"'tools-icon ' + tool.class\"\r\n                                [class.disabled]=\"tool.disabledFn ? tool.disabledFn!(row) : false\"\r\n                                [class.hidden]=\"tool.hiddenFn ? tool.hiddenFn!(row) : false\"\r\n                                (click)=\"onToolClickLocal(row, $index)\">\r\n                            </div>\r\n                            }\r\n                        </div>\r\n                    </td>\r\n                    }\r\n                </tr>\r\n                }\r\n\r\n                @if (!!lazyLoading) {\r\n                <tr [ngStyle]=\"{\r\n                    height: hiddenBottomHeight + 'px'\r\n                }\">\r\n                    <td>\r\n                        <div [ngStyle]=\"{\r\n                                height: hiddenBottomHeight + 'px'\r\n                            }\">\r\n                        </div>\r\n                    </td>\r\n                </tr>\r\n                }\r\n\r\n            </ng-container>\r\n\r\n        </tbody>\r\n        @if (!!footer) {\r\n        <tfoot>\r\n            Footer\r\n        </tfoot>\r\n        }\r\n    </table>\r\n\r\n    <ng-template #searchSwitcher>\r\n        <div class=\"search-toggler d-flex-center pointer\" (click)=\"toggleAllowSearch()\">\r\n            <i class=\"feather-search\"></i>\r\n        </div>\r\n    </ng-template>\r\n</div>"]}
|
|
508
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, AfterViewInit, OnChanges, ViewChild, SimpleChanges, Output, EventEmitter, isDevMode } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport enum ECoreTableToolCode {\r\n  edit = 'edit',\r\n  delete = 'delete',\r\n  complete = 'complete',\r\n  navigate = 'navigate',\r\n}\r\n\r\nexport enum ECoreTableToolClass {\r\n  edit = 'edit-icon',\r\n  delete = 'delete-icon',\r\n  repeat = 'repeat-icon',\r\n  navigate = 'navigate-icon'\r\n}\r\n\r\nexport interface ICoreTableToolItem {\r\n  code: ECoreTableToolCode;\r\n  class: ECoreTableToolClass;\r\n  caption?: EnumTranslateKey | string; // Later we will remove \"| string\"\r\n\r\n  /* callbacks to calculate disabled and hiden based on row*/\r\n  disabledFn?: (row: any) => boolean;\r\n  hiddenFn?: (row: any) => boolean;\r\n}\r\n\r\nexport interface ICoreTableToolClickEventEmitterData {\r\n  code: ECoreTableToolCode;\r\n  id: string | number;\r\n}\r\n\r\n/*\r\nexport interface ICoreTableRowDoubleClickEventEmitterData {\r\n  id: string | number;\r\n}\r\n*/\r\n\r\ninterface IDoubleTouchendData {\r\n  previous: number;\r\n  current: number;\r\n}\r\n\r\nimport { Subscription, BehaviorSubject, filter, debounceTime, Observable, fromEvent } from 'rxjs';\r\nimport { CorePageListService } from '../core-page-list/core-page-list.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { ICoreButtonVNS } from '../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { ISearchItem } from '../../interfaces/IQueryListRequest';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { AlertService } from '../alert/alert.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { noneAutoClosedAlertOptions } from '../../constants/alertOptions';\r\nimport { ICoreTableColumnItem } from './ICoreTableColumnItem';\r\nimport { EnumSortDirection } from '../../enum/EnumSortDirection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreButtonGroupComponent } from '../core-button-group/core-button-group/core-button-group.component';\r\nimport { ThreedotsComponent } from '../threedots/threedots.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { CoreLoadingSurfaceComponent } from '../core-loading-surface/core-loading-surface/core-loading-surface.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreButtonGroupComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    TranslatePipe,\r\n    CoreLoadingSurfaceComponent,\r\n    CoreButtonGroupVnsComponent,\r\n  ],\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreTableComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreTableComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n\r\n  /*\r\n  This component displays input data without pagination.\r\n  For paginating please organize from parents\r\n  */\r\n\r\n  @Input() id!: string; // for html id identifying\r\n  @Input() width!: string;\r\n  @Input() height!: number;\r\n  @Input() showCheckbox!: boolean;\r\n  @Input() checkboxSize!: number;\r\n  @Input() outerButtons!: ICoreButtonVNS[];\r\n  @Input() showTools!: boolean;\r\n  @Input() tools!: ICoreTableToolItem[];\r\n  @Input() checkingResetFlag!: boolean;\r\n  @Input() borderRadius: number = 0;\r\n  @Input() headerBackgroundColor: string = '#666666';\r\n\r\n  /* change these 2 props to wrap header texts */\r\n  @Input() headerWrap!: boolean;\r\n  @Input() headerFirstRowHeight!: number;\r\n  /** */\r\n\r\n  @Input() headerSecondRowHeight!: number;\r\n  @Input() wrap!: boolean;\r\n  @Input() allowCellScrollY!: boolean;\r\n  @Input() loading!: boolean;\r\n  @Input() rowHeight!: string; // VERY IMPORTANT PROPERTY\r\n  @Input() frozen!: number;\r\n  @Input() footer!: any;\r\n  @Input({ required: true }) columns!: ICoreTableColumnItem[]; // required\r\n  @Input({ required: true }) data: any[] = [];\r\n  @Input() selectedIds!: string[] | number[];\r\n  @Input() corePageListInstanceNumber!: number;\r\n  @Input() disableHighlightOnClick!: boolean;\r\n  @Input() freeMode!: boolean;\r\n  @Input() searchSwitchDisabled: boolean = false; // ???\r\n  @Input() disableSorting!: boolean;\r\n  @Input() inlineToolItems!: EnumCoreButtonVNSCode[];\r\n  @Input() columnSearchDefaultOpen!: boolean;\r\n  @Input() lazyLoading!: boolean;\r\n\r\n  @Input() noPaddingCell!: boolean;\r\n\r\n  @Output() onSearching = new EventEmitter<ISearchItem[]>();\r\n  @Output() onToolClick = new EventEmitter<ICoreTableToolClickEventEmitterData>();\r\n  @Output() onRowClick = new EventEmitter();\r\n  @Output() onRowDoubleClick = new EventEmitter();\r\n  @Output() onSelectedIdsChange = new EventEmitter<string[] | number[]>();\r\n  @Output() onSelectedDataChange = new EventEmitter<any[]>();\r\n  @Output() onColumnCaptionClick = new EventEmitter<ICoreTableColumnItem>();\r\n\r\n  checkboxColumnWidth: number = 30; // (--checkbox-size)* 2 Please do not change this\r\n\r\n  searchActive!: boolean;\r\n  visibleColumns!: ICoreTableColumnItem[];\r\n  frozenLefts: number[] = [];\r\n  checkingModel: boolean[] = [];\r\n  headerCheckboxState!: boolean;\r\n  checkingState!: number; // 0=none; 1=all; 2=mixed\r\n  tbodyheight!: number;\r\n  visibleRowCount!: number;\r\n\r\n  rowTouchendStream$: BehaviorSubject<IDoubleTouchendData> = new BehaviorSubject<IDoubleTouchendData>({ previous: -2, current: -1 });\r\n  subscriptions: Subscription[] = [];\r\n\r\n  searchObject!: ISearchItem[];\r\n\r\n  lang!: string;\r\n\r\n  activeRow!: any; // number | string\r\n\r\n  mouseDown = false;\r\n  startX: any;\r\n  endX: any;\r\n\r\n  scrollStream$!: Observable<any>;\r\n\r\n  /* FOR LAZY UI LOADING */\r\n  renderAhread: number = 0;\r\n  hiddenTopHeight: number = 0;\r\n  hiddenBottomHeight: number = 0;\r\n  scrollTop: number = 0;\r\n  offsetY: number = 0;\r\n  visibleData!: any[];\r\n  startNode: number = 0;\r\n  /***********************/\r\n\r\n  @ViewChild('coreTable') coreTable!: ElementRef;\r\n  @ViewChild('table') table!: ElementRef;\r\n  @ViewChild('firstHeaderRow') firstHeaderRow!: ElementRef;\r\n\r\n  constructor(\r\n    private layoutService: LayoutService,\r\n    private corePageListService: CorePageListService,\r\n    private mls: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private authService: AuthService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  calculateScroll(): void {\r\n\r\n    try {\r\n\r\n      if (!!!this.coreTable) return;\r\n      if (!!!this.lazyLoading) return;\r\n      if (!!!this.data) return;\r\n\r\n      const height = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--height').replace('px', ''));\r\n      const rowHeight = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--row-height').split('px')[0]);\r\n\r\n      if (!!!rowHeight) throw new Error(\"Could not get --row-height property\");\r\n\r\n      let startNode = Math.floor(this.scrollTop / rowHeight) - this.renderAhread;\r\n      startNode = Math.max(0, startNode);\r\n      this.startNode = startNode || 0;\r\n      let visibleNodeCount = Math.ceil(height / rowHeight) + 2 * this.renderAhread;\r\n      visibleNodeCount = Math.min(this.data.length - startNode, visibleNodeCount);\r\n      this.offsetY = startNode * rowHeight;\r\n      const newVisibleData: any[] = [];\r\n\r\n      this.hiddenTopHeight = startNode * rowHeight;\r\n      this.hiddenBottomHeight = (this.data.length - startNode - visibleNodeCount) * rowHeight;\r\n      for (let i = startNode; i < startNode + visibleNodeCount; i++) {\r\n        newVisibleData.push(this.data[i])\r\n      }\r\n\r\n      this.visibleData = newVisibleData;\r\n\r\n      /* OPEN COMMENTS TO SEE CONTROL VALUES */\r\n      console.log(\"startNode\", startNode)\r\n      /*\r\n      console.log(\"this.offsetY\", this.offsetY)\r\n      console.log(\"this.hiddenTopHeight\", this.hiddenTopHeight)\r\n      console.log(\"this.hiddenBottomHeight\", this.hiddenBottomHeight)\r\n      console.log(\"this.visibleData.length\", this.visibleData.length)\r\n      const controlValue = (this.hiddenTopHeight + this.hiddenBottomHeight + this.visibleData.length * rowHeight) / rowHeight\r\n      console.log(\"controlValue\", controlValue) // Must equeal pageSize\r\n      */\r\n    } catch (error: any) {\r\n      if (isDevMode() && this.authService.data$.value?.id === '8c24683d-7d52-4f5a-8090-31c777e8869d') {\r\n        this.alertService.error(error.message, noneAutoClosedAlertOptions);\r\n      }\r\n\r\n      if (!!this.data) {\r\n        this.visibleData = JSON.parse(JSON.stringify(this.data));\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  startDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (e.buttons === 1) {\r\n      this.startX = e.pageX;\r\n      if (!!!this.mouseDown) {\r\n\r\n      }\r\n      this.mouseDown = true;\r\n    }\r\n  }\r\n\r\n  stopDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (!!this.mouseDown) {\r\n      this.endX = e.pageX;\r\n      let offset = this.endX - this.startX;\r\n      col.width! += offset;\r\n      this.mouseDown = false;\r\n      this.endX = 0;\r\n      this.startX = 0;\r\n    }\r\n  }\r\n\r\n  moveEvent(e: any, col: ICoreTableColumnItem) {\r\n    e.preventDefault();\r\n    if (!this.mouseDown) {\r\n      return;\r\n    }\r\n    const x = e.pageX;\r\n    console.log(\"moveEvent\", e.pageX)\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.showCheckbox) {\r\n      if (!this.checkboxSize) {\r\n        this.checkboxSize = 15;\r\n      }\r\n    }\r\n\r\n    if (this.headerFirstRowHeight === undefined) this.headerFirstRowHeight = 40;\r\n    if (this.headerSecondRowHeight === undefined) this.headerSecondRowHeight = 40;\r\n\r\n\r\n    /* Validate columns input to make sure one of fields is 'id' */\r\n    if (!!!this.columns) {\r\n      this.alertService.error(this.id + \": Columns are not defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    if (this.columns?.filter((c: ICoreTableColumnItem) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": The columns must have one with 'field' property === 'id'\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden)\r\n    if (!!!this.visibleColumns?.length && isDevMode() && this.columns?.length) {\r\n      this.alertService.error(this.id + \": No visible column defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    // add default sort direction to visibleColumns\r\n    this.visibleColumns?.map(c => c.sortDirection = EnumSortDirection.NONE)\r\n\r\n    /* START: Initializing searchObject */\r\n    const newSearchObject: ISearchItem[] = [];\r\n    this.visibleColumns?.map(c => {\r\n      newSearchObject.push({\r\n        field: c.field,\r\n        searchFor: ''\r\n      })\r\n    })\r\n    this.searchObject = newSearchObject;\r\n    /* END: Initializing searchObject */\r\n\r\n    const frozenColumns = this.visibleColumns?.filter((_, index) => index < this.frozen);\r\n\r\n    let left = this.checkboxSize! * 2 || 0; // the first size is for checkbox\r\n    frozenColumns?.map(c => {\r\n      if (!!!c.width) console.error(this.id + \": Each frozen column must have its number property 'width'.\");\r\n      this.frozenLefts.push(left);\r\n      left = left + c.width!\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.rowTouchendStream$.pipe(\r\n        filter((x: any) => x.current === x.previous),\r\n        debounceTime(200),\r\n      ).subscribe((y: any) => {\r\n        this.onRowDoubleClick.emit({\r\n          id: this.data[y.current].id\r\n        })\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n    /* Check if any of columns is templateRef */\r\n    const templateRefFilter = this.columns?.filter(x => !!x.templateRef)\r\n    if (!!templateRefFilter?.length) {\r\n      templateRefFilter.map(x => {\r\n        if (x.templateRef?.elementRef?.nativeElement?.height > Number(this.rowHeight.replace('px', ''))) {\r\n          this.alertService.error(`Chiều cao của ${this.mls.trans(x.caption)} templateRef là ${x.templateRef?.elementRef?.nativeElement?.height}, lớn hơn chiều cao của dòng lưới ${this.rowHeight}`, noneAutoClosedAlertOptions)\r\n        }\r\n      })\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (changes['checkingResetFlag']) {\r\n      if (!!this.data) {\r\n        this.toggleCheckAll(false)\r\n        this.headerCheckboxState = false;\r\n      }\r\n    }\r\n\r\n    if (changes['data']) {\r\n\r\n      // Check unique of \"id\"\r\n      if (isDevMode()) {\r\n        if (changes['data'].currentValue?.length) {\r\n          const arr = changes['data'].currentValue\r\n          let findDuplicateIds = (arr: any) => arr.filter((item: any) => arr.filter((x: any) => x.id === item.id).length > 1)\r\n          let findDuplicateVirtualIds = (arr: any) => arr.filter((item: any) => arr.filter((x: any) => x.virtualId === item.virtualId).length > 1)\r\n          if (!!findDuplicateIds(arr).length && !!findDuplicateVirtualIds(arr).length) {\r\n            this.alertService.error(\"CoreTable requires unique id/virtualId values!\", noneAutoClosedAlertOptions)\r\n          }\r\n        }\r\n      }\r\n\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['data'].currentValue?.map((_: any) => {\r\n        newCheckingModel.push(false)\r\n      });\r\n      this.checkingModel = newCheckingModel;\r\n\r\n      if (!!this.lazyLoading) {\r\n        if (!!this.coreTable) {\r\n          this.calculateScroll();\r\n        }\r\n      } else {\r\n        this.visibleData = changes['data'].currentValue;\r\n      }\r\n    }\r\n\r\n    if (changes['checkedIds']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['checkedIds'].currentValue?.map((checkedId: any) => {\r\n        this.data.map((item) => {\r\n          if (item['id'] === checkedId) {\r\n            newCheckingModel.push(true);\r\n          } else {\r\n            newCheckingModel.push(false);\r\n          }\r\n        })\r\n      })\r\n      this.checkingModel = newCheckingModel;\r\n    }\r\n    // if (changes['loading']) {\r\n    //   this.loading = changes['loading'].currentValue;\r\n    // }\r\n    if (changes['columns']) {\r\n      this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden) || []\r\n    }\r\n    if (changes['columnSearchDefaultOpen']) {\r\n      this.searchActive = !!changes['columnSearchDefaultOpen'].currentValue\r\n    }\r\n  }\r\n\r\n  private resetHeaderFirstRowHeight(): void {\r\n    setTimeout(() => {\r\n      const firstHeaderRowHeight = this.firstHeaderRow.nativeElement.getBoundingClientRect().height;\r\n      this.coreTable.nativeElement.style.setProperty('--header-1st-row-height',\r\n        firstHeaderRowHeight + 'px'\r\n      );\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (this.corePageListInstanceNumber) {\r\n      const callerFilter = this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber);\r\n      if (!!callerFilter.length) {\r\n        const caller = callerFilter[0];\r\n        caller.coreTableRef = this.coreTable;\r\n      }\r\n\r\n      if (!!!this.freeMode) {\r\n        this.subscriptions.push(\r\n          this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].id$.subscribe(x => {\r\n            this.activeRow = x;\r\n          })\r\n        )\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].tbodyHeight$.subscribe(x => {\r\n          if (!!x) {\r\n            this.tbodyheight = x;\r\n          }\r\n        })\r\n      )\r\n\r\n      const rect = this.coreTable.nativeElement.getBoundingClientRect();\r\n      this.coreTable.nativeElement.style.setProperty('--table-width', rect.width + 'px')\r\n\r\n    }\r\n\r\n    this.scrollStream$ = fromEvent(this.table.nativeElement, 'scroll');\r\n\r\n    setTimeout(() => {\r\n\r\n      if (!!this.width) this.coreTable.nativeElement.style.setProperty('--width', this.width + 'px');\r\n      if (!!this.rowHeight) this.coreTable.nativeElement.style.setProperty('--row-height', this.rowHeight + 'px');\r\n      if (!!this.height) this.coreTable.nativeElement.style.setProperty('--height', this.height + 'px');\r\n\r\n      // Chỉ subscride sau khi các lệnh trên đã được thực hiện\r\n      this.subscriptions.push(\r\n        this.scrollStream$\r\n          .pipe(\r\n            debounceTime(50)\r\n          )\r\n          .subscribe(event => {\r\n            this.scrollTop = event.srcElement.scrollTop;\r\n            this.calculateScroll();\r\n          })\r\n      )\r\n\r\n    }, 0)\r\n\r\n    this.resetHeaderFirstRowHeight();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.resetHeaderFirstRowHeight();\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  onToolClickLocal(row: any, toolIndex: number): void {\r\n    this.onToolClick.emit({\r\n      code: this.tools[toolIndex].code,\r\n      id: row['id']\r\n    })\r\n  }\r\n\r\n  toggleCheckAll(args: boolean) {\r\n    const newCheckingModel: boolean[] = [];\r\n    const newSelectedIds: any[] = [];\r\n    const newSelectedData: any[] = [];\r\n\r\n    this.data.map(item => {\r\n      newCheckingModel.push(args);\r\n      if (args) {\r\n        newSelectedIds.push(item.id);\r\n        newSelectedData.push(item);\r\n      }\r\n    });\r\n\r\n    this.checkingModel = newCheckingModel;\r\n    this.checkingState = args ? 1 : 0;\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n  }\r\n\r\n  onCheckingNgModelChange() {\r\n    const newSelectedIds: number[] = [];\r\n    const newSelectedData: any[] = [];\r\n    this.data.filter((_: any, index: number) => !!this.checkingModel[index]).map(item => {\r\n      newSelectedIds.push(item.id)\r\n      newSelectedData.push(item)\r\n    })\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n\r\n    if (newSelectedIds.length === 0) {\r\n      this.checkingState = 0; // none\r\n    } else if (newSelectedIds.length === this.checkingModel.length) {\r\n      this.checkingState = 1; // all\r\n    } else {\r\n      this.checkingState = 2; // mixed\r\n    }\r\n\r\n  }\r\n\r\n  onDoubleClickLocal(rowIndex: number) {\r\n    this.onRowDoubleClick.emit(this.data[rowIndex])\r\n  }\r\n\r\n  onClickLocal(row: any, event: any) {\r\n\r\n    console.log(\"onClickLocal row\", row, \"event\", event)\r\n\r\n    if (event.detail === 1) {\r\n      this.activeRow = row.id;\r\n      this.onRowClick.emit(row);\r\n    } else if (event.detail === 2) {\r\n      this.onRowDoubleClick.emit(row)\r\n    }\r\n\r\n  }\r\n\r\n  onRowTouchend(rowIndex: number) {\r\n    this.rowTouchendStream$.next({\r\n      previous: this.rowTouchendStream$.value.current,\r\n      current: rowIndex\r\n    });\r\n  }\r\n\r\n  onSearch(e: string, searchColumnIndex: number): void {\r\n    this.searchObject.filter((_, i) => i === searchColumnIndex)[0].searchFor = e;\r\n    this.onSearching.emit(this.searchObject);\r\n  }\r\n\r\n  onColumnCaptionClickLocal(column: ICoreTableColumnItem) {\r\n\r\n    if (!!this.disableSorting || !!column.templateRef) return; // no action for templateRef type\r\n\r\n    this.onColumnCaptionClick.emit(column);\r\n\r\n    // update sort dicrection property of this column\r\n    // and clear up the property for the other visibleColumns\r\n    this.visibleColumns.map(vc => {\r\n      if (vc.field === column.field) {\r\n        vc.sortDirection = vc.sortDirection === EnumSortDirection.NONE ? EnumSortDirection.ASC : vc.sortDirection === EnumSortDirection.ASC ? EnumSortDirection.DESC : EnumSortDirection.NONE;\r\n      } else {\r\n        vc.sortDirection = EnumSortDirection.NONE\r\n      }\r\n    })\r\n  }\r\n\r\n  toggleAllowSearch(): void {\r\n    this.searchActive = !!!this.searchActive\r\n  }\r\n\r\n  onInlineToolClick(e: ICoreButtonVNS, row: any): void {\r\n    console.log(\"onInlineToolClick\", e, row)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n  }\r\n\r\n}\r\n","<div #coreTable class=\"core-table-container\" [class.hide-search]=\"!!!searchActive\">\r\n\r\n    <!-- \r\n        Cần truyền chính xác height của CoreTable\r\n        Tuy nhiên chiều cao của CoreTable cần được tính dựa vào chiều cao của các phần tử DOM lần lượt từ lớp ngoài vào lớp trong\r\n        Anh em chưa tính khi triển khai code, nên đang cần có con số default là 400px\r\n    -->\r\n    <table [class.wrap]=\"!!wrap\" #table [ngStyle]=\"{ height: (height || 400) + 'px' }\">\r\n        <colgroup>\r\n            @if (showCheckbox) {\r\n            <col> }\r\n            @for (col of visibleColumns; track col) {\r\n            <col> }\r\n            @if (showTools) {\r\n            <col> }\r\n        </colgroup>\r\n        <thead>\r\n            <tr #firstHeaderRow data-row=\"1\" [ngStyle]=\"{\r\n                height: headerFirstRowHeight + 'px'\r\n            }\">\r\n                @if (showCheckbox) {\r\n                <th class=\"check-col-header check-cell frozen-col\" style=\"left: 0px\"\r\n                    [attr.rowspan]=\"searchActive ? 2 : 1\" [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\">\r\n                    <!-- please do not change -->\r\n                    <div [ngStyle]=\"{\r\n                            width: checkboxSize * 2 + 'px'\r\n                        }\">\r\n                        <label class=\"checkwrap\" [ngStyle]=\"{\r\n                                height: searchActive ? headerFirstRowHeight + headerSecondRowHeight + 'px' : headerFirstRowHeight + 'px'\r\n                            }\">\r\n                            <input type=\"checkbox\" [id]=\"'check-col-header' + id\" [(ngModel)]=\"headerCheckboxState\"\r\n                                (ngModelChange)=\"toggleCheckAll($event)\">\r\n                            <span class=\"checkmark\" [class.mixed]=\"checkingState===2\" [ngStyle]=\"{\r\n                                    top: ((headerFirstRowHeight + headerSecondRowHeight * (searchActive ? 1 : 0)) /2 - checkboxSize/2) + 'px'\r\n                                }\"></span>\r\n                        </label>\r\n                    </div>\r\n                </th>\r\n                }\r\n                @for (col of visibleColumns; track col) {\r\n                <th [class.frozen-col]=\"$index < frozen\"\r\n                    [style]=\"$index < frozen ? 'left: ' + frozenLefts[$index] + 'px' : ''\" [ngStyle]=\"{\r\n                            backgroundColor: headerBackgroundColor,\r\n                            color: 'white',\r\n                            padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                        }\">\r\n                    <!-- -1px for borderBottom of header first row -->\r\n                    <div class=\"column-caption\" [class.ascending]=\"col.sortDirection===-1\"\r\n                        [class.descending]=\"col.sortDirection===1\" (click)=\"onColumnCaptionClickLocal(col)\"\r\n                        [appTooltip]=\"col.caption | translate : lang\" [ngStyle]=\"{\r\n                                width: col.width + 'px',\r\n                                height: (headerFirstRowHeight - 1) + 'px',\r\n                                display: 'flex',\r\n                                alignItems: 'center',\r\n                                whiteSpace: !!headerWrap ? 'initial' : 'inherit'\r\n                            }\">{{ col.caption | translate : lang }}</div>\r\n                    <div class=\"resizer\" (mousedown)=\"startDragging($event, col, false)\"\r\n                        (mouseup)=\"stopDragging($event, col, false)\" (mousemove)=\"moveEvent($event, col)\"></div>\r\n                </th>\r\n                }\r\n                @if (showTools && visibleColumns?.length) {\r\n                <th class=\"check-col-header check-cell\" [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\">\r\n                    <div style=\"width: 100px;\">\r\n                    </div>\r\n                </th>\r\n                }\r\n                @if (!searchSwitchDisabled) {\r\n                <th [ngStyle]=\"{\r\n                    backgroundColor: headerBackgroundColor,\r\n                    width: '50px'\r\n                }\">\r\n                    <ng-container *ngTemplateOutlet=\"searchSwitcher\"></ng-container>\r\n                </th>\r\n                }\r\n            </tr>\r\n            @if (searchActive) {\r\n            <tr data-row=\"2\" [class.hiden]=\"!!!searchActive\">\r\n                @for (col of visibleColumns; track col) {\r\n                <th [class.frozen-col]=\"$index < frozen\"\r\n                    [style]=\"$index < frozen ? 'left: ' + frozenLefts[$index] + 'px' : ''\" [ngStyle]=\"{\r\n                                backgroundColor: headerBackgroundColor,\r\n                                color: 'white',\r\n                                padding: '0px 12px'\r\n                            }\">\r\n                    @if (!col.hideSearchBox) {\r\n                    <div [style]=\"'width: ' + col.width + 'px;'\">\r\n                        <input type=\"text\" class=\"form-control search\" [(ngModel)]=\"searchObject[$index].searchFor\"\r\n                            (ngModelChange)=\"onSearch($event, $index)\">\r\n                    </div>\r\n                    }\r\n                </th>\r\n                }\r\n                <th [ngStyle]=\"{\r\n                        backgroundColor: headerBackgroundColor,\r\n                        color: 'white'\r\n                    }\"></th>\r\n            </tr>\r\n            }\r\n        </thead>\r\n\r\n        <tbody [class.loading]=\"loading\">\r\n            <core-loading-surface [loading]=\"loading\" [height]=\"tbodyheight || 500\"></core-loading-surface>\r\n\r\n            <ng-container>\r\n                @if (!!lazyLoading) {\r\n                <tr [ngStyle]=\"{ height: hiddenTopHeight + 'px' }\">\r\n                    <td>\r\n                        <div [ngStyle]=\"{ height: hiddenTopHeight + 'px' }\"></div>\r\n                    </td>\r\n                </tr>\r\n                }\r\n\r\n                @for (row of visibleData; track row) {\r\n                <tr (click)=\"onClickLocal(row, $event)\" (touchend)=\"onRowTouchend($index+startNode)\"\r\n                    [class.active]=\"row.id === activeRow && !!!disableHighlightOnClick\">\r\n\r\n                    <!-- <div class=\"row-item-tools\">\r\n                                    <div class=\"row-item-tool\">\r\n                                        <div class=\"row-item-tool-wrapper\">\r\n                                            <core-button-group-vns [shownItems]=\"inlineToolItems\"\r\n                                                (buttonClick)=\"onInlineToolClick($event, row)\"></core-button-group-vns>\r\n                                        </div>\r\n                                    </div>\r\n                                </div> -->\r\n\r\n                    @if (showCheckbox) {\r\n                    <td class=\"check-cell frozen-col\" style=\"left: 0px;\">\r\n                        <label class=\"checkwrap\">\r\n                            <input type=\"checkbox\" class=\"check-row\" [id]=\"'check-row' + ($index + startNode)\"\r\n                                [(ngModel)]=\"checkingModel[$index+startNode]\"\r\n                                (ngModelChange)=\"onCheckingNgModelChange()\">\r\n                            <span class=\"checkmark\"></span>\r\n                        </label>\r\n                    </td>\r\n                    }\r\n\r\n                    @for (col of visibleColumns; track col) {\r\n                    <td [class.frozen-col]=\"$index < frozen\" [ngStyle]=\"{\r\n                                                left: $index < frozen ? frozenLefts[$index] + 'px' : '0px',\r\n                                                padding: !!noPaddingCell ? '0px 0px' : '2px 0px'\r\n                                            }\">\r\n\r\n                        @if (!col?.templateRef) {\r\n                        <!-- IN MOST CASES WE NEED TO RENDER THE CELL WITH PRIMITIVE TYPE -->\r\n                        <div [class.scroll-y]=\"allowCellScrollY\" [ngStyle]=\"{\r\n                                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                                    lineHeight: rowHeight,\r\n                                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                                }\" [appTooltip]=\"row[col.field] | tableCell: col.pipe : lang\">{{\r\n                            row[col.field] | tableCell: col.pipe : lang }}</div>\r\n                        <!------------------------------------------------------------------>\r\n                        } @else {\r\n                        <!-- BUT SOME TIME WE NEED TO RENDER THE CELL WITH TEMPLATE -->\r\n                        <div [ngStyle]=\"{\r\n                                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                                }\">\r\n                            @if (!col?.templateRefAllowEditOnRowActived) {\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"col?.templateRef!; context: { context: row }\"></ng-container>\r\n                            } @else {\r\n                            <ng-container\r\n                                *ngTemplateOutlet=\"col?.templateRef!; context: { context: row, allowEdit: row.id === activeRow }\"></ng-container>\r\n                            }\r\n                        </div>\r\n                        <!------------------------------------------------------------------>\r\n                        }\r\n                    </td>\r\n                    }\r\n\r\n\r\n                    @if (showTools) {\r\n                    <td>\r\n                        <div class=\"tools-group d-flex-center\">\r\n                            @for (tool of tools; track tool) {\r\n                            <div [class]=\"'tools-icon ' + tool.class\"\r\n                                [class.disabled]=\"tool.disabledFn ? tool.disabledFn!(row) : false\"\r\n                                [class.hidden]=\"tool.hiddenFn ? tool.hiddenFn!(row) : false\"\r\n                                (click)=\"onToolClickLocal(row, $index)\">\r\n                            </div>\r\n                            }\r\n                        </div>\r\n                    </td>\r\n                    }\r\n                </tr>\r\n                }\r\n\r\n                @if (!!lazyLoading) {\r\n                <tr [ngStyle]=\"{\r\n                    height: hiddenBottomHeight + 'px'\r\n                }\">\r\n                    <td>\r\n                        <div [ngStyle]=\"{\r\n                                height: hiddenBottomHeight + 'px'\r\n                            }\">\r\n                        </div>\r\n                    </td>\r\n                </tr>\r\n                }\r\n\r\n            </ng-container>\r\n\r\n        </tbody>\r\n        @if (!!footer) {\r\n        <tfoot>\r\n            Footer\r\n        </tfoot>\r\n        }\r\n    </table>\r\n\r\n    <ng-template #searchSwitcher>\r\n        <div class=\"search-toggler d-flex-center pointer\" (click)=\"toggleAllowSearch()\">\r\n            <i class=\"feather-search\"></i>\r\n        </div>\r\n    </ng-template>\r\n</div>"]}
|