@worktile/gantt 18.1.0-next.2 → 19.0.0
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/components/main/gantt-main.component.d.ts +3 -2
- package/fesm2022/worktile-gantt.mjs +124 -127
- package/fesm2022/worktile-gantt.mjs.map +1 -1
- package/gantt-item-upper.d.ts +1 -1
- package/gantt-upper.d.ts +1 -1
- package/gantt.module.d.ts +1 -1
- package/gantt.pipe.d.ts +5 -5
- package/package.json +4 -6
- package/esm2022/class/baseline.mjs +0 -18
- package/esm2022/class/date-point.mjs +0 -11
- package/esm2022/class/event.mjs +0 -27
- package/esm2022/class/group.mjs +0 -17
- package/esm2022/class/index.mjs +0 -9
- package/esm2022/class/item.mjs +0 -85
- package/esm2022/class/link.mjs +0 -19
- package/esm2022/class/toolbar.mjs +0 -2
- package/esm2022/class/view-type.mjs +0 -10
- package/esm2022/components/bar/bar-drag.mjs +0 -560
- package/esm2022/components/bar/bar.component.mjs +0 -132
- package/esm2022/components/baseline/baseline.component.mjs +0 -43
- package/esm2022/components/calendar/grid/calendar-grid.component.mjs +0 -66
- package/esm2022/components/calendar/header/calendar-header.component.mjs +0 -70
- package/esm2022/components/drag-backdrop/drag-backdrop.component.mjs +0 -21
- package/esm2022/components/icon/icon.component.mjs +0 -37
- package/esm2022/components/icon/icons.mjs +0 -93
- package/esm2022/components/links/lines/curve.mjs +0 -95
- package/esm2022/components/links/lines/factory.mjs +0 -14
- package/esm2022/components/links/lines/line.mjs +0 -24
- package/esm2022/components/links/lines/straight.mjs +0 -58
- package/esm2022/components/links/links.component.mjs +0 -196
- package/esm2022/components/loader/loader.component.mjs +0 -30
- package/esm2022/components/main/gantt-main.component.mjs +0 -94
- package/esm2022/components/range/range.component.mjs +0 -25
- package/esm2022/components/scrollbar/scrollbar.component.mjs +0 -27
- package/esm2022/components/table/body/gantt-table-body.component.mjs +0 -329
- package/esm2022/components/table/header/gantt-table-header.component.mjs +0 -152
- package/esm2022/components/toolbar/toolbar.component.mjs +0 -37
- package/esm2022/gantt-abstract.mjs +0 -3
- package/esm2022/gantt-dom.service.mjs +0 -156
- package/esm2022/gantt-drag-container.mjs +0 -78
- package/esm2022/gantt-item-upper.mjs +0 -67
- package/esm2022/gantt-print.service.mjs +0 -94
- package/esm2022/gantt-upper.mjs +0 -402
- package/esm2022/gantt.component.mjs +0 -361
- package/esm2022/gantt.config.mjs +0 -69
- package/esm2022/gantt.module.mjs +0 -141
- package/esm2022/gantt.pipe.mjs +0 -61
- package/esm2022/gantt.styles.mjs +0 -10
- package/esm2022/i18n/i18n.mjs +0 -12
- package/esm2022/i18n/index.mjs +0 -18
- package/esm2022/i18n/locales/de-de.mjs +0 -51
- package/esm2022/i18n/locales/en-us.mjs +0 -49
- package/esm2022/i18n/locales/ja-jp.mjs +0 -49
- package/esm2022/i18n/locales/ru-ru.mjs +0 -51
- package/esm2022/i18n/locales/zh-hans.mjs +0 -49
- package/esm2022/i18n/locales/zh-hant.mjs +0 -49
- package/esm2022/public-api.mjs +0 -28
- package/esm2022/root.component.mjs +0 -174
- package/esm2022/table/gantt-column.component.mjs +0 -46
- package/esm2022/table/gantt-table.component.mjs +0 -49
- package/esm2022/utils/date.mjs +0 -180
- package/esm2022/utils/drag-scroll.mjs +0 -54
- package/esm2022/utils/helpers.mjs +0 -73
- package/esm2022/utils/passive-listeners.mjs +0 -30
- package/esm2022/utils/set-style-with-vendor-prefix.mjs +0 -15
- package/esm2022/views/day.mjs +0 -58
- package/esm2022/views/factory.mjs +0 -22
- package/esm2022/views/hour.mjs +0 -89
- package/esm2022/views/month.mjs +0 -52
- package/esm2022/views/quarter.mjs +0 -55
- package/esm2022/views/view.mjs +0 -177
- package/esm2022/views/week.mjs +0 -53
- package/esm2022/views/year.mjs +0 -54
- package/esm2022/worktile-gantt.mjs +0 -5
|
@@ -1,329 +0,0 @@
|
|
|
1
|
-
import { auditTime, filter, startWith, Subject, takeUntil } from 'rxjs';
|
|
2
|
-
import { Component, HostBinding, Input, Inject, Output, EventEmitter, ViewChildren } from '@angular/core';
|
|
3
|
-
import { coerceCssPixelValue } from '@angular/cdk/coercion';
|
|
4
|
-
import { GANTT_ABSTRACT_TOKEN } from '../../../gantt-abstract';
|
|
5
|
-
import { defaultColumnWidth } from '../header/gantt-table-header.component';
|
|
6
|
-
import { GANTT_UPPER_TOKEN } from '../../../gantt-upper';
|
|
7
|
-
import { CdkDrag, CdkDropList, CdkDragHandle } from '@angular/cdk/drag-drop';
|
|
8
|
-
import { DOCUMENT, NgIf, NgTemplateOutlet, NgFor, NgClass } from '@angular/common';
|
|
9
|
-
import { IsGanttRangeItemPipe } from '../../../gantt.pipe';
|
|
10
|
-
import { GanttIconComponent } from '../../icon/icon.component';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../../../gantt-upper";
|
|
13
|
-
export class GanttTableBodyComponent {
|
|
14
|
-
set viewportItems(data) {
|
|
15
|
-
const firstData = data[0];
|
|
16
|
-
if (firstData && firstData.hasOwnProperty('items')) {
|
|
17
|
-
this.hasGroup = true;
|
|
18
|
-
}
|
|
19
|
-
this.ganttTableEmptyClass = data?.length ? false : true;
|
|
20
|
-
this._viewportItems = data;
|
|
21
|
-
}
|
|
22
|
-
get viewportItems() {
|
|
23
|
-
return this._viewportItems;
|
|
24
|
-
}
|
|
25
|
-
constructor(gantt, ganttUpper, cdr, document) {
|
|
26
|
-
this.gantt = gantt;
|
|
27
|
-
this.ganttUpper = ganttUpper;
|
|
28
|
-
this.cdr = cdr;
|
|
29
|
-
this.document = document;
|
|
30
|
-
this.draggable = false;
|
|
31
|
-
this.dragDropped = new EventEmitter();
|
|
32
|
-
this.dragStarted = new EventEmitter();
|
|
33
|
-
this.dragEnded = new EventEmitter();
|
|
34
|
-
this.itemClick = new EventEmitter();
|
|
35
|
-
this.ganttTableClass = true;
|
|
36
|
-
this.ganttTableEmptyClass = false;
|
|
37
|
-
this.ganttTableDragging = false;
|
|
38
|
-
this.hasExpandIcon = false;
|
|
39
|
-
// 缓存 Element 和 DragRef 的关系,方便在 Item 拖动时查找
|
|
40
|
-
this.itemDragsMap = new Map();
|
|
41
|
-
this.itemDragMoved = new Subject();
|
|
42
|
-
this.destroy$ = new Subject();
|
|
43
|
-
}
|
|
44
|
-
ngOnInit() {
|
|
45
|
-
this.columns.changes.pipe(startWith(this.columns), takeUntil(this.destroy$)).subscribe(() => {
|
|
46
|
-
this.hasExpandIcon = false;
|
|
47
|
-
this.columns.forEach((column) => {
|
|
48
|
-
if (!column.columnWidth) {
|
|
49
|
-
column.columnWidth = coerceCssPixelValue(defaultColumnWidth);
|
|
50
|
-
}
|
|
51
|
-
if (column.showExpandIcon) {
|
|
52
|
-
this.hasExpandIcon = true;
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
this.cdr.detectChanges();
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
ngAfterViewInit() {
|
|
59
|
-
this.cdkDrags.changes
|
|
60
|
-
.pipe(startWith(this.cdkDrags), takeUntil(this.destroy$))
|
|
61
|
-
.subscribe((drags) => {
|
|
62
|
-
this.itemDragsMap.clear();
|
|
63
|
-
drags.forEach((drag) => {
|
|
64
|
-
if (drag.data) {
|
|
65
|
-
// cdkDrag 变化时,缓存 Element 与 DragRef 的关系,方便 Drag Move 时查找
|
|
66
|
-
this.itemDragsMap.set(drag.element.nativeElement, drag);
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
this.itemDragMoved
|
|
71
|
-
.pipe(auditTime(30),
|
|
72
|
-
// auditTime 可能会导致拖动结束后仍然执行 moved ,所以通过判断 dragging 状态来过滤无效 moved
|
|
73
|
-
filter((event) => event.source._dragRef.isDragging()), takeUntil(this.destroy$))
|
|
74
|
-
.subscribe((event) => {
|
|
75
|
-
this.onItemDragMoved(event);
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
expandGroup(group) {
|
|
79
|
-
this.gantt.expandGroup(group);
|
|
80
|
-
}
|
|
81
|
-
expandChildren(event, item) {
|
|
82
|
-
event.stopPropagation();
|
|
83
|
-
this.gantt.expandChildren(item);
|
|
84
|
-
}
|
|
85
|
-
onItemDragStarted(event) {
|
|
86
|
-
this.ganttTableDragging = true;
|
|
87
|
-
// 拖动开始时隐藏所有的子项
|
|
88
|
-
const children = this.getChildrenElementsByElement(event.source.element.nativeElement);
|
|
89
|
-
children.forEach((element) => {
|
|
90
|
-
element.classList.add('drag-item-hide');
|
|
91
|
-
});
|
|
92
|
-
this.dragStarted.emit({
|
|
93
|
-
source: event.source.data?.origin,
|
|
94
|
-
sourceParent: this.getParentByItem(event.source.data)?.origin
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
emitItemDragMoved(event) {
|
|
98
|
-
this.itemDragMoved.next(event);
|
|
99
|
-
}
|
|
100
|
-
onItemDragMoved(event) {
|
|
101
|
-
// 通过鼠标位置查找对应的目标 Item 元素
|
|
102
|
-
let currentPointElement = this.document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y);
|
|
103
|
-
if (!currentPointElement) {
|
|
104
|
-
this.cleanupDragArtifacts();
|
|
105
|
-
return;
|
|
106
|
-
}
|
|
107
|
-
let targetElement = currentPointElement.classList.contains('gantt-table-item')
|
|
108
|
-
? currentPointElement
|
|
109
|
-
: currentPointElement.closest('.gantt-table-item');
|
|
110
|
-
if (!targetElement) {
|
|
111
|
-
this.cleanupDragArtifacts();
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
// 缓存放置目标Id 并计算鼠标相对应的位置
|
|
115
|
-
this.itemDropTarget = {
|
|
116
|
-
id: this.itemDragsMap.get(targetElement)?.data.id,
|
|
117
|
-
position: this.getTargetPosition(targetElement, event)
|
|
118
|
-
};
|
|
119
|
-
// 执行外部传入的 dropEnterPredicate 判断是否允许拖入目标项
|
|
120
|
-
if (this.dropEnterPredicate) {
|
|
121
|
-
const targetDragRef = this.itemDragsMap.get(targetElement);
|
|
122
|
-
if (this.dropEnterPredicate({
|
|
123
|
-
source: event.source.data.origin,
|
|
124
|
-
target: targetDragRef.data.origin,
|
|
125
|
-
dropPosition: this.itemDropTarget.position
|
|
126
|
-
})) {
|
|
127
|
-
this.showDropPositionPlaceholder(targetElement);
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
this.itemDropTarget = null;
|
|
131
|
-
this.cleanupDragArtifacts(false);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
else {
|
|
135
|
-
this.showDropPositionPlaceholder(targetElement);
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
onItemDragEnded(event) {
|
|
139
|
-
this.ganttTableDragging = false;
|
|
140
|
-
this.dragEnded.emit({
|
|
141
|
-
source: event.source.data?.origin,
|
|
142
|
-
sourceParent: this.getParentByItem(event.source.data)?.origin
|
|
143
|
-
});
|
|
144
|
-
// dropEnterPredicate 方法返回值为 false 时,始终未执行 onListDropped,所以只能在 dragEnded 中移除 drag-item-hide
|
|
145
|
-
const children = this.getChildrenElementsByElement(event.source.element.nativeElement);
|
|
146
|
-
children.forEach((element) => {
|
|
147
|
-
element.classList.remove('drag-item-hide');
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
onListDropped(event) {
|
|
151
|
-
if (!this.itemDropTarget) {
|
|
152
|
-
return;
|
|
153
|
-
}
|
|
154
|
-
const sourceItem = event.item.data;
|
|
155
|
-
const sourceParent = this.getParentByItem(sourceItem);
|
|
156
|
-
const sourceChildren = this.getExpandChildrenByDrag(event.item);
|
|
157
|
-
const targetDragRef = this.cdkDrags.find((item) => item.data?.id === this.itemDropTarget.id);
|
|
158
|
-
const targetItem = targetDragRef?.data;
|
|
159
|
-
const targetParent = this.getParentByItem(targetItem);
|
|
160
|
-
this.removeItem(sourceItem, sourceChildren);
|
|
161
|
-
switch (this.itemDropTarget.position) {
|
|
162
|
-
case 'before':
|
|
163
|
-
case 'after':
|
|
164
|
-
this.insertItem(targetItem, sourceItem, sourceChildren, this.itemDropTarget.position);
|
|
165
|
-
sourceItem.updateLevel(targetItem.level);
|
|
166
|
-
break;
|
|
167
|
-
case 'inside':
|
|
168
|
-
this.insertChildrenItem(targetItem, sourceItem, sourceChildren);
|
|
169
|
-
sourceItem.updateLevel(targetItem.level + 1);
|
|
170
|
-
break;
|
|
171
|
-
}
|
|
172
|
-
this.dragDropped.emit({
|
|
173
|
-
source: sourceItem.origin,
|
|
174
|
-
sourceParent: sourceParent?.origin,
|
|
175
|
-
target: targetItem.origin,
|
|
176
|
-
targetParent: targetParent?.origin,
|
|
177
|
-
dropPosition: this.itemDropTarget.position
|
|
178
|
-
});
|
|
179
|
-
this.cleanupDragArtifacts(true);
|
|
180
|
-
}
|
|
181
|
-
trackBy(index, item) {
|
|
182
|
-
return item.id || index;
|
|
183
|
-
}
|
|
184
|
-
ngOnDestroy() {
|
|
185
|
-
this.destroy$.next();
|
|
186
|
-
this.destroy$.complete();
|
|
187
|
-
}
|
|
188
|
-
removeItem(item, children) {
|
|
189
|
-
this.viewportItems.splice(this.viewportItems.indexOf(item), 1 + children.length);
|
|
190
|
-
this.flatItems.splice(this.flatItems.indexOf(item), 1 + children.length);
|
|
191
|
-
}
|
|
192
|
-
insertItem(target, inserted, children, position) {
|
|
193
|
-
if (position === 'before') {
|
|
194
|
-
this.viewportItems.splice(this.viewportItems.indexOf(target), 0, inserted, ...children);
|
|
195
|
-
this.flatItems.splice(this.flatItems.indexOf(target), 0, inserted, ...children);
|
|
196
|
-
}
|
|
197
|
-
else {
|
|
198
|
-
const dragRef = this.cdkDrags.find((drag) => drag.data === target);
|
|
199
|
-
// 如果目标项是展开的,插入的 index 位置需要考虑子项的数量
|
|
200
|
-
let childrenCount = 0;
|
|
201
|
-
if (target.expanded) {
|
|
202
|
-
childrenCount = this.getChildrenElementsByElement(dragRef.element.nativeElement)?.length || 0;
|
|
203
|
-
}
|
|
204
|
-
this.viewportItems.splice(this.viewportItems.indexOf(target) + 1 + childrenCount, 0, inserted, ...children);
|
|
205
|
-
this.flatItems.splice(this.flatItems.indexOf(target) + 1 + childrenCount, 0, inserted, ...children);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
insertChildrenItem(target, inserted, children) {
|
|
209
|
-
if (target.expanded) {
|
|
210
|
-
this.viewportItems.splice(this.viewportItems.indexOf(target) + target.children.length + 1, 0, inserted, ...children);
|
|
211
|
-
this.flatItems.splice(this.flatItems.indexOf(target) + target.children.length + 1, 0, inserted, ...children);
|
|
212
|
-
}
|
|
213
|
-
target.children.push(inserted);
|
|
214
|
-
}
|
|
215
|
-
getParentByItem(item) {
|
|
216
|
-
return (this.flatItems || []).find((n) => {
|
|
217
|
-
return n.children?.includes(item);
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
getExpandChildrenByDrag(dragRef) {
|
|
221
|
-
if (!dragRef.data.expanded) {
|
|
222
|
-
return [];
|
|
223
|
-
}
|
|
224
|
-
else {
|
|
225
|
-
const childrenElements = this.getChildrenElementsByElement(dragRef.element.nativeElement);
|
|
226
|
-
return childrenElements.map((element) => this.itemDragsMap.get(element).data);
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
getChildrenElementsByElement(dragElement) {
|
|
230
|
-
// 通过循环持续查找 next element,如果 element 的 level 小于当前 item 的 level,则为它的 children
|
|
231
|
-
const children = [];
|
|
232
|
-
const dragRef = this.itemDragsMap.get(dragElement);
|
|
233
|
-
// 如果当前的 Drag 正在拖拽,会创建 PlaceholderElement 占位,所以以 PlaceholderElement 向下查找
|
|
234
|
-
let nextElement = (dragRef.getPlaceholderElement() || dragElement).nextElementSibling;
|
|
235
|
-
let nextDragRef = this.itemDragsMap.get(nextElement);
|
|
236
|
-
while (nextDragRef && nextDragRef.data.level > dragRef.data.level) {
|
|
237
|
-
children.push(nextElement);
|
|
238
|
-
nextElement = nextElement.nextElementSibling;
|
|
239
|
-
nextDragRef = this.itemDragsMap.get(nextElement);
|
|
240
|
-
}
|
|
241
|
-
return children;
|
|
242
|
-
}
|
|
243
|
-
getTargetPosition(target, event) {
|
|
244
|
-
const targetRect = target.getBoundingClientRect();
|
|
245
|
-
const beforeOrAfterGap = targetRect.height * 0.3;
|
|
246
|
-
// 将 Item 高度分为上中下三段,其中上下的 Gap 为 height 的 30%,通过判断鼠标位置在哪一段 gap 来计算对应的位置
|
|
247
|
-
if (event.pointerPosition.y - targetRect.top < beforeOrAfterGap) {
|
|
248
|
-
return 'before';
|
|
249
|
-
}
|
|
250
|
-
else if (event.pointerPosition.y >= targetRect.bottom - beforeOrAfterGap) {
|
|
251
|
-
return 'after';
|
|
252
|
-
}
|
|
253
|
-
else {
|
|
254
|
-
return 'inside';
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
showDropPositionPlaceholder(targetElement) {
|
|
258
|
-
this.cleanupDragArtifacts();
|
|
259
|
-
if (this.itemDropTarget && targetElement) {
|
|
260
|
-
targetElement.classList.add(`drop-position-${this.itemDropTarget.position}`);
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
cleanupDragArtifacts(dropped = false) {
|
|
264
|
-
if (dropped) {
|
|
265
|
-
this.itemDropTarget = null;
|
|
266
|
-
this.document.querySelectorAll('.drag-item-hide').forEach((element) => element.classList.remove('drag-item-hide'));
|
|
267
|
-
}
|
|
268
|
-
this.document.querySelectorAll('.drop-position-before').forEach((element) => element.classList.remove('drop-position-before'));
|
|
269
|
-
this.document.querySelectorAll('.drop-position-after').forEach((element) => element.classList.remove('drop-position-after'));
|
|
270
|
-
this.document.querySelectorAll('.drop-position-inside').forEach((element) => element.classList.remove('drop-position-inside'));
|
|
271
|
-
}
|
|
272
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttTableBodyComponent, deps: [{ token: GANTT_ABSTRACT_TOKEN }, { token: GANTT_UPPER_TOKEN }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
273
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttTableBodyComponent, isStandalone: true, selector: "gantt-table-body", inputs: { viewportItems: "viewportItems", flatItems: "flatItems", columns: "columns", groupTemplate: "groupTemplate", emptyTemplate: "emptyTemplate", rowBeforeTemplate: "rowBeforeTemplate", rowAfterTemplate: "rowAfterTemplate", draggable: "draggable", dropEnterPredicate: "dropEnterPredicate" }, outputs: { dragDropped: "dragDropped", dragStarted: "dragStarted", dragEnded: "dragEnded", itemClick: "itemClick" }, host: { properties: { "class.gantt-table-draggable": "this.draggable", "class.gantt-table-body": "this.ganttTableClass", "class.gantt-table-empty": "this.ganttTableEmptyClass", "class.gantt-table-dragging": "this.ganttTableDragging" } }, viewQueries: [{ propertyName: "cdkDrags", predicate: (CdkDrag), descendants: true }], ngImport: i0, template: "<div\n class=\"gantt-table-body-container\"\n cdkDropList\n [cdkDropListAutoScrollStep]=\"6\"\n [cdkDropListData]=\"viewportItems\"\n [cdkDropListSortingDisabled]=\"true\"\n (cdkDropListDropped)=\"onListDropped($event)\"\n>\n <ng-container *ngIf=\"!viewportItems?.length\">\n <ng-container *ngIf=\"!emptyTemplate\">\n <gantt-icon class=\"empty-icon\" iconName=\"empty\"></gantt-icon>\n <div class=\"empty-text\">\u6CA1\u6709\u6570\u636E</div>\n </ng-container>\n <ng-template [ngTemplateOutlet]=\"emptyTemplate\"></ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"viewportItems && viewportItems.length > 0\">\n <ng-container *ngFor=\"let item of viewportItems; trackBy: trackBy\">\n <div class=\"gantt-table-group\" [style.height.px]=\"gantt.styles.lineHeight\" [ngClass]=\"item.class\" *ngIf=\"item.items\">\n <div class=\"gantt-table-group-title\" [class.expanded]=\"item.expanded\" (click)=\"expandGroup(item)\">\n <gantt-icon class=\"expand-icon\" [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"></gantt-icon>\n <ng-container *ngIf=\"groupTemplate; else default\">\n <ng-template\n [ngTemplateOutlet]=\"groupTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, group: item.origin }\"\n ></ng-template>\n </ng-container>\n <ng-template #default>\n <span class=\"group-title\">{{ item.title }}</span>\n </ng-template>\n </div>\n </div>\n\n <div\n *ngIf=\"!item.items\"\n (click)=\"itemClick.emit({ event: $event, current: item.origin, selectedValue: item.origin })\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n (cdkDragStarted)=\"onItemDragStarted($event)\"\n (cdkDragEnded)=\"onItemDragEnded($event)\"\n (cdkDragMoved)=\"emitItemDragMoved($event)\"\n class=\"gantt-table-item\"\n [class.gantt-table-item-with-group]=\"hasGroup\"\n [class.gantt-table-item-first-level-group]=\"item.level === 0 && (item.type | isGanttRangeItem)\"\n [style.height.px]=\"gantt.styles.lineHeight\"\n [style.lineHeight.px]=\"gantt.styles.lineHeight\"\n [class.gantt-table-item-active]=\"ganttUpper.isSelected(item.id)\"\n >\n <ng-template\n [ngTemplateOutlet]=\"rowBeforeTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n\n <div [classList]=\"column.classList\" *ngFor=\"let column of columns; let first = first\" [style.width]=\"column.columnWidth\">\n <!-- drag icon -->\n <gantt-icon\n *ngIf=\"first && draggable\"\n class=\"gantt-drag-handle\"\n iconName=\"drag\"\n cdkDragHandle\n [cdkDragHandleDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n ></gantt-icon>\n <!-- expand icon -->\n <div\n *ngIf=\"column?.showExpandIcon || (!hasExpandIcon && first)\"\n class=\"gantt-expand-icon\"\n [style.marginLeft.px]=\"item.level * 20\"\n >\n <ng-container *ngIf=\"item.level < gantt.maxLevel - 1 && ((gantt.async && item.expandable) || item.children?.length > 0)\">\n <gantt-icon\n *ngIf=\"!item.loading\"\n class=\"expand-icon\"\n [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"\n (click)=\"expandChildren($event, item)\"\n >\n </gantt-icon>\n <gantt-icon *ngIf=\"item.loading\" [iconName]=\"'loading'\"></gantt-icon>\n </ng-container>\n </div>\n <!-- column content -->\n <div class=\"gantt-table-column-content\">\n <ng-template\n [ngTemplateOutlet]=\"column.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n </div>\n </div>\n <ng-template\n [ngTemplateOutlet]=\"rowAfterTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n </div>\n </ng-container>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: GanttIconComponent, selector: "gantt-icon", inputs: ["iconName"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "pipe", type: IsGanttRangeItemPipe, name: "isGanttRangeItem" }] }); }
|
|
274
|
-
}
|
|
275
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttTableBodyComponent, decorators: [{
|
|
276
|
-
type: Component,
|
|
277
|
-
args: [{ selector: 'gantt-table-body', standalone: true, imports: [CdkDropList, NgIf, GanttIconComponent, NgTemplateOutlet, NgFor, NgClass, CdkDrag, CdkDragHandle, IsGanttRangeItemPipe], template: "<div\n class=\"gantt-table-body-container\"\n cdkDropList\n [cdkDropListAutoScrollStep]=\"6\"\n [cdkDropListData]=\"viewportItems\"\n [cdkDropListSortingDisabled]=\"true\"\n (cdkDropListDropped)=\"onListDropped($event)\"\n>\n <ng-container *ngIf=\"!viewportItems?.length\">\n <ng-container *ngIf=\"!emptyTemplate\">\n <gantt-icon class=\"empty-icon\" iconName=\"empty\"></gantt-icon>\n <div class=\"empty-text\">\u6CA1\u6709\u6570\u636E</div>\n </ng-container>\n <ng-template [ngTemplateOutlet]=\"emptyTemplate\"></ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"viewportItems && viewportItems.length > 0\">\n <ng-container *ngFor=\"let item of viewportItems; trackBy: trackBy\">\n <div class=\"gantt-table-group\" [style.height.px]=\"gantt.styles.lineHeight\" [ngClass]=\"item.class\" *ngIf=\"item.items\">\n <div class=\"gantt-table-group-title\" [class.expanded]=\"item.expanded\" (click)=\"expandGroup(item)\">\n <gantt-icon class=\"expand-icon\" [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"></gantt-icon>\n <ng-container *ngIf=\"groupTemplate; else default\">\n <ng-template\n [ngTemplateOutlet]=\"groupTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, group: item.origin }\"\n ></ng-template>\n </ng-container>\n <ng-template #default>\n <span class=\"group-title\">{{ item.title }}</span>\n </ng-template>\n </div>\n </div>\n\n <div\n *ngIf=\"!item.items\"\n (click)=\"itemClick.emit({ event: $event, current: item.origin, selectedValue: item.origin })\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n (cdkDragStarted)=\"onItemDragStarted($event)\"\n (cdkDragEnded)=\"onItemDragEnded($event)\"\n (cdkDragMoved)=\"emitItemDragMoved($event)\"\n class=\"gantt-table-item\"\n [class.gantt-table-item-with-group]=\"hasGroup\"\n [class.gantt-table-item-first-level-group]=\"item.level === 0 && (item.type | isGanttRangeItem)\"\n [style.height.px]=\"gantt.styles.lineHeight\"\n [style.lineHeight.px]=\"gantt.styles.lineHeight\"\n [class.gantt-table-item-active]=\"ganttUpper.isSelected(item.id)\"\n >\n <ng-template\n [ngTemplateOutlet]=\"rowBeforeTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n\n <div [classList]=\"column.classList\" *ngFor=\"let column of columns; let first = first\" [style.width]=\"column.columnWidth\">\n <!-- drag icon -->\n <gantt-icon\n *ngIf=\"first && draggable\"\n class=\"gantt-drag-handle\"\n iconName=\"drag\"\n cdkDragHandle\n [cdkDragHandleDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n ></gantt-icon>\n <!-- expand icon -->\n <div\n *ngIf=\"column?.showExpandIcon || (!hasExpandIcon && first)\"\n class=\"gantt-expand-icon\"\n [style.marginLeft.px]=\"item.level * 20\"\n >\n <ng-container *ngIf=\"item.level < gantt.maxLevel - 1 && ((gantt.async && item.expandable) || item.children?.length > 0)\">\n <gantt-icon\n *ngIf=\"!item.loading\"\n class=\"expand-icon\"\n [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"\n (click)=\"expandChildren($event, item)\"\n >\n </gantt-icon>\n <gantt-icon *ngIf=\"item.loading\" [iconName]=\"'loading'\"></gantt-icon>\n </ng-container>\n </div>\n <!-- column content -->\n <div class=\"gantt-table-column-content\">\n <ng-template\n [ngTemplateOutlet]=\"column.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n </div>\n </div>\n <ng-template\n [ngTemplateOutlet]=\"rowAfterTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n </div>\n </ng-container>\n </ng-container>\n</div>\n" }]
|
|
278
|
-
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
279
|
-
type: Inject,
|
|
280
|
-
args: [GANTT_ABSTRACT_TOKEN]
|
|
281
|
-
}] }, { type: i1.GanttUpper, decorators: [{
|
|
282
|
-
type: Inject,
|
|
283
|
-
args: [GANTT_UPPER_TOKEN]
|
|
284
|
-
}] }, { type: i0.ChangeDetectorRef }, { type: Document, decorators: [{
|
|
285
|
-
type: Inject,
|
|
286
|
-
args: [DOCUMENT]
|
|
287
|
-
}] }], propDecorators: { viewportItems: [{
|
|
288
|
-
type: Input
|
|
289
|
-
}], flatItems: [{
|
|
290
|
-
type: Input
|
|
291
|
-
}], columns: [{
|
|
292
|
-
type: Input
|
|
293
|
-
}], groupTemplate: [{
|
|
294
|
-
type: Input
|
|
295
|
-
}], emptyTemplate: [{
|
|
296
|
-
type: Input
|
|
297
|
-
}], rowBeforeTemplate: [{
|
|
298
|
-
type: Input
|
|
299
|
-
}], rowAfterTemplate: [{
|
|
300
|
-
type: Input
|
|
301
|
-
}], draggable: [{
|
|
302
|
-
type: HostBinding,
|
|
303
|
-
args: ['class.gantt-table-draggable']
|
|
304
|
-
}, {
|
|
305
|
-
type: Input
|
|
306
|
-
}], dropEnterPredicate: [{
|
|
307
|
-
type: Input
|
|
308
|
-
}], dragDropped: [{
|
|
309
|
-
type: Output
|
|
310
|
-
}], dragStarted: [{
|
|
311
|
-
type: Output
|
|
312
|
-
}], dragEnded: [{
|
|
313
|
-
type: Output
|
|
314
|
-
}], itemClick: [{
|
|
315
|
-
type: Output
|
|
316
|
-
}], ganttTableClass: [{
|
|
317
|
-
type: HostBinding,
|
|
318
|
-
args: ['class.gantt-table-body']
|
|
319
|
-
}], ganttTableEmptyClass: [{
|
|
320
|
-
type: HostBinding,
|
|
321
|
-
args: ['class.gantt-table-empty']
|
|
322
|
-
}], ganttTableDragging: [{
|
|
323
|
-
type: HostBinding,
|
|
324
|
-
args: ['class.gantt-table-dragging']
|
|
325
|
-
}], cdkDrags: [{
|
|
326
|
-
type: ViewChildren,
|
|
327
|
-
args: [(CdkDrag)]
|
|
328
|
-
}] } });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gantt-table-body.component.js","sourceRoot":"","sources":["../../../../../../packages/gantt/src/components/table/body/gantt-table-body.component.ts","../../../../../../packages/gantt/src/components/table/body/gantt-table-body.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAgB,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACtF,OAAO,EACH,SAAS,EACT,WAAW,EAGX,KAAK,EAEL,MAAM,EACN,MAAM,EACN,YAAY,EAGZ,YAAY,EAEf,MAAM,eAAe,CAAC;AAYvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAA0B,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAc,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAE,OAAO,EAA+D,WAAW,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAC1I,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACnF,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;;;AAO/D,MAAM,OAAO,uBAAuB;IAEhC,IAAa,aAAa,CAAC,IAAgD;QACvE,MAAM,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1B,IAAI,SAAS,IAAI,SAAS,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;YACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,oBAAoB,GAAG,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;QACxD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;IAC/B,CAAC;IAED,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAqDD,YACyC,KAA6B,EAChC,UAAsB,EAChD,GAAsB,EACJ,QAAkB;QAHP,UAAK,GAAL,KAAK,CAAwB;QAChC,eAAU,GAAV,UAAU,CAAY;QAChD,QAAG,GAAH,GAAG,CAAmB;QACJ,aAAQ,GAAR,QAAQ,CAAU;QAzChD,cAAS,GAAG,KAAK,CAAC;QAIR,gBAAW,GAAG,IAAI,YAAY,EAA8B,CAAC;QAE7D,gBAAW,GAAG,IAAI,YAAY,EAA8B,CAAC;QAE7D,cAAS,GAAG,IAAI,YAAY,EAA4B,CAAC;QAEzD,cAAS,GAAG,IAAI,YAAY,EAAsB,CAAC;QAEtB,oBAAe,GAAG,IAAI,CAAC;QAEtB,yBAAoB,GAAG,KAAK,CAAC;QAE1B,uBAAkB,GAAG,KAAK,CAAC;QAM/D,kBAAa,GAAG,KAAK,CAAC;QAE7B,0CAA0C;QAClC,iBAAY,GAAG,IAAI,GAAG,EAA2C,CAAC;QAElE,kBAAa,GAAG,IAAI,OAAO,EAAe,CAAC;QAQ3C,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAOpC,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACxF,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC5B,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;oBACtB,MAAM,CAAC,WAAW,GAAG,mBAAmB,CAAC,kBAAkB,CAAC,CAAC;gBACjE,CAAC;gBACD,IAAI,MAAM,CAAC,cAAc,EAAE,CAAC;oBACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC9B,CAAC;YACL,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACX,IAAI,CAAC,QAAQ,CAAC,OAAO;aAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACxD,SAAS,CAAC,CAAC,KAA4C,EAAE,EAAE;YACxD,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;YAC1B,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBACnB,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;oBACZ,wDAAwD;oBACxD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBAC5D,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,aAAa;aACb,IAAI,CACD,SAAS,CAAC,EAAE,CAAC;QACb,iEAAiE;QACjE,MAAM,CAAC,CAAC,KAAkB,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC,EAClE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW,CAAC,KAAyB;QACjC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,IAAuB;QACrD,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,iBAAiB,CAAC,KAAsC;QACpD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,eAAe;QACf,MAAM,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACvF,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACzB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAClB,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM;YACjC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM;SAChE,CAAC,CAAC;IACP,CAAC;IAED,iBAAiB,CAAC,KAAkB;QAChC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,eAAe,CAAC,KAAqC;QACjD,wBAAwB;QACxB,IAAI,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC,CAAgB,CAAC;QAC1H,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QACD,IAAI,aAAa,GAAG,mBAAmB,CAAC,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC;YAC1E,CAAC,CAAC,mBAAmB;YACrB,CAAC,CAAE,mBAAmB,CAAC,OAAO,CAAC,mBAAmB,CAAiB,CAAC;QACxE,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QAED,uBAAuB;QACvB,IAAI,CAAC,cAAc,GAAG;YAClB,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,EAAE;YACjD,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,KAAK,CAAC;SACzD,CAAC;QAEF,yCAAyC;QACzC,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YAC3D,IACI,IAAI,CAAC,kBAAkB,CAAC;gBACpB,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM;gBAChC,MAAM,EAAE,aAAa,CAAC,IAAI,CAAC,MAAM;gBACjC,YAAY,EAAE,IAAI,CAAC,cAAc,CAAC,QAAQ;aAC7C,CAAC,EACJ,CAAC;gBACC,IAAI,CAAC,2BAA2B,CAAC,aAAa,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YACrC,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,2BAA2B,CAAC,aAAa,CAAC,CAAC;QACpD,CAAC;IACL,CAAC;IAED,eAAe,CAAC,KAAoC;QAChD,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAEhC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAChB,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM;YACjC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM;SAChE,CAAC,CAAC;QACH,2FAA2F;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACvF,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACzB,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,KAA+E;QACzF,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;QACnC,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACtD,MAAM,cAAc,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAEhE,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,KAAK,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QAC7F,MAAM,UAAU,GAAG,aAAa,EAAE,IAAI,CAAC;QACvC,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAEtD,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;QAE5C,QAAQ,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;YACnC,KAAK,QAAQ,CAAC;YACd,KAAK,OAAO;gBACR,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;gBACtF,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACzC,MAAM;YACV,KAAK,QAAQ;gBACT,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC;gBAChE,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;gBAC7C,MAAM;QACd,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAClB,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,YAAY,EAAE,YAAY,EAAE,MAAM;YAClC,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,YAAY,EAAE,YAAY,EAAE,MAAM;YAClC,YAAY,EAAE,IAAI,CAAC,cAAc,CAAC,QAAQ;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,OAAO,CAAC,KAAa,EAAE,IAA4C;QAC/D,OAAO,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC;IAC5B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAEO,UAAU,CAAC,IAAuB,EAAE,QAA6B;QACrE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;QACjF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC7E,CAAC;IAEO,UAAU,CACd,MAAyB,EACzB,QAA2B,EAC3B,QAA6B,EAC7B,QAA4B;QAE5B,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;YACxB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;YACxF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;QACpF,CAAC;aAAM,CAAC;YACJ,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;YACnE,kCAAkC;YAClC,IAAI,aAAa,GAAG,CAAC,CAAC;YACtB,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAClB,aAAa,GAAG,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC,CAAC;YAClG,CAAC;YACD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;YAC5G,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;QACxG,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,MAAyB,EAAE,QAA2B,EAAE,QAA6B;QAC5G,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;YACrH,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,CAAC;QACjH,CAAC;QACD,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAEO,eAAe,CAAC,IAAuB;QAC3C,OAAO,CAAC,IAAI,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAoB,EAAE,EAAE;YACxD,OAAO,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,uBAAuB,CAAC,OAAmC;QAC/D,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,OAAO,EAAE,CAAC;QACd,CAAC;aAAM,CAAC;YACJ,MAAM,gBAAgB,GAAG,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC1F,OAAO,gBAAgB,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;QAClF,CAAC;IACL,CAAC;IAEO,4BAA4B,CAAC,WAAwB;QACzD,2EAA2E;QAC3E,MAAM,QAAQ,GAAkB,EAAE,CAAC;QACnC,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAEnD,wEAAwE;QACxE,IAAI,WAAW,GAAG,CAAC,OAAO,CAAC,qBAAqB,EAAE,IAAI,WAAW,CAAC,CAAC,kBAAiC,CAAC;QACrG,IAAI,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAErD,OAAO,WAAW,IAAI,WAAW,CAAC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC3B,WAAW,GAAG,WAAW,CAAC,kBAAiC,CAAC;YAC5D,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACrD,CAAC;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;IAEO,iBAAiB,CAAC,MAAmB,EAAE,KAAkB;QAC7D,MAAM,UAAU,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;QAClD,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,GAAG,GAAG,CAAC;QACjD,sEAAsE;QACtE,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,gBAAgB,EAAE,CAAC;YAC9D,OAAO,QAAQ,CAAC;QACpB,CAAC;aAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,IAAI,UAAU,CAAC,MAAM,GAAG,gBAAgB,EAAE,CAAC;YACzE,OAAO,OAAO,CAAC;QACnB,CAAC;aAAM,CAAC;YACJ,OAAO,QAAQ,CAAC;QACpB,CAAC;IACL,CAAC;IAEO,2BAA2B,CAAC,aAA0B;QAC1D,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,IAAI,CAAC,cAAc,IAAI,aAAa,EAAE,CAAC;YACvC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC;QACjF,CAAC;IACL,CAAC;IAEO,oBAAoB,CAAC,OAAO,GAAG,KAAK;QACxC,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;QACvH,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC;QAC/H,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAC7H,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC;IACnI,CAAC;8GAhVQ,uBAAuB,kBAmEpB,oBAAoB,aACpB,iBAAiB,8CAEjB,QAAQ;kGAtEX,uBAAuB,ovBA+ClB,CAAA,OAAe,CAAA,gDCxFjC,0yIAgGA,4CDzDc,WAAW,8fAAE,IAAI,6FAAE,kBAAkB,6EAAE,gBAAgB,oJAAE,KAAK,mHAAE,OAAO,oFAAE,OAAO,wcAAE,aAAa,0FAAE,oBAAoB;;2FAEtH,uBAAuB;kBANnC,SAAS;+BACI,kBAAkB,cAEhB,IAAI,WACP,CAAC,WAAW,EAAE,IAAI,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,oBAAoB,CAAC;;0BAqE3H,MAAM;2BAAC,oBAAoB;;0BAC3B,MAAM;2BAAC,iBAAiB;;0BAExB,MAAM;2BAAC,QAAQ;yCApEP,aAAa;sBAAzB,KAAK;gBAaG,SAAS;sBAAjB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAIN,SAAS;sBAFR,WAAW;uBAAC,6BAA6B;;sBACzC,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBAEG,SAAS;sBAAlB,MAAM;gBAEG,SAAS;sBAAlB,MAAM;gBAEgC,eAAe;sBAArD,WAAW;uBAAC,wBAAwB;gBAEG,oBAAoB;sBAA3D,WAAW;uBAAC,yBAAyB;gBAEK,kBAAkB;sBAA5D,WAAW;uBAAC,4BAA4B;gBAEV,QAAQ;sBAAtC,YAAY;uBAAC,CAAA,OAAe,CAAA","sourcesContent":["import { auditTime, debounceTime, filter, startWith, Subject, takeUntil } from 'rxjs';\nimport {\n    Component,\n    HostBinding,\n    TemplateRef,\n    QueryList,\n    Input,\n    OnInit,\n    Inject,\n    Output,\n    EventEmitter,\n    OnDestroy,\n    ChangeDetectorRef,\n    ViewChildren,\n    AfterViewInit\n} from '@angular/core';\nimport {\n    GanttItemInternal,\n    GanttGroupInternal,\n    GanttSelectedEvent,\n    GanttTableDropPosition,\n    GanttTableDragEnterPredicateContext,\n    GanttTableDragDroppedEvent,\n    GanttTableDragStartedEvent,\n    GanttTableDragEndedEvent\n} from '../../../class';\nimport { NgxGanttTableColumnComponent } from '../../../table/gantt-column.component';\nimport { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { GanttAbstractComponent, GANTT_ABSTRACT_TOKEN } from '../../../gantt-abstract';\nimport { defaultColumnWidth } from '../header/gantt-table-header.component';\nimport { GanttUpper, GANTT_UPPER_TOKEN } from '../../../gantt-upper';\nimport { CdkDrag, CdkDragDrop, CdkDragEnd, CdkDragMove, CdkDragStart, DragRef, CdkDropList, CdkDragHandle } from '@angular/cdk/drag-drop';\nimport { DOCUMENT, NgIf, NgTemplateOutlet, NgFor, NgClass } from '@angular/common';\nimport { IsGanttRangeItemPipe } from '../../../gantt.pipe';\nimport { GanttIconComponent } from '../../icon/icon.component';\n@Component({\n    selector: 'gantt-table-body',\n    templateUrl: './gantt-table-body.component.html',\n    standalone: true,\n    imports: [CdkDropList, NgIf, GanttIconComponent, NgTemplateOutlet, NgFor, NgClass, CdkDrag, CdkDragHandle, IsGanttRangeItemPipe]\n})\nexport class GanttTableBodyComponent implements OnInit, OnDestroy, AfterViewInit {\n    private _viewportItems: (GanttGroupInternal | GanttItemInternal)[];\n    @Input() set viewportItems(data: (GanttGroupInternal | GanttItemInternal)[]) {\n        const firstData = data[0];\n        if (firstData && firstData.hasOwnProperty('items')) {\n            this.hasGroup = true;\n        }\n        this.ganttTableEmptyClass = data?.length ? false : true;\n        this._viewportItems = data;\n    }\n\n    get viewportItems() {\n        return this._viewportItems;\n    }\n\n    @Input() flatItems: (GanttGroupInternal | GanttItemInternal)[];\n\n    @Input() columns: QueryList<NgxGanttTableColumnComponent>;\n\n    @Input() groupTemplate: TemplateRef<any>;\n\n    @Input() emptyTemplate: TemplateRef<any>;\n\n    @Input() rowBeforeTemplate: TemplateRef<any>;\n\n    @Input() rowAfterTemplate: TemplateRef<any>;\n\n    @HostBinding('class.gantt-table-draggable')\n    @Input()\n    draggable = false;\n\n    @Input() dropEnterPredicate?: (context: GanttTableDragEnterPredicateContext) => boolean;\n\n    @Output() dragDropped = new EventEmitter<GanttTableDragDroppedEvent>();\n\n    @Output() dragStarted = new EventEmitter<GanttTableDragStartedEvent>();\n\n    @Output() dragEnded = new EventEmitter<GanttTableDragEndedEvent>();\n\n    @Output() itemClick = new EventEmitter<GanttSelectedEvent>();\n\n    @HostBinding('class.gantt-table-body') ganttTableClass = true;\n\n    @HostBinding('class.gantt-table-empty') ganttTableEmptyClass = false;\n\n    @HostBinding('class.gantt-table-dragging') ganttTableDragging = false;\n\n    @ViewChildren(CdkDrag<string>) cdkDrags: QueryList<CdkDrag<GanttItemInternal>>;\n\n    public hasGroup: boolean;\n\n    public hasExpandIcon = false;\n\n    // 缓存 Element 和 DragRef 的关系，方便在 Item 拖动时查找\n    private itemDragsMap = new Map<HTMLElement, CdkDrag<GanttItemInternal>>();\n\n    private itemDragMoved = new Subject<CdkDragMove>();\n\n    // Item 拖动经过目标时临时记录目标id以及相对应目标的位置\n    private itemDropTarget: {\n        position?: GanttTableDropPosition;\n        id?: string;\n    };\n\n    private destroy$ = new Subject<void>();\n\n    constructor(\n        @Inject(GANTT_ABSTRACT_TOKEN) public gantt: GanttAbstractComponent,\n        @Inject(GANTT_UPPER_TOKEN) public ganttUpper: GanttUpper,\n        private cdr: ChangeDetectorRef,\n        @Inject(DOCUMENT) private document: Document\n    ) {}\n\n    ngOnInit() {\n        this.columns.changes.pipe(startWith(this.columns), takeUntil(this.destroy$)).subscribe(() => {\n            this.hasExpandIcon = false;\n            this.columns.forEach((column) => {\n                if (!column.columnWidth) {\n                    column.columnWidth = coerceCssPixelValue(defaultColumnWidth);\n                }\n                if (column.showExpandIcon) {\n                    this.hasExpandIcon = true;\n                }\n            });\n            this.cdr.detectChanges();\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.cdkDrags.changes\n            .pipe(startWith(this.cdkDrags), takeUntil(this.destroy$))\n            .subscribe((drags: QueryList<CdkDrag<GanttItemInternal>>) => {\n                this.itemDragsMap.clear();\n                drags.forEach((drag) => {\n                    if (drag.data) {\n                        // cdkDrag 变化时，缓存 Element 与 DragRef 的关系，方便 Drag Move 时查找\n                        this.itemDragsMap.set(drag.element.nativeElement, drag);\n                    }\n                });\n            });\n\n        this.itemDragMoved\n            .pipe(\n                auditTime(30),\n                //  auditTime 可能会导致拖动结束后仍然执行 moved ，所以通过判断 dragging 状态来过滤无效 moved\n                filter((event: CdkDragMove) => event.source._dragRef.isDragging()),\n                takeUntil(this.destroy$)\n            )\n            .subscribe((event) => {\n                this.onItemDragMoved(event);\n            });\n    }\n\n    expandGroup(group: GanttGroupInternal) {\n        this.gantt.expandGroup(group);\n    }\n\n    expandChildren(event: MouseEvent, item: GanttItemInternal) {\n        event.stopPropagation();\n        this.gantt.expandChildren(item);\n    }\n\n    onItemDragStarted(event: CdkDragStart<GanttItemInternal>) {\n        this.ganttTableDragging = true;\n        // 拖动开始时隐藏所有的子项\n        const children = this.getChildrenElementsByElement(event.source.element.nativeElement);\n        children.forEach((element) => {\n            element.classList.add('drag-item-hide');\n        });\n        this.dragStarted.emit({\n            source: event.source.data?.origin,\n            sourceParent: this.getParentByItem(event.source.data)?.origin\n        });\n    }\n\n    emitItemDragMoved(event: CdkDragMove) {\n        this.itemDragMoved.next(event);\n    }\n\n    onItemDragMoved(event: CdkDragMove<GanttItemInternal>) {\n        // 通过鼠标位置查找对应的目标 Item 元素\n        let currentPointElement = this.document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y) as HTMLElement;\n        if (!currentPointElement) {\n            this.cleanupDragArtifacts();\n            return;\n        }\n        let targetElement = currentPointElement.classList.contains('gantt-table-item')\n            ? currentPointElement\n            : (currentPointElement.closest('.gantt-table-item') as HTMLElement);\n        if (!targetElement) {\n            this.cleanupDragArtifacts();\n            return;\n        }\n\n        // 缓存放置目标Id 并计算鼠标相对应的位置\n        this.itemDropTarget = {\n            id: this.itemDragsMap.get(targetElement)?.data.id,\n            position: this.getTargetPosition(targetElement, event)\n        };\n\n        // 执行外部传入的 dropEnterPredicate 判断是否允许拖入目标项\n        if (this.dropEnterPredicate) {\n            const targetDragRef = this.itemDragsMap.get(targetElement);\n            if (\n                this.dropEnterPredicate({\n                    source: event.source.data.origin,\n                    target: targetDragRef.data.origin,\n                    dropPosition: this.itemDropTarget.position\n                })\n            ) {\n                this.showDropPositionPlaceholder(targetElement);\n            } else {\n                this.itemDropTarget = null;\n                this.cleanupDragArtifacts(false);\n            }\n        } else {\n            this.showDropPositionPlaceholder(targetElement);\n        }\n    }\n\n    onItemDragEnded(event: CdkDragEnd<GanttItemInternal>) {\n        this.ganttTableDragging = false;\n\n        this.dragEnded.emit({\n            source: event.source.data?.origin,\n            sourceParent: this.getParentByItem(event.source.data)?.origin\n        });\n        // dropEnterPredicate 方法返回值为 false 时，始终未执行 onListDropped，所以只能在 dragEnded 中移除 drag-item-hide\n        const children = this.getChildrenElementsByElement(event.source.element.nativeElement);\n        children.forEach((element) => {\n            element.classList.remove('drag-item-hide');\n        });\n    }\n\n    onListDropped(event: CdkDragDrop<GanttItemInternal[], GanttItemInternal[], GanttItemInternal>) {\n        if (!this.itemDropTarget) {\n            return;\n        }\n\n        const sourceItem = event.item.data;\n        const sourceParent = this.getParentByItem(sourceItem);\n        const sourceChildren = this.getExpandChildrenByDrag(event.item);\n\n        const targetDragRef = this.cdkDrags.find((item) => item.data?.id === this.itemDropTarget.id);\n        const targetItem = targetDragRef?.data;\n        const targetParent = this.getParentByItem(targetItem);\n\n        this.removeItem(sourceItem, sourceChildren);\n\n        switch (this.itemDropTarget.position) {\n            case 'before':\n            case 'after':\n                this.insertItem(targetItem, sourceItem, sourceChildren, this.itemDropTarget.position);\n                sourceItem.updateLevel(targetItem.level);\n                break;\n            case 'inside':\n                this.insertChildrenItem(targetItem, sourceItem, sourceChildren);\n                sourceItem.updateLevel(targetItem.level + 1);\n                break;\n        }\n\n        this.dragDropped.emit({\n            source: sourceItem.origin,\n            sourceParent: sourceParent?.origin,\n            target: targetItem.origin,\n            targetParent: targetParent?.origin,\n            dropPosition: this.itemDropTarget.position\n        });\n\n        this.cleanupDragArtifacts(true);\n    }\n\n    trackBy(index: number, item: GanttGroupInternal | GanttItemInternal) {\n        return item.id || index;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private removeItem(item: GanttItemInternal, children: GanttItemInternal[]) {\n        this.viewportItems.splice(this.viewportItems.indexOf(item), 1 + children.length);\n        this.flatItems.splice(this.flatItems.indexOf(item), 1 + children.length);\n    }\n\n    private insertItem(\n        target: GanttItemInternal,\n        inserted: GanttItemInternal,\n        children: GanttItemInternal[],\n        position: 'before' | 'after'\n    ) {\n        if (position === 'before') {\n            this.viewportItems.splice(this.viewportItems.indexOf(target), 0, inserted, ...children);\n            this.flatItems.splice(this.flatItems.indexOf(target), 0, inserted, ...children);\n        } else {\n            const dragRef = this.cdkDrags.find((drag) => drag.data === target);\n            // 如果目标项是展开的，插入的 index 位置需要考虑子项的数量\n            let childrenCount = 0;\n            if (target.expanded) {\n                childrenCount = this.getChildrenElementsByElement(dragRef.element.nativeElement)?.length || 0;\n            }\n            this.viewportItems.splice(this.viewportItems.indexOf(target) + 1 + childrenCount, 0, inserted, ...children);\n            this.flatItems.splice(this.flatItems.indexOf(target) + 1 + childrenCount, 0, inserted, ...children);\n        }\n    }\n\n    private insertChildrenItem(target: GanttItemInternal, inserted: GanttItemInternal, children: GanttItemInternal[]) {\n        if (target.expanded) {\n            this.viewportItems.splice(this.viewportItems.indexOf(target) + target.children.length + 1, 0, inserted, ...children);\n            this.flatItems.splice(this.flatItems.indexOf(target) + target.children.length + 1, 0, inserted, ...children);\n        }\n        target.children.push(inserted);\n    }\n\n    private getParentByItem(item: GanttItemInternal) {\n        return (this.flatItems || []).find((n: GanttItemInternal) => {\n            return n.children?.includes(item);\n        });\n    }\n\n    private getExpandChildrenByDrag(dragRef: CdkDrag<GanttItemInternal>) {\n        if (!dragRef.data.expanded) {\n            return [];\n        } else {\n            const childrenElements = this.getChildrenElementsByElement(dragRef.element.nativeElement);\n            return childrenElements.map((element) => this.itemDragsMap.get(element).data);\n        }\n    }\n\n    private getChildrenElementsByElement(dragElement: HTMLElement) {\n        // 通过循环持续查找 next element，如果 element 的 level 小于当前 item 的 level，则为它的 children\n        const children: HTMLElement[] = [];\n        const dragRef = this.itemDragsMap.get(dragElement);\n\n        // 如果当前的 Drag 正在拖拽，会创建 PlaceholderElement 占位，所以以 PlaceholderElement 向下查找\n        let nextElement = (dragRef.getPlaceholderElement() || dragElement).nextElementSibling as HTMLElement;\n        let nextDragRef = this.itemDragsMap.get(nextElement);\n\n        while (nextDragRef && nextDragRef.data.level > dragRef.data.level) {\n            children.push(nextElement);\n            nextElement = nextElement.nextElementSibling as HTMLElement;\n            nextDragRef = this.itemDragsMap.get(nextElement);\n        }\n\n        return children;\n    }\n\n    private getTargetPosition(target: HTMLElement, event: CdkDragMove) {\n        const targetRect = target.getBoundingClientRect();\n        const beforeOrAfterGap = targetRect.height * 0.3;\n        // 将 Item 高度分为上中下三段，其中上下的 Gap 为 height 的 30%，通过判断鼠标位置在哪一段 gap 来计算对应的位置\n        if (event.pointerPosition.y - targetRect.top < beforeOrAfterGap) {\n            return 'before';\n        } else if (event.pointerPosition.y >= targetRect.bottom - beforeOrAfterGap) {\n            return 'after';\n        } else {\n            return 'inside';\n        }\n    }\n\n    private showDropPositionPlaceholder(targetElement: HTMLElement) {\n        this.cleanupDragArtifacts();\n        if (this.itemDropTarget && targetElement) {\n            targetElement.classList.add(`drop-position-${this.itemDropTarget.position}`);\n        }\n    }\n\n    private cleanupDragArtifacts(dropped = false) {\n        if (dropped) {\n            this.itemDropTarget = null;\n            this.document.querySelectorAll('.drag-item-hide').forEach((element) => element.classList.remove('drag-item-hide'));\n        }\n        this.document.querySelectorAll('.drop-position-before').forEach((element) => element.classList.remove('drop-position-before'));\n        this.document.querySelectorAll('.drop-position-after').forEach((element) => element.classList.remove('drop-position-after'));\n        this.document.querySelectorAll('.drop-position-inside').forEach((element) => element.classList.remove('drop-position-inside'));\n    }\n}\n","<div\n  class=\"gantt-table-body-container\"\n  cdkDropList\n  [cdkDropListAutoScrollStep]=\"6\"\n  [cdkDropListData]=\"viewportItems\"\n  [cdkDropListSortingDisabled]=\"true\"\n  (cdkDropListDropped)=\"onListDropped($event)\"\n>\n  <ng-container *ngIf=\"!viewportItems?.length\">\n    <ng-container *ngIf=\"!emptyTemplate\">\n      <gantt-icon class=\"empty-icon\" iconName=\"empty\"></gantt-icon>\n      <div class=\"empty-text\">没有数据</div>\n    </ng-container>\n    <ng-template [ngTemplateOutlet]=\"emptyTemplate\"></ng-template>\n  </ng-container>\n\n  <ng-container *ngIf=\"viewportItems && viewportItems.length > 0\">\n    <ng-container *ngFor=\"let item of viewportItems; trackBy: trackBy\">\n      <div class=\"gantt-table-group\" [style.height.px]=\"gantt.styles.lineHeight\" [ngClass]=\"item.class\" *ngIf=\"item.items\">\n        <div class=\"gantt-table-group-title\" [class.expanded]=\"item.expanded\" (click)=\"expandGroup(item)\">\n          <gantt-icon class=\"expand-icon\" [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"></gantt-icon>\n          <ng-container *ngIf=\"groupTemplate; else default\">\n            <ng-template\n              [ngTemplateOutlet]=\"groupTemplate\"\n              [ngTemplateOutletContext]=\"{ $implicit: item.origin, group: item.origin }\"\n            ></ng-template>\n          </ng-container>\n          <ng-template #default>\n            <span class=\"group-title\">{{ item.title }}</span>\n          </ng-template>\n        </div>\n      </div>\n\n      <div\n        *ngIf=\"!item.items\"\n        (click)=\"itemClick.emit({ event: $event, current: item.origin, selectedValue: item.origin })\"\n        cdkDrag\n        [cdkDragData]=\"item\"\n        [cdkDragDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n        (cdkDragStarted)=\"onItemDragStarted($event)\"\n        (cdkDragEnded)=\"onItemDragEnded($event)\"\n        (cdkDragMoved)=\"emitItemDragMoved($event)\"\n        class=\"gantt-table-item\"\n        [class.gantt-table-item-with-group]=\"hasGroup\"\n        [class.gantt-table-item-first-level-group]=\"item.level === 0 && (item.type | isGanttRangeItem)\"\n        [style.height.px]=\"gantt.styles.lineHeight\"\n        [style.lineHeight.px]=\"gantt.styles.lineHeight\"\n        [class.gantt-table-item-active]=\"ganttUpper.isSelected(item.id)\"\n      >\n        <ng-template\n          [ngTemplateOutlet]=\"rowBeforeTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n        ></ng-template>\n\n        <div [classList]=\"column.classList\" *ngFor=\"let column of columns; let first = first\" [style.width]=\"column.columnWidth\">\n          <!-- drag icon -->\n          <gantt-icon\n            *ngIf=\"first && draggable\"\n            class=\"gantt-drag-handle\"\n            iconName=\"drag\"\n            cdkDragHandle\n            [cdkDragHandleDisabled]=\"(draggable && item.itemDraggable === false) || !draggable\"\n          ></gantt-icon>\n          <!-- expand icon -->\n          <div\n            *ngIf=\"column?.showExpandIcon || (!hasExpandIcon && first)\"\n            class=\"gantt-expand-icon\"\n            [style.marginLeft.px]=\"item.level * 20\"\n          >\n            <ng-container *ngIf=\"item.level < gantt.maxLevel - 1 && ((gantt.async && item.expandable) || item.children?.length > 0)\">\n              <gantt-icon\n                *ngIf=\"!item.loading\"\n                class=\"expand-icon\"\n                [iconName]=\"item.expanded ? 'angle-down' : 'angle-right'\"\n                (click)=\"expandChildren($event, item)\"\n              >\n              </gantt-icon>\n              <gantt-icon *ngIf=\"item.loading\" [iconName]=\"'loading'\"></gantt-icon>\n            </ng-container>\n          </div>\n          <!-- column content -->\n          <div class=\"gantt-table-column-content\">\n            <ng-template\n              [ngTemplateOutlet]=\"column.templateRef\"\n              [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n            ></ng-template>\n          </div>\n        </div>\n        <ng-template\n          [ngTemplateOutlet]=\"rowAfterTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n        ></ng-template>\n      </div>\n    </ng-container>\n  </ng-container>\n</div>\n"]}
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
import { Component, HostBinding, Input, ViewChild, Inject } from '@angular/core';
|
|
2
|
-
import { CdkDrag } from '@angular/cdk/drag-drop';
|
|
3
|
-
import { coerceCssPixelValue } from '@angular/cdk/coercion';
|
|
4
|
-
import { GANTT_ABSTRACT_TOKEN } from '../../../gantt-abstract';
|
|
5
|
-
import { setStyleWithVendorPrefix } from '../../../utils/set-style-with-vendor-prefix';
|
|
6
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
7
|
-
import { NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
export const defaultColumnWidth = 100;
|
|
10
|
-
export const minColumnWidth = 80;
|
|
11
|
-
export class GanttTableHeaderComponent {
|
|
12
|
-
get height() {
|
|
13
|
-
return this.gantt.styles.headerHeight + 'px';
|
|
14
|
-
}
|
|
15
|
-
get lineHeight() {
|
|
16
|
-
return this.gantt.styles.headerHeight + 'px';
|
|
17
|
-
}
|
|
18
|
-
constructor(elementRef, gantt, cdr) {
|
|
19
|
-
this.elementRef = elementRef;
|
|
20
|
-
this.gantt = gantt;
|
|
21
|
-
this.cdr = cdr;
|
|
22
|
-
this.tableWidth = 0;
|
|
23
|
-
this.unsubscribe$ = new Subject();
|
|
24
|
-
this.className = `gantt-table-header `;
|
|
25
|
-
}
|
|
26
|
-
ngOnInit() {
|
|
27
|
-
this.columnsChange();
|
|
28
|
-
this.columns.changes.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
|
|
29
|
-
this.columnsChange();
|
|
30
|
-
this.gantt.cdr.detectChanges();
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
columnsChange() {
|
|
34
|
-
let tableWidth = 0;
|
|
35
|
-
this.columns.forEach((column) => {
|
|
36
|
-
if (!column.columnWidth) {
|
|
37
|
-
column.columnWidth = coerceCssPixelValue(defaultColumnWidth);
|
|
38
|
-
}
|
|
39
|
-
tableWidth += Number(column.columnWidth.replace('px', ''));
|
|
40
|
-
});
|
|
41
|
-
this.tableWidth = tableWidth;
|
|
42
|
-
}
|
|
43
|
-
dragFixed(config) {
|
|
44
|
-
if (config.movedWidth < config.minWidth) {
|
|
45
|
-
setStyleWithVendorPrefix({
|
|
46
|
-
element: config.target,
|
|
47
|
-
style: 'transform',
|
|
48
|
-
value: `translate3d(${config.minWidth - config.originWidth}px, 0, 0)`
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
onResizeStarted(event) {
|
|
53
|
-
const target = event.source.element.nativeElement;
|
|
54
|
-
this.dragStartLeft = target.getBoundingClientRect().left;
|
|
55
|
-
}
|
|
56
|
-
onResizeMoved(event, column) {
|
|
57
|
-
const target = event.source.element.nativeElement;
|
|
58
|
-
const left = target.getBoundingClientRect().left;
|
|
59
|
-
let originWidth;
|
|
60
|
-
let movedWidth;
|
|
61
|
-
let minWidth;
|
|
62
|
-
if (column) {
|
|
63
|
-
originWidth = parseInt(column.columnWidth, 10);
|
|
64
|
-
movedWidth = originWidth + (left - this.dragStartLeft);
|
|
65
|
-
minWidth = minColumnWidth;
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
originWidth = this.elementRef.nativeElement.getBoundingClientRect().width;
|
|
69
|
-
movedWidth = originWidth + (left - this.dragStartLeft);
|
|
70
|
-
minWidth = minColumnWidth * this.columns.length;
|
|
71
|
-
}
|
|
72
|
-
this.dragFixed({
|
|
73
|
-
target,
|
|
74
|
-
originWidth,
|
|
75
|
-
movedWidth,
|
|
76
|
-
minWidth
|
|
77
|
-
});
|
|
78
|
-
this.showAuxiliaryLine(event);
|
|
79
|
-
}
|
|
80
|
-
onResizeEnded(event, column) {
|
|
81
|
-
const beforeWidth = parseInt(column.columnWidth, 10);
|
|
82
|
-
const target = event.source.element.nativeElement;
|
|
83
|
-
const left = target.getBoundingClientRect().left;
|
|
84
|
-
const width = parseInt(column.columnWidth, 10) + (left - this.dragStartLeft);
|
|
85
|
-
const columnWidth = Math.max(width || 0, minColumnWidth);
|
|
86
|
-
column.columnWidth = coerceCssPixelValue(columnWidth);
|
|
87
|
-
if (this.gantt.table) {
|
|
88
|
-
this.gantt.table.columnChanges.emit({ columns: this.columns });
|
|
89
|
-
}
|
|
90
|
-
this.tableWidth = this.tableWidth - beforeWidth + columnWidth;
|
|
91
|
-
this.hideAuxiliaryLine();
|
|
92
|
-
event.source.reset();
|
|
93
|
-
}
|
|
94
|
-
onOverallResizeEnded(event) {
|
|
95
|
-
const target = event.source.element.nativeElement;
|
|
96
|
-
const left = target.getBoundingClientRect().left;
|
|
97
|
-
const tableWidth = this.elementRef.nativeElement.getBoundingClientRect().width;
|
|
98
|
-
const dragWidth = left - this.dragStartLeft;
|
|
99
|
-
let tempWidth = 0;
|
|
100
|
-
this.columns.forEach((column) => {
|
|
101
|
-
const lastColumnWidth = parseInt(column.columnWidth, 10);
|
|
102
|
-
const distributeWidth = parseInt(String(dragWidth * (lastColumnWidth / tableWidth)), 10);
|
|
103
|
-
const columnWidth = Math.max(lastColumnWidth + distributeWidth || 0, minColumnWidth);
|
|
104
|
-
column.columnWidth = coerceCssPixelValue(columnWidth);
|
|
105
|
-
tempWidth += columnWidth;
|
|
106
|
-
});
|
|
107
|
-
this.tableWidth = tempWidth;
|
|
108
|
-
if (this.gantt.table) {
|
|
109
|
-
this.gantt.table.columnChanges.emit({ columns: this.columns });
|
|
110
|
-
}
|
|
111
|
-
this.hideAuxiliaryLine();
|
|
112
|
-
event.source.reset();
|
|
113
|
-
}
|
|
114
|
-
showAuxiliaryLine(event) {
|
|
115
|
-
const tableRect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
116
|
-
const targetRect = event.source.element.nativeElement.getBoundingClientRect();
|
|
117
|
-
const distance = { x: targetRect.left - tableRect.left, y: targetRect.top - tableRect.top };
|
|
118
|
-
this.resizeLineElementRef.nativeElement.style.left = `${distance.x}px`;
|
|
119
|
-
this.resizeLineElementRef.nativeElement.style.display = 'block';
|
|
120
|
-
}
|
|
121
|
-
hideAuxiliaryLine() {
|
|
122
|
-
this.resizeLineElementRef.nativeElement.style.display = 'none';
|
|
123
|
-
}
|
|
124
|
-
ngOnDestroy() {
|
|
125
|
-
this.unsubscribe$.next();
|
|
126
|
-
this.unsubscribe$.complete();
|
|
127
|
-
}
|
|
128
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttTableHeaderComponent, deps: [{ token: i0.ElementRef }, { token: GANTT_ABSTRACT_TOKEN }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttTableHeaderComponent, isStandalone: true, selector: "gantt-table-header", inputs: { columns: "columns" }, host: { properties: { "class": "this.className", "style.height": "this.height", "style.line-height": "this.lineHeight" } }, viewQueries: [{ propertyName: "resizeLineElementRef", first: true, predicate: ["resizeLine"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"gantt-table-header-container\">\n <div class=\"gantt-table-column\" *ngFor=\"let column of columns; let i = index\" [style.width]=\"column.columnWidth\">\n <ng-container *ngIf=\"column.headerTemplateRef; else default\" [ngTemplateOutlet]=\"column.headerTemplateRef\"> </ng-container>\n <ng-template #default>\n {{ column.name }}\n </ng-template>\n <div\n class=\"column-resize-handle\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"onResizeMoved($event, column)\"\n (cdkDragStarted)=\"onResizeStarted($event)\"\n (cdkDragEnded)=\"onResizeEnded($event, column)\"\n ></div>\n </div>\n</div>\n\n<div\n class=\"table-resize-handle\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"onResizeMoved($event)\"\n (cdkDragStarted)=\"onResizeStarted($event)\"\n (cdkDragEnded)=\"onOverallResizeEnded($event)\"\n></div>\n\n<div #resizeLine class=\"table-resize-auxiliary-line\"></div>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] }); }
|
|
130
|
-
}
|
|
131
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttTableHeaderComponent, decorators: [{
|
|
132
|
-
type: Component,
|
|
133
|
-
args: [{ selector: 'gantt-table-header', standalone: true, imports: [NgFor, NgIf, NgTemplateOutlet, CdkDrag], template: "<div class=\"gantt-table-header-container\">\n <div class=\"gantt-table-column\" *ngFor=\"let column of columns; let i = index\" [style.width]=\"column.columnWidth\">\n <ng-container *ngIf=\"column.headerTemplateRef; else default\" [ngTemplateOutlet]=\"column.headerTemplateRef\"> </ng-container>\n <ng-template #default>\n {{ column.name }}\n </ng-template>\n <div\n class=\"column-resize-handle\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"onResizeMoved($event, column)\"\n (cdkDragStarted)=\"onResizeStarted($event)\"\n (cdkDragEnded)=\"onResizeEnded($event, column)\"\n ></div>\n </div>\n</div>\n\n<div\n class=\"table-resize-handle\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"onResizeMoved($event)\"\n (cdkDragStarted)=\"onResizeStarted($event)\"\n (cdkDragEnded)=\"onOverallResizeEnded($event)\"\n></div>\n\n<div #resizeLine class=\"table-resize-auxiliary-line\"></div>\n" }]
|
|
134
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
135
|
-
type: Inject,
|
|
136
|
-
args: [GANTT_ABSTRACT_TOKEN]
|
|
137
|
-
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { columns: [{
|
|
138
|
-
type: Input
|
|
139
|
-
}], resizeLineElementRef: [{
|
|
140
|
-
type: ViewChild,
|
|
141
|
-
args: ['resizeLine', { static: true }]
|
|
142
|
-
}], className: [{
|
|
143
|
-
type: HostBinding,
|
|
144
|
-
args: ['class']
|
|
145
|
-
}], height: [{
|
|
146
|
-
type: HostBinding,
|
|
147
|
-
args: ['style.height']
|
|
148
|
-
}], lineHeight: [{
|
|
149
|
-
type: HostBinding,
|
|
150
|
-
args: ['style.line-height']
|
|
151
|
-
}] } });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gantt-table-header.component.js","sourceRoot":"","sources":["../../../../../../packages/gantt/src/components/table/header/gantt-table-header.component.ts","../../../../../../packages/gantt/src/components/table/header/gantt-table-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    QueryList,\n    Input,\n    OnInit,\n    ViewChild,\n    ElementRef,\n    Inject,\n    OnDestroy,\n    ChangeDetectorRef\n} from '@angular/core';\nimport { NgxGanttTableColumnComponent } from '../../../table/gantt-column.component';\nimport { CdkDragEnd, CdkDragMove, CdkDragStart, CdkDrag } from '@angular/cdk/drag-drop';\nimport { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { GanttAbstractComponent, GANTT_ABSTRACT_TOKEN } from '../../../gantt-abstract';\nimport { setStyleWithVendorPrefix } from '../../../utils/set-style-with-vendor-prefix';\nimport { Subject, takeUntil } from 'rxjs';\nimport { NgFor, NgIf, NgTemplateOutlet } from '@angular/common';\nexport const defaultColumnWidth = 100;\nexport const minColumnWidth = 80;\ninterface DragFixedConfig {\n    target: HTMLElement;\n    originWidth: number;\n    movedWidth: number;\n    minWidth: number;\n}\n@Component({\n    selector: 'gantt-table-header',\n    templateUrl: './gantt-table-header.component.html',\n    standalone: true,\n    imports: [NgFor, NgIf, NgTemplateOutlet, CdkDrag]\n})\nexport class GanttTableHeaderComponent implements OnInit, OnDestroy {\n    public dragStartLeft: number;\n\n    public tableWidth = 0;\n\n    private unsubscribe$ = new Subject<void>();\n\n    @Input() columns: QueryList<NgxGanttTableColumnComponent>;\n\n    @ViewChild('resizeLine', { static: true }) resizeLineElementRef: ElementRef<HTMLElement>;\n\n    @HostBinding('class') className = `gantt-table-header `;\n\n    @HostBinding('style.height')\n    get height() {\n        return this.gantt.styles.headerHeight + 'px';\n    }\n\n    @HostBinding('style.line-height')\n    get lineHeight() {\n        return this.gantt.styles.headerHeight + 'px';\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        @Inject(GANTT_ABSTRACT_TOKEN) private gantt: GanttAbstractComponent,\n        private cdr: ChangeDetectorRef\n    ) {}\n\n    ngOnInit() {\n        this.columnsChange();\n        this.columns.changes.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.columnsChange();\n            this.gantt.cdr.detectChanges();\n        });\n    }\n\n    private columnsChange() {\n        let tableWidth = 0;\n        this.columns.forEach((column) => {\n            if (!column.columnWidth) {\n                column.columnWidth = coerceCssPixelValue(defaultColumnWidth);\n            }\n            tableWidth += Number(column.columnWidth.replace('px', ''));\n        });\n        this.tableWidth = tableWidth;\n    }\n\n    private dragFixed(config: DragFixedConfig) {\n        if (config.movedWidth < config.minWidth) {\n            setStyleWithVendorPrefix({\n                element: config.target,\n                style: 'transform',\n                value: `translate3d(${config.minWidth - config.originWidth}px, 0, 0)`\n            });\n        }\n    }\n\n    onResizeStarted(event: CdkDragStart) {\n        const target = event.source.element.nativeElement;\n        this.dragStartLeft = target.getBoundingClientRect().left;\n    }\n\n    onResizeMoved(event: CdkDragMove, column?: NgxGanttTableColumnComponent) {\n        const target = event.source.element.nativeElement;\n        const left = target.getBoundingClientRect().left;\n\n        let originWidth: number;\n        let movedWidth: number;\n        let minWidth: number;\n        if (column) {\n            originWidth = parseInt(column.columnWidth, 10);\n            movedWidth = originWidth + (left - this.dragStartLeft);\n            minWidth = minColumnWidth;\n        } else {\n            originWidth = this.elementRef.nativeElement.getBoundingClientRect().width;\n            movedWidth = originWidth + (left - this.dragStartLeft);\n            minWidth = minColumnWidth * this.columns.length;\n        }\n\n        this.dragFixed({\n            target,\n            originWidth,\n            movedWidth,\n            minWidth\n        });\n\n        this.showAuxiliaryLine(event);\n    }\n\n    onResizeEnded(event: CdkDragEnd, column: NgxGanttTableColumnComponent) {\n        const beforeWidth = parseInt(column.columnWidth, 10);\n        const target = event.source.element.nativeElement;\n        const left = target.getBoundingClientRect().left;\n        const width = parseInt(column.columnWidth, 10) + (left - this.dragStartLeft);\n        const columnWidth = Math.max(width || 0, minColumnWidth);\n        column.columnWidth = coerceCssPixelValue(columnWidth);\n        if (this.gantt.table) {\n            this.gantt.table.columnChanges.emit({ columns: this.columns });\n        }\n\n        this.tableWidth = this.tableWidth - beforeWidth + columnWidth;\n        this.hideAuxiliaryLine();\n        event.source.reset();\n    }\n\n    onOverallResizeEnded(event: CdkDragEnd) {\n        const target = event.source.element.nativeElement;\n        const left = target.getBoundingClientRect().left;\n        const tableWidth = this.elementRef.nativeElement.getBoundingClientRect().width;\n        const dragWidth = left - this.dragStartLeft;\n        let tempWidth = 0;\n        this.columns.forEach((column) => {\n            const lastColumnWidth = parseInt(column.columnWidth, 10);\n            const distributeWidth = parseInt(String(dragWidth * (lastColumnWidth / tableWidth)), 10);\n            const columnWidth = Math.max(lastColumnWidth + distributeWidth || 0, minColumnWidth);\n            column.columnWidth = coerceCssPixelValue(columnWidth);\n            tempWidth += columnWidth;\n        });\n        this.tableWidth = tempWidth;\n        if (this.gantt.table) {\n            this.gantt.table.columnChanges.emit({ columns: this.columns });\n        }\n\n        this.hideAuxiliaryLine();\n        event.source.reset();\n    }\n\n    private showAuxiliaryLine(event: CdkDragMove) {\n        const tableRect = this.elementRef.nativeElement.getBoundingClientRect();\n        const targetRect = event.source.element.nativeElement.getBoundingClientRect();\n        const distance = { x: targetRect.left - tableRect.left, y: targetRect.top - tableRect.top };\n        this.resizeLineElementRef.nativeElement.style.left = `${distance.x}px`;\n        this.resizeLineElementRef.nativeElement.style.display = 'block';\n    }\n\n    private hideAuxiliaryLine() {\n        this.resizeLineElementRef.nativeElement.style.display = 'none';\n    }\n\n    ngOnDestroy() {\n        this.unsubscribe$.next();\n        this.unsubscribe$.complete();\n    }\n}\n","<div class=\"gantt-table-header-container\">\n  <div class=\"gantt-table-column\" *ngFor=\"let column of columns; let i = index\" [style.width]=\"column.columnWidth\">\n    <ng-container *ngIf=\"column.headerTemplateRef; else default\" [ngTemplateOutlet]=\"column.headerTemplateRef\"> </ng-container>\n    <ng-template #default>\n      {{ column.name }}\n    </ng-template>\n    <div\n      class=\"column-resize-handle\"\n      cdkDrag\n      cdkDragLockAxis=\"x\"\n      cdkDragBoundary=\".gantt\"\n      (cdkDragMoved)=\"onResizeMoved($event, column)\"\n      (cdkDragStarted)=\"onResizeStarted($event)\"\n      (cdkDragEnded)=\"onResizeEnded($event, column)\"\n    ></div>\n  </div>\n</div>\n\n<div\n  class=\"table-resize-handle\"\n  cdkDrag\n  cdkDragLockAxis=\"x\"\n  cdkDragBoundary=\".gantt\"\n  (cdkDragMoved)=\"onResizeMoved($event)\"\n  (cdkDragStarted)=\"onResizeStarted($event)\"\n  (cdkDragEnded)=\"onOverallResizeEnded($event)\"\n></div>\n\n<div #resizeLine class=\"table-resize-auxiliary-line\"></div>\n"]}
|