@worktile/gantt 12.2.1 → 13.0.0-next.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.
Files changed (106) hide show
  1. package/components/bar/bar-drag.d.ts +4 -2
  2. package/components/bar/bar.component.d.ts +4 -4
  3. package/components/bar/bar.component.scss +201 -0
  4. package/components/calendar/calendar.component.d.ts +3 -5
  5. package/components/calendar/calendar.component.scss +79 -0
  6. package/components/drag-backdrop/drag-backdrop.component.d.ts +1 -5
  7. package/components/drag-backdrop/drag-backdrop.component.scss +50 -0
  8. package/components/icon/icon.component.d.ts +2 -4
  9. package/components/icon/icon.component.scss +13 -0
  10. package/components/links/links.component.scss +29 -0
  11. package/components/main/gantt-main.component.d.ts +2 -3
  12. package/components/range/range.component.d.ts +2 -5
  13. package/components/range/range.component.scss +35 -0
  14. package/components/table/gantt-table.component.d.ts +2 -3
  15. package/components/table/gantt-table.component.scss +153 -0
  16. package/{esm2015/class/date-point.js → esm2020/class/date-point.mjs} +0 -0
  17. package/{esm2015/class/event.js → esm2020/class/event.mjs} +0 -0
  18. package/{esm2015/class/group.js → esm2020/class/group.mjs} +0 -0
  19. package/{esm2015/class/index.js → esm2020/class/index.mjs} +0 -0
  20. package/{esm2015/class/item.js → esm2020/class/item.mjs} +0 -0
  21. package/{esm2015/class/link.js → esm2020/class/link.mjs} +0 -0
  22. package/{esm2015/class/view-type.js → esm2020/class/view-type.mjs} +0 -0
  23. package/esm2020/components/bar/bar-drag.mjs +308 -0
  24. package/esm2020/components/bar/bar.component.mjs +101 -0
  25. package/esm2020/components/calendar/calendar.component.mjs +88 -0
  26. package/esm2020/components/drag-backdrop/drag-backdrop.component.mjs +13 -0
  27. package/esm2020/components/icon/icon.component.mjs +36 -0
  28. package/{esm2015/components/icon/icons.js → esm2020/components/icon/icons.mjs} +0 -0
  29. package/esm2020/components/links/lines/curve.mjs +95 -0
  30. package/{esm2015/components/links/lines/factory.js → esm2020/components/links/lines/factory.mjs} +0 -0
  31. package/{esm2015/components/links/lines/line.js → esm2020/components/links/lines/line.mjs} +0 -0
  32. package/{esm2015/components/links/lines/straight.js → esm2020/components/links/lines/straight.mjs} +0 -0
  33. package/esm2020/components/links/links.component.mjs +178 -0
  34. package/esm2020/components/main/gantt-main.component.mjs +49 -0
  35. package/esm2020/components/range/range.component.mjs +25 -0
  36. package/esm2020/components/table/gantt-table.component.mjs +163 -0
  37. package/{esm2015/gantt-abstract.js → esm2020/gantt-abstract.mjs} +0 -0
  38. package/esm2020/gantt-dom.service.mjs +117 -0
  39. package/esm2020/gantt-drag-container.mjs +78 -0
  40. package/esm2020/gantt-item-upper.mjs +58 -0
  41. package/esm2020/gantt-print.service.mjs +94 -0
  42. package/esm2020/gantt-upper.mjs +339 -0
  43. package/esm2020/gantt.component.mjs +150 -0
  44. package/{esm2015/gantt.config.js → esm2020/gantt.config.mjs} +0 -0
  45. package/{esm2015/gantt.module.js → esm2020/gantt.module.mjs} +4 -4
  46. package/{esm2015/gantt.pipe.js → esm2020/gantt.pipe.mjs} +9 -9
  47. package/{esm2015/gantt.styles.js → esm2020/gantt.styles.mjs} +0 -0
  48. package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  49. package/esm2020/root.component.mjs +130 -0
  50. package/esm2020/table/gantt-column.component.mjs +36 -0
  51. package/esm2020/table/gantt-table.component.mjs +25 -0
  52. package/{esm2015/utils/date.js → esm2020/utils/date.mjs} +0 -0
  53. package/{esm2015/utils/helpers.js → esm2020/utils/helpers.mjs} +0 -0
  54. package/esm2020/utils/passive-listeners.mjs +30 -0
  55. package/esm2020/utils/set-style-with-vendor-prefix.mjs +15 -0
  56. package/{esm2015/views/day.js → esm2020/views/day.mjs} +1 -1
  57. package/{esm2015/views/factory.js → esm2020/views/factory.mjs} +0 -0
  58. package/{esm2015/views/month.js → esm2020/views/month.mjs} +0 -0
  59. package/{esm2015/views/quarter.js → esm2020/views/quarter.mjs} +0 -0
  60. package/{esm2015/views/view.js → esm2020/views/view.mjs} +5 -5
  61. package/{esm2015/views/week.js → esm2020/views/week.mjs} +0 -0
  62. package/{esm2015/views/year.js → esm2020/views/year.mjs} +0 -0
  63. package/{esm2015/worktile-gantt.js → esm2020/worktile-gantt.mjs} +0 -0
  64. package/fesm2015/worktile-gantt.mjs +3080 -0
  65. package/fesm2015/worktile-gantt.mjs.map +1 -0
  66. package/{fesm2015/worktile-gantt.js → fesm2020/worktile-gantt.mjs} +344 -288
  67. package/fesm2020/worktile-gantt.mjs.map +1 -0
  68. package/gantt-dom.service.d.ts +11 -4
  69. package/gantt-drag-container.d.ts +1 -1
  70. package/gantt-item-upper.d.ts +6 -6
  71. package/gantt-print.service.d.ts +1 -1
  72. package/gantt-upper.d.ts +6 -6
  73. package/gantt.component.d.ts +2 -4
  74. package/gantt.component.scss +83 -0
  75. package/package.json +23 -9
  76. package/root.component.d.ts +5 -3
  77. package/styles/index.scss +10 -0
  78. package/styles/variables.scss +46 -0
  79. package/table/gantt-column.component.d.ts +2 -3
  80. package/table/gantt-table.component.d.ts +2 -4
  81. package/utils/passive-listeners.d.ts +13 -0
  82. package/utils/set-style-with-vendor-prefix.d.ts +12 -0
  83. package/README.md +0 -24
  84. package/bundles/worktile-gantt.umd.js +0 -3622
  85. package/bundles/worktile-gantt.umd.js.map +0 -1
  86. package/esm2015/components/bar/bar-drag.js +0 -295
  87. package/esm2015/components/bar/bar.component.js +0 -98
  88. package/esm2015/components/calendar/calendar.component.js +0 -86
  89. package/esm2015/components/drag-backdrop/drag-backdrop.component.js +0 -21
  90. package/esm2015/components/icon/icon.component.js +0 -38
  91. package/esm2015/components/links/lines/curve.js +0 -96
  92. package/esm2015/components/links/links.component.js +0 -173
  93. package/esm2015/components/main/gantt-main.component.js +0 -53
  94. package/esm2015/components/range/range.component.js +0 -37
  95. package/esm2015/components/table/gantt-table.component.js +0 -163
  96. package/esm2015/gantt-dom.service.js +0 -103
  97. package/esm2015/gantt-drag-container.js +0 -77
  98. package/esm2015/gantt-item-upper.js +0 -58
  99. package/esm2015/gantt-print.service.js +0 -94
  100. package/esm2015/gantt-upper.js +0 -331
  101. package/esm2015/gantt.component.js +0 -155
  102. package/esm2015/root.component.js +0 -123
  103. package/esm2015/table/gantt-column.component.js +0 -37
  104. package/esm2015/table/gantt-table.component.js +0 -26
  105. package/fesm2015/worktile-gantt.js.map +0 -1
  106. package/main.bundle.scss +0 -687
@@ -0,0 +1,153 @@
1
+ @use '../../styles/variables';
2
+
3
+ .gantt-table {
4
+ display: block;
5
+ &-empty {
6
+ height: 100%;
7
+ position: relative;
8
+ .gantt-table-body {
9
+ position: absolute;
10
+ text-align: center;
11
+ top: 50%;
12
+ left: 50%;
13
+ transform: translate(-50%, -50%);
14
+ margin-top: 22px;
15
+ .empty-icon {
16
+ svg {
17
+ height: 78px;
18
+ width: 78px;
19
+ }
20
+ }
21
+ .empty-text {
22
+ color: #cacaca;
23
+ }
24
+ }
25
+ }
26
+
27
+ &-drag-trigger {
28
+ width: variables.$gantt-table-header-drag-line-width;
29
+ position: absolute;
30
+ top: 0;
31
+ right: 0;
32
+ bottom: 0;
33
+ cursor: ew-resize;
34
+ z-index: 1;
35
+
36
+ &:hover {
37
+ background: variables.$gantt-table-header-drag-line-color;
38
+ z-index: 2;
39
+ }
40
+ }
41
+
42
+ &-drag-auxiliary-line {
43
+ width: variables.$gantt-table-header-drag-line-width;
44
+ background: variables.$gantt-table-header-drag-line-color;
45
+ position: absolute;
46
+ top: 0;
47
+ bottom: 0;
48
+ z-index: 100;
49
+ display: none;
50
+ }
51
+
52
+ .gantt-table-row {
53
+ display: flex;
54
+ box-sizing: border-box;
55
+ border-bottom: 1px solid variables.$gantt-border-color;
56
+
57
+ .gantt-table-column {
58
+ overflow: hidden;
59
+ border-right: 1px solid variables.$gantt-border-color;
60
+ box-sizing: border-box;
61
+ position: relative;
62
+
63
+ &:last-child {
64
+ border-right: none;
65
+ }
66
+ }
67
+ }
68
+
69
+ .gantt-table-header {
70
+ text-align: center;
71
+ position: sticky;
72
+ top: 0;
73
+ background: #fff;
74
+ z-index: 2;
75
+ height: variables.$gantt-header-height;
76
+ line-height: variables.$gantt-header-height;
77
+
78
+ .gantt-table-column {
79
+ font-weight: 400;
80
+ }
81
+ }
82
+
83
+ .gantt-table-body {
84
+ .gantt-table-group {
85
+ display: flex;
86
+ height: variables.$gantt-group-height;
87
+ background: variables.$gantt-group-background-color;
88
+ padding: 0 10px;
89
+ align-items: center;
90
+ border-bottom: 1px solid variables.$gantt-border-color;
91
+ box-sizing: border-box;
92
+ position: relative;
93
+
94
+ .gantt-table-group-title {
95
+ cursor: pointer;
96
+
97
+ .expand-icon {
98
+ color: #aaa;
99
+ margin-right: 6px;
100
+ }
101
+ }
102
+ }
103
+
104
+ .gantt-table-item {
105
+ cursor: pointer;
106
+ &-first-level-group {
107
+ background: variables.$gantt-group-background-color;
108
+ }
109
+
110
+ &-with-group {
111
+ .gantt-table-column {
112
+ &:first-child {
113
+ padding: 0 15px 0 32px;
114
+ }
115
+ }
116
+ }
117
+
118
+ .gantt-table-column {
119
+ display: flex;
120
+ padding: variables.$gantt-table-td-padding;
121
+
122
+ &:last-child {
123
+ border-right: none;
124
+ }
125
+ }
126
+
127
+ .gantt-table-column-content {
128
+ flex: 1;
129
+ position: relative;
130
+ overflow: hidden;
131
+ text-overflow: ellipsis;
132
+ white-space: nowrap;
133
+ }
134
+
135
+ &:hover {
136
+ background-color: variables.$gantt-container-background-color;
137
+ }
138
+
139
+ &-active {
140
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
141
+ &:hover {
142
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
143
+ }
144
+ }
145
+ }
146
+
147
+ .gantt-expand-icon {
148
+ display: inline-block;
149
+ width: 20px;
150
+ color: #aaa;
151
+ }
152
+ }
153
+ }
@@ -0,0 +1,308 @@
1
+ import { Injectable, SkipSelf } from '@angular/core';
2
+ import { InBarPosition } from '../../gantt-drag-container';
3
+ import { differenceInCalendarDays } from '../../utils/date';
4
+ import { fromEvent, Subject } from 'rxjs';
5
+ import { takeUntil } from 'rxjs/operators';
6
+ import { GanttLinkType } from '../../class/link';
7
+ import { passiveListenerOptions } from '../../utils/passive-listeners';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/cdk/drag-drop";
10
+ import * as i2 from "../../gantt-dom.service";
11
+ import * as i3 from "../../gantt-drag-container";
12
+ import * as i4 from "../../root.component";
13
+ const dragMinWidth = 10;
14
+ const activeClass = 'gantt-bar-active';
15
+ const dropActiveClass = 'gantt-bar-drop-active';
16
+ const singleDropActiveClass = 'gantt-bar-single-drop-active';
17
+ function createSvgElement(qualifiedName, className) {
18
+ const element = document.createElementNS('http://www.w3.org/2000/svg', qualifiedName);
19
+ element.classList.add(className);
20
+ return element;
21
+ }
22
+ export class GanttBarDrag {
23
+ constructor(dragDrop, dom, dragContainer, root) {
24
+ this.dragDrop = dragDrop;
25
+ this.dom = dom;
26
+ this.dragContainer = dragContainer;
27
+ this.root = root;
28
+ this.dragRefs = [];
29
+ this.destroy$ = new Subject();
30
+ }
31
+ get dragDisabled() {
32
+ return !this.item.draggable || !this.ganttUpper.draggable;
33
+ }
34
+ get linkDragDisabled() {
35
+ return !this.item.linkable || !this.ganttUpper.linkable;
36
+ }
37
+ createMouseEvents() {
38
+ const dropClass = this.ganttUpper.config.linkOptions?.dependencyTypes?.length === 1 &&
39
+ this.ganttUpper.config.linkOptions?.dependencyTypes[0] === GanttLinkType.fs
40
+ ? singleDropActiveClass
41
+ : dropActiveClass;
42
+ fromEvent(this.barElement, 'mouseenter', passiveListenerOptions)
43
+ .pipe(takeUntil(this.destroy$))
44
+ .subscribe(() => {
45
+ if (this.dragContainer.linkDraggingId && this.dragContainer.linkDraggingId !== this.item.id) {
46
+ if (this.item.linkable) {
47
+ this.barElement.classList.add(dropClass);
48
+ this.dragContainer.emitLinkDragEntered({
49
+ item: this.item,
50
+ element: this.barElement
51
+ });
52
+ }
53
+ }
54
+ else {
55
+ this.barElement.classList.add(activeClass);
56
+ }
57
+ });
58
+ fromEvent(this.barElement, 'mouseleave', passiveListenerOptions)
59
+ .pipe(takeUntil(this.destroy$))
60
+ .subscribe(() => {
61
+ if (!this.dragContainer.linkDraggingId) {
62
+ this.barElement.classList.remove(activeClass);
63
+ }
64
+ else {
65
+ this.dragContainer.emitLinkDragLeaved();
66
+ }
67
+ this.barElement.classList.remove(dropClass);
68
+ });
69
+ }
70
+ createBarDrag() {
71
+ const dragRef = this.dragDrop.createDrag(this.barElement);
72
+ dragRef.lockAxis = 'x';
73
+ dragRef.started.subscribe(() => {
74
+ this.setDraggingStyles();
75
+ this.dragContainer.dragStarted.emit({ item: this.item.origin });
76
+ });
77
+ dragRef.moved.subscribe((event) => {
78
+ const currentX = this.item.refs.x + event.distance.x;
79
+ const currentDate = this.ganttUpper.view.getDateByXPoint(currentX);
80
+ const currentStartX = this.ganttUpper.view.getXPointByDate(currentDate);
81
+ const dayWidth = this.ganttUpper.view.getDayOccupancyWidth(currentDate);
82
+ const diffDays = differenceInCalendarDays(this.item.end.value, this.item.start.value);
83
+ let start = currentDate;
84
+ let end = currentDate.addDays(diffDays);
85
+ if (currentX > currentStartX + dayWidth / 2) {
86
+ start = start.addDays(1);
87
+ end = end.addDays(1);
88
+ }
89
+ this.openDragBackdrop(this.barElement, start, end);
90
+ this.item.updateDate(start, end);
91
+ this.dragContainer.dragMoved.emit({ item: this.item.origin });
92
+ });
93
+ dragRef.ended.subscribe((event) => {
94
+ this.clearDraggingStyles();
95
+ this.closeDragBackdrop();
96
+ event.source.reset();
97
+ this.dragContainer.dragEnded.emit({ item: this.item.origin });
98
+ });
99
+ this.barDragRef = dragRef;
100
+ return dragRef;
101
+ }
102
+ createBarHandleDrags() {
103
+ const dragRefs = [];
104
+ const handles = this.barElement.querySelectorAll('.drag-handles .handle');
105
+ handles.forEach((handle, index) => {
106
+ const isBefore = index === 0;
107
+ const dragRef = this.dragDrop.createDrag(handle);
108
+ dragRef.lockAxis = 'x';
109
+ dragRef.withBoundaryElement(this.dom.root);
110
+ dragRef.started.subscribe(() => {
111
+ this.setDraggingStyles();
112
+ this.dragContainer.dragStarted.emit({ item: this.item.origin });
113
+ });
114
+ dragRef.moved.subscribe((event) => {
115
+ if (isBefore) {
116
+ const x = this.item.refs.x + event.distance.x;
117
+ const width = this.item.refs.width + event.distance.x * -1;
118
+ if (width > dragMinWidth) {
119
+ this.barElement.style.width = width + 'px';
120
+ this.barElement.style.left = x + 'px';
121
+ this.openDragBackdrop(this.barElement, this.ganttUpper.view.getDateByXPoint(x), this.item.end);
122
+ this.item.updateDate(this.ganttUpper.view.getDateByXPoint(x), this.item.end);
123
+ }
124
+ }
125
+ else {
126
+ const width = this.item.refs.width + event.distance.x;
127
+ if (width > dragMinWidth) {
128
+ this.barElement.style.width = width + 'px';
129
+ this.openDragBackdrop(this.barElement, this.item.start, this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width));
130
+ }
131
+ this.item.updateDate(this.item.start, this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width));
132
+ }
133
+ this.dragContainer.dragMoved.emit({ item: this.item.origin });
134
+ event.source.reset();
135
+ });
136
+ dragRef.ended.subscribe((event) => {
137
+ if (isBefore) {
138
+ const width = this.item.refs.width + event.distance.x * -1;
139
+ if (width > dragMinWidth) {
140
+ this.item.updateDate(this.ganttUpper.view.getDateByXPoint(this.item.refs.x + event.distance.x), this.item.end);
141
+ }
142
+ else {
143
+ this.item.updateDate(this.item.end.startOfDay(), this.item.end);
144
+ }
145
+ }
146
+ else {
147
+ const width = this.item.refs.width + event.distance.x;
148
+ if (width > dragMinWidth) {
149
+ this.item.updateDate(this.item.start, this.ganttUpper.view.getDateByXPoint(this.item.refs.x + this.item.refs.width + event.distance.x));
150
+ }
151
+ else {
152
+ this.item.updateDate(this.item.start, this.item.start.endOfDay());
153
+ }
154
+ }
155
+ this.clearDraggingStyles();
156
+ this.closeDragBackdrop();
157
+ this.dragContainer.dragEnded.emit({ item: this.item.origin });
158
+ });
159
+ dragRefs.push(dragRef);
160
+ });
161
+ return dragRefs;
162
+ }
163
+ createLinkHandleDrags() {
164
+ const dragRefs = [];
165
+ const handles = this.barElement.querySelectorAll('.link-handles .handle');
166
+ handles.forEach((handle, index) => {
167
+ const isBegin = index === 0;
168
+ const dragRef = this.dragDrop.createDrag(handle);
169
+ dragRef.withBoundaryElement(this.dom.root);
170
+ dragRef.beforeStarted.subscribe(() => {
171
+ handle.style.pointerEvents = 'none';
172
+ if (this.barDragRef) {
173
+ this.barDragRef.disabled = true;
174
+ }
175
+ this.createLinkDraggingLine();
176
+ this.dragContainer.emitLinkDragStarted({
177
+ element: this.barElement,
178
+ item: this.item,
179
+ pos: isBegin ? InBarPosition.start : InBarPosition.finish
180
+ });
181
+ });
182
+ dragRef.moved.subscribe(() => {
183
+ const positions = this.calcLinkLinePositions(handle, isBegin);
184
+ this.linkDraggingLine.setAttribute('x1', positions.x1.toString());
185
+ this.linkDraggingLine.setAttribute('y1', positions.y1.toString());
186
+ this.linkDraggingLine.setAttribute('x2', positions.x2.toString());
187
+ this.linkDraggingLine.setAttribute('y2', positions.y2.toString());
188
+ });
189
+ dragRef.ended.subscribe((event) => {
190
+ handle.style.pointerEvents = '';
191
+ if (this.barDragRef) {
192
+ this.barDragRef.disabled = false;
193
+ }
194
+ // 计算line拖动的落点位于目标Bar的值,如果值大于Bar宽度的一半,说明是拖动到Begin位置,否则则为拖动到End位置
195
+ if (this.dragContainer.linkDragPath.to) {
196
+ const placePointX = event.source.getRootElement().getBoundingClientRect().x -
197
+ this.dragContainer.linkDragPath.to.element.getBoundingClientRect().x;
198
+ this.dragContainer.emitLinkDragEnded({
199
+ ...this.dragContainer.linkDragPath.to,
200
+ pos: placePointX < this.dragContainer.linkDragPath.to.item.refs.width / 2
201
+ ? InBarPosition.start
202
+ : InBarPosition.finish
203
+ });
204
+ }
205
+ else {
206
+ this.dragContainer.emitLinkDragEnded();
207
+ }
208
+ event.source.reset();
209
+ this.barElement.classList.remove(activeClass);
210
+ this.destroyLinkDraggingLine();
211
+ });
212
+ dragRefs.push(dragRef);
213
+ });
214
+ return dragRefs;
215
+ }
216
+ openDragBackdrop(dragElement, start, end) {
217
+ const dragBackdropElement = this.root.backdrop.nativeElement;
218
+ const dragMaskElement = dragBackdropElement.querySelector('.gantt-drag-mask');
219
+ const rootRect = this.dom.root.getBoundingClientRect();
220
+ const dragRect = dragElement.getBoundingClientRect();
221
+ const left = dragRect.left - rootRect.left - this.dom.side.clientWidth;
222
+ const width = dragRect.right - dragRect.left;
223
+ // Note: updating styles will cause re-layout so we have to place them consistently one by one.
224
+ dragMaskElement.style.left = left + 'px';
225
+ dragMaskElement.style.width = width + 'px';
226
+ dragMaskElement.style.display = 'block';
227
+ dragBackdropElement.style.display = 'block';
228
+ // This will invalidate the layout, but we won't need re-layout, because we set styles previously.
229
+ dragMaskElement.querySelector('.start').innerHTML = start.format('MM-dd');
230
+ dragMaskElement.querySelector('.end').innerHTML = end.format('MM-dd');
231
+ }
232
+ closeDragBackdrop() {
233
+ const dragBackdropElement = this.root.backdrop.nativeElement;
234
+ const dragMaskElement = dragBackdropElement.querySelector('.gantt-drag-mask');
235
+ dragMaskElement.style.display = 'none';
236
+ dragBackdropElement.style.display = 'none';
237
+ }
238
+ setDraggingStyles() {
239
+ this.barElement.style.pointerEvents = 'none';
240
+ this.barElement.classList.add('gantt-bar-draggable-drag');
241
+ }
242
+ clearDraggingStyles() {
243
+ this.barElement.style.pointerEvents = '';
244
+ this.barElement.classList.remove('gantt-bar-draggable-drag');
245
+ }
246
+ calcLinkLinePositions(target, isBefore) {
247
+ const rootRect = this.dom.root.getBoundingClientRect();
248
+ const targetRect = target.getBoundingClientRect();
249
+ const layerRect = target.parentElement.parentElement.getBoundingClientRect();
250
+ return {
251
+ x1: layerRect.left + (isBefore ? 0 : layerRect.width) - rootRect.left,
252
+ y1: layerRect.top + layerRect.height / 2 - rootRect.top,
253
+ x2: targetRect.left - rootRect.left + targetRect.width / 2,
254
+ y2: targetRect.top - rootRect.top + targetRect.height / 2
255
+ };
256
+ }
257
+ createLinkDraggingLine() {
258
+ if (!this.linkDraggingLine) {
259
+ const svgElement = createSvgElement('svg', 'gantt-link-drag-container');
260
+ const linElement = createSvgElement('line', 'link-dragging-line');
261
+ linElement.style.pointerEvents = 'none';
262
+ svgElement.appendChild(linElement);
263
+ this.dom.root.appendChild(svgElement);
264
+ this.linkDraggingLine = linElement;
265
+ }
266
+ }
267
+ destroyLinkDraggingLine() {
268
+ if (this.linkDraggingLine) {
269
+ this.linkDraggingLine.parentElement.remove();
270
+ this.linkDraggingLine = null;
271
+ }
272
+ }
273
+ createDrags(elementRef, item, ganttUpper) {
274
+ this.item = item;
275
+ this.barElement = elementRef.nativeElement;
276
+ this.ganttUpper = ganttUpper;
277
+ // if (!item.draggable || (this.dragDisabled && this.linkDragDisabled)) {
278
+ if (this.dragDisabled && this.linkDragDisabled) {
279
+ return;
280
+ }
281
+ else {
282
+ this.createMouseEvents();
283
+ if (!this.dragDisabled) {
284
+ const dragRef = this.createBarDrag();
285
+ const dragHandlesRefs = this.createBarHandleDrags();
286
+ this.dragRefs.push(dragRef, ...dragHandlesRefs);
287
+ }
288
+ if (!this.linkDragDisabled) {
289
+ const linkDragRefs = this.createLinkHandleDrags();
290
+ this.dragRefs.push(...linkDragRefs);
291
+ }
292
+ }
293
+ }
294
+ ngOnDestroy() {
295
+ this.closeDragBackdrop();
296
+ this.dragRefs.forEach((dragRef) => dragRef.dispose());
297
+ this.destroy$.next();
298
+ this.destroy$.complete();
299
+ }
300
+ }
301
+ GanttBarDrag.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: GanttBarDrag, deps: [{ token: i1.DragDrop }, { token: i2.GanttDomService }, { token: i3.GanttDragContainer }, { token: i4.NgxGanttRootComponent, skipSelf: true }], target: i0.ɵɵFactoryTarget.Injectable });
302
+ GanttBarDrag.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: GanttBarDrag });
303
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: GanttBarDrag, decorators: [{
304
+ type: Injectable
305
+ }], ctorParameters: function () { return [{ type: i1.DragDrop }, { type: i2.GanttDomService }, { type: i3.GanttDragContainer }, { type: i4.NgxGanttRootComponent, decorators: [{
306
+ type: SkipSelf
307
+ }] }]; } });
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-drag.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/bar/bar-drag.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ElementRef, OnDestroy, SkipSelf } from '@angular/core';\nimport { DragRef, DragDrop } from '@angular/cdk/drag-drop';\nimport { GanttDomService } from '../../gantt-dom.service';\nimport { GanttDragContainer, InBarPosition } from '../../gantt-drag-container';\nimport { GanttItemInternal } from '../../class/item';\nimport { GanttDate, differenceInCalendarDays } from '../../utils/date';\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { GanttUpper } from '../../gantt-upper';\nimport { GanttLinkType } from '../../class/link';\nimport { NgxGanttRootComponent } from '../../root.component';\nimport { passiveListenerOptions } from '../../utils/passive-listeners';\n\nconst dragMinWidth = 10;\nconst activeClass = 'gantt-bar-active';\nconst dropActiveClass = 'gantt-bar-drop-active';\nconst singleDropActiveClass = 'gantt-bar-single-drop-active';\n\nfunction createSvgElement(qualifiedName: string, className: string) {\n    const element = document.createElementNS('http://www.w3.org/2000/svg', qualifiedName);\n    element.classList.add(className);\n    return element;\n}\n\n@Injectable()\nexport class GanttBarDrag implements OnDestroy {\n    private ganttUpper: GanttUpper;\n\n    private barElement: HTMLElement;\n\n    private item: GanttItemInternal;\n\n    private get dragDisabled() {\n        return !this.item.draggable || !this.ganttUpper.draggable;\n    }\n\n    private get linkDragDisabled() {\n        return !this.item.linkable || !this.ganttUpper.linkable;\n    }\n\n    private linkDraggingLine: SVGElement;\n\n    private barDragRef: DragRef;\n\n    private dragRefs: DragRef[] = [];\n\n    private destroy$ = new Subject<void>();\n\n    constructor(\n        private dragDrop: DragDrop,\n        private dom: GanttDomService,\n        private dragContainer: GanttDragContainer,\n        @SkipSelf() private root: NgxGanttRootComponent\n    ) {}\n\n    private createMouseEvents() {\n        const dropClass =\n            this.ganttUpper.config.linkOptions?.dependencyTypes?.length === 1 &&\n            this.ganttUpper.config.linkOptions?.dependencyTypes[0] === GanttLinkType.fs\n                ? singleDropActiveClass\n                : dropActiveClass;\n\n        fromEvent(this.barElement, 'mouseenter', passiveListenerOptions)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                if (this.dragContainer.linkDraggingId && this.dragContainer.linkDraggingId !== this.item.id) {\n                    if (this.item.linkable) {\n                        this.barElement.classList.add(dropClass);\n                        this.dragContainer.emitLinkDragEntered({\n                            item: this.item,\n                            element: this.barElement\n                        });\n                    }\n                } else {\n                    this.barElement.classList.add(activeClass);\n                }\n            });\n\n        fromEvent(this.barElement, 'mouseleave', passiveListenerOptions)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                if (!this.dragContainer.linkDraggingId) {\n                    this.barElement.classList.remove(activeClass);\n                } else {\n                    this.dragContainer.emitLinkDragLeaved();\n                }\n                this.barElement.classList.remove(dropClass);\n            });\n    }\n\n    private createBarDrag() {\n        const dragRef = this.dragDrop.createDrag(this.barElement);\n        dragRef.lockAxis = 'x';\n        dragRef.started.subscribe(() => {\n            this.setDraggingStyles();\n            this.dragContainer.dragStarted.emit({ item: this.item.origin });\n        });\n        dragRef.moved.subscribe((event) => {\n            const currentX = this.item.refs.x + event.distance.x;\n            const currentDate = this.ganttUpper.view.getDateByXPoint(currentX);\n            const currentStartX = this.ganttUpper.view.getXPointByDate(currentDate);\n            const dayWidth = this.ganttUpper.view.getDayOccupancyWidth(currentDate);\n            const diffDays = differenceInCalendarDays(this.item.end.value, this.item.start.value);\n            let start = currentDate;\n            let end = currentDate.addDays(diffDays);\n            if (currentX > currentStartX + dayWidth / 2) {\n                start = start.addDays(1);\n                end = end.addDays(1);\n            }\n            this.openDragBackdrop(this.barElement, start, end);\n            this.item.updateDate(start, end);\n            this.dragContainer.dragMoved.emit({ item: this.item.origin });\n        });\n        dragRef.ended.subscribe((event) => {\n            this.clearDraggingStyles();\n            this.closeDragBackdrop();\n            event.source.reset();\n            this.dragContainer.dragEnded.emit({ item: this.item.origin });\n        });\n        this.barDragRef = dragRef;\n        return dragRef;\n    }\n\n    private createBarHandleDrags() {\n        const dragRefs = [];\n        const handles = this.barElement.querySelectorAll<HTMLElement>('.drag-handles .handle');\n        handles.forEach((handle, index) => {\n            const isBefore = index === 0;\n            const dragRef = this.dragDrop.createDrag(handle);\n            dragRef.lockAxis = 'x';\n            dragRef.withBoundaryElement(this.dom.root as HTMLElement);\n\n            dragRef.started.subscribe(() => {\n                this.setDraggingStyles();\n                this.dragContainer.dragStarted.emit({ item: this.item.origin });\n            });\n\n            dragRef.moved.subscribe((event) => {\n                if (isBefore) {\n                    const x = this.item.refs.x + event.distance.x;\n                    const width = this.item.refs.width + event.distance.x * -1;\n                    if (width > dragMinWidth) {\n                        this.barElement.style.width = width + 'px';\n                        this.barElement.style.left = x + 'px';\n                        this.openDragBackdrop(this.barElement, this.ganttUpper.view.getDateByXPoint(x), this.item.end);\n                        this.item.updateDate(this.ganttUpper.view.getDateByXPoint(x), this.item.end);\n                    }\n                } else {\n                    const width = this.item.refs.width + event.distance.x;\n                    if (width > dragMinWidth) {\n                        this.barElement.style.width = width + 'px';\n                        this.openDragBackdrop(\n                            this.barElement,\n                            this.item.start,\n                            this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width)\n                        );\n                    }\n                    this.item.updateDate(this.item.start, this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width));\n                }\n                this.dragContainer.dragMoved.emit({ item: this.item.origin });\n                event.source.reset();\n            });\n\n            dragRef.ended.subscribe((event) => {\n                if (isBefore) {\n                    const width = this.item.refs.width + event.distance.x * -1;\n                    if (width > dragMinWidth) {\n                        this.item.updateDate(this.ganttUpper.view.getDateByXPoint(this.item.refs.x + event.distance.x), this.item.end);\n                    } else {\n                        this.item.updateDate(this.item.end.startOfDay(), this.item.end);\n                    }\n                } else {\n                    const width = this.item.refs.width + event.distance.x;\n                    if (width > dragMinWidth) {\n                        this.item.updateDate(\n                            this.item.start,\n                            this.ganttUpper.view.getDateByXPoint(this.item.refs.x + this.item.refs.width + event.distance.x)\n                        );\n                    } else {\n                        this.item.updateDate(this.item.start, this.item.start.endOfDay());\n                    }\n                }\n                this.clearDraggingStyles();\n                this.closeDragBackdrop();\n                this.dragContainer.dragEnded.emit({ item: this.item.origin });\n            });\n            dragRefs.push(dragRef);\n        });\n        return dragRefs;\n    }\n\n    private createLinkHandleDrags() {\n        const dragRefs = [];\n        const handles = this.barElement.querySelectorAll<HTMLElement>('.link-handles .handle');\n        handles.forEach((handle, index) => {\n            const isBegin = index === 0;\n            const dragRef = this.dragDrop.createDrag(handle);\n            dragRef.withBoundaryElement(this.dom.root as HTMLElement);\n            dragRef.beforeStarted.subscribe(() => {\n                handle.style.pointerEvents = 'none';\n                if (this.barDragRef) {\n                    this.barDragRef.disabled = true;\n                }\n                this.createLinkDraggingLine();\n                this.dragContainer.emitLinkDragStarted({\n                    element: this.barElement,\n                    item: this.item,\n                    pos: isBegin ? InBarPosition.start : InBarPosition.finish\n                });\n            });\n\n            dragRef.moved.subscribe(() => {\n                const positions = this.calcLinkLinePositions(handle, isBegin);\n                this.linkDraggingLine.setAttribute('x1', positions.x1.toString());\n                this.linkDraggingLine.setAttribute('y1', positions.y1.toString());\n                this.linkDraggingLine.setAttribute('x2', positions.x2.toString());\n                this.linkDraggingLine.setAttribute('y2', positions.y2.toString());\n            });\n\n            dragRef.ended.subscribe((event) => {\n                handle.style.pointerEvents = '';\n                if (this.barDragRef) {\n                    this.barDragRef.disabled = false;\n                }\n                // 计算line拖动的落点位于目标Bar的值，如果值大于Bar宽度的一半，说明是拖动到Begin位置，否则则为拖动到End位置\n                if (this.dragContainer.linkDragPath.to) {\n                    const placePointX =\n                        event.source.getRootElement().getBoundingClientRect().x -\n                        this.dragContainer.linkDragPath.to.element.getBoundingClientRect().x;\n\n                    this.dragContainer.emitLinkDragEnded({\n                        ...this.dragContainer.linkDragPath.to,\n                        pos:\n                            placePointX < this.dragContainer.linkDragPath.to.item.refs.width / 2\n                                ? InBarPosition.start\n                                : InBarPosition.finish\n                    });\n                } else {\n                    this.dragContainer.emitLinkDragEnded();\n                }\n                event.source.reset();\n                this.barElement.classList.remove(activeClass);\n                this.destroyLinkDraggingLine();\n            });\n\n            dragRefs.push(dragRef);\n        });\n        return dragRefs;\n    }\n\n    private openDragBackdrop(dragElement: HTMLElement, start: GanttDate, end: GanttDate) {\n        const dragBackdropElement = this.root.backdrop.nativeElement;\n        const dragMaskElement = dragBackdropElement.querySelector('.gantt-drag-mask') as HTMLElement;\n        const rootRect = this.dom.root.getBoundingClientRect();\n        const dragRect = dragElement.getBoundingClientRect();\n        const left = dragRect.left - rootRect.left - this.dom.side.clientWidth;\n        const width = dragRect.right - dragRect.left;\n        // Note: updating styles will cause re-layout so we have to place them consistently one by one.\n        dragMaskElement.style.left = left + 'px';\n        dragMaskElement.style.width = width + 'px';\n        dragMaskElement.style.display = 'block';\n        dragBackdropElement.style.display = 'block';\n        // This will invalidate the layout, but we won't need re-layout, because we set styles previously.\n        dragMaskElement.querySelector('.start').innerHTML = start.format('MM-dd');\n        dragMaskElement.querySelector('.end').innerHTML = end.format('MM-dd');\n    }\n\n    private closeDragBackdrop() {\n        const dragBackdropElement = this.root.backdrop.nativeElement;\n        const dragMaskElement = dragBackdropElement.querySelector('.gantt-drag-mask') as HTMLElement;\n        dragMaskElement.style.display = 'none';\n        dragBackdropElement.style.display = 'none';\n    }\n\n    private setDraggingStyles() {\n        this.barElement.style.pointerEvents = 'none';\n        this.barElement.classList.add('gantt-bar-draggable-drag');\n    }\n\n    private clearDraggingStyles() {\n        this.barElement.style.pointerEvents = '';\n        this.barElement.classList.remove('gantt-bar-draggable-drag');\n    }\n\n    private calcLinkLinePositions(target: HTMLElement, isBefore: boolean) {\n        const rootRect = this.dom.root.getBoundingClientRect();\n        const targetRect = target.getBoundingClientRect();\n        const layerRect = target.parentElement.parentElement.getBoundingClientRect();\n        return {\n            x1: layerRect.left + (isBefore ? 0 : layerRect.width) - rootRect.left,\n            y1: layerRect.top + layerRect.height / 2 - rootRect.top,\n            x2: targetRect.left - rootRect.left + targetRect.width / 2,\n            y2: targetRect.top - rootRect.top + targetRect.height / 2\n        };\n    }\n\n    private createLinkDraggingLine() {\n        if (!this.linkDraggingLine) {\n            const svgElement = createSvgElement('svg', 'gantt-link-drag-container');\n            const linElement = createSvgElement('line', 'link-dragging-line');\n            linElement.style.pointerEvents = 'none';\n            svgElement.appendChild(linElement);\n            this.dom.root.appendChild(svgElement);\n            this.linkDraggingLine = linElement;\n        }\n    }\n\n    private destroyLinkDraggingLine() {\n        if (this.linkDraggingLine) {\n            this.linkDraggingLine.parentElement.remove();\n            this.linkDraggingLine = null;\n        }\n    }\n\n    createDrags(elementRef: ElementRef, item: GanttItemInternal, ganttUpper: GanttUpper) {\n        this.item = item;\n        this.barElement = elementRef.nativeElement;\n        this.ganttUpper = ganttUpper;\n        // if (!item.draggable || (this.dragDisabled && this.linkDragDisabled)) {\n        if (this.dragDisabled && this.linkDragDisabled) {\n            return;\n        } else {\n            this.createMouseEvents();\n            if (!this.dragDisabled) {\n                const dragRef = this.createBarDrag();\n                const dragHandlesRefs = this.createBarHandleDrags();\n                this.dragRefs.push(dragRef, ...dragHandlesRefs);\n            }\n            if (!this.linkDragDisabled) {\n                const linkDragRefs = this.createLinkHandleDrags();\n                this.dragRefs.push(...linkDragRefs);\n            }\n        }\n    }\n\n    ngOnDestroy() {\n        this.closeDragBackdrop();\n        this.dragRefs.forEach((dragRef) => dragRef.dispose());\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}