@worktile/gantt 15.0.0 → 15.1.0-next.1

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 (59) hide show
  1. package/class/event.d.ts +13 -0
  2. package/class/item.d.ts +7 -1
  3. package/components/bar/bar-drag.d.ts +10 -0
  4. package/components/bar/bar.component.d.ts +2 -1
  5. package/components/bar/bar.component.scss +22 -0
  6. package/components/calendar/calendar.scss +91 -0
  7. package/components/calendar/grid/calendar-grid.component.d.ts +24 -0
  8. package/components/calendar/header/calendar-header.component.d.ts +21 -0
  9. package/components/icon/icons.d.ts +1 -0
  10. package/components/links/links.component.d.ts +5 -5
  11. package/components/loader/loader.component.d.ts +5 -0
  12. package/components/loader/loader.component.scss +90 -0
  13. package/components/main/gantt-main.component.d.ts +3 -3
  14. package/components/table/body/gantt-table-body.component.d.ts +58 -0
  15. package/components/table/gantt-table.component.scss +169 -85
  16. package/components/table/gantt-table.scss +271 -0
  17. package/components/table/header/gantt-table-header.component.d.ts +31 -0
  18. package/esm2020/class/event.mjs +5 -1
  19. package/esm2020/class/item.mjs +9 -4
  20. package/esm2020/components/bar/bar-drag.mjs +106 -42
  21. package/esm2020/components/bar/bar.component.mjs +8 -2
  22. package/esm2020/components/calendar/grid/calendar-grid.component.mjs +71 -0
  23. package/esm2020/components/calendar/header/calendar-header.component.mjs +67 -0
  24. package/esm2020/components/icon/icons.mjs +4 -2
  25. package/esm2020/components/links/links.component.mjs +72 -54
  26. package/esm2020/components/loader/loader.component.mjs +29 -0
  27. package/esm2020/components/main/gantt-main.component.mjs +5 -5
  28. package/esm2020/components/table/body/gantt-table-body.component.mjs +298 -0
  29. package/esm2020/components/table/header/gantt-table-header.component.mjs +140 -0
  30. package/esm2020/gantt-dom.service.mjs +8 -12
  31. package/esm2020/gantt-item-upper.mjs +15 -6
  32. package/esm2020/gantt-print.service.mjs +2 -2
  33. package/esm2020/gantt-upper.mjs +18 -15
  34. package/esm2020/gantt.component.mjs +143 -25
  35. package/esm2020/gantt.module.mjs +28 -10
  36. package/esm2020/public-api.mjs +2 -1
  37. package/esm2020/root.component.mjs +10 -8
  38. package/esm2020/table/gantt-table.component.mjs +12 -4
  39. package/esm2020/utils/helpers.mjs +11 -1
  40. package/fesm2015/worktile-gantt.mjs +969 -378
  41. package/fesm2015/worktile-gantt.mjs.map +1 -1
  42. package/fesm2020/worktile-gantt.mjs +959 -380
  43. package/fesm2020/worktile-gantt.mjs.map +1 -1
  44. package/gantt-dom.service.d.ts +1 -0
  45. package/gantt-item-upper.d.ts +3 -2
  46. package/gantt-upper.d.ts +4 -1
  47. package/gantt.component.d.ts +26 -8
  48. package/gantt.component.scss +39 -0
  49. package/gantt.module.d.ts +19 -15
  50. package/package.json +1 -1
  51. package/public-api.d.ts +1 -0
  52. package/root.component.d.ts +1 -1
  53. package/styles/index.scss +5 -2
  54. package/styles/variables.scss +12 -7
  55. package/table/gantt-table.component.d.ts +5 -2
  56. package/components/calendar/calendar.component.d.ts +0 -26
  57. package/components/table/gantt-table.component.d.ts +0 -42
  58. package/esm2020/components/calendar/calendar.component.mjs +0 -88
  59. package/esm2020/components/table/gantt-table.component.mjs +0 -166
@@ -1,7 +1,148 @@
1
1
  @use '../../styles/variables';
2
2
 
3
+ @mixin gantt-table-item-base() {
4
+ display: flex;
5
+ flex-wrap: wrap;
6
+ box-sizing: border-box;
7
+ border-bottom: 1px solid variables.$gantt-border-color;
8
+
9
+ .gantt-table-column {
10
+ overflow: hidden;
11
+ border-right: 1px solid variables.$gantt-border-color;
12
+ box-sizing: border-box;
13
+ position: relative;
14
+
15
+ &:last-child {
16
+ border-right: none;
17
+ }
18
+ }
19
+ }
20
+
21
+ @mixin gantt-table-item {
22
+ @include gantt-table-item-base();
23
+ position: relative;
24
+ cursor: pointer;
25
+
26
+ &-first-level-group {
27
+ background: variables.$gantt-group-background-color;
28
+ }
29
+
30
+ &-with-group {
31
+ .gantt-table-column {
32
+ &:first-child {
33
+ padding: 0 15px 0 32px;
34
+ }
35
+ }
36
+ }
37
+
38
+ .gantt-table-column {
39
+ display: flex;
40
+ padding: variables.$gantt-table-td-padding;
41
+
42
+ &:last-child {
43
+ border-right: none;
44
+ }
45
+ }
46
+
47
+ .gantt-table-column-content {
48
+ flex: 1;
49
+ position: relative;
50
+ overflow: hidden;
51
+ text-overflow: ellipsis;
52
+ white-space: nowrap;
53
+ }
54
+
55
+ .gantt-expand-icon {
56
+ display: inline-block;
57
+ width: 20px;
58
+ color: #aaa;
59
+ }
60
+
61
+ .gantt-drag-handle {
62
+ width: 1rem;
63
+ padding: 0 5px 0 0;
64
+ display: flex;
65
+ align-items: center;
66
+ margin-left: -10px;
67
+ }
68
+
69
+ &:hover {
70
+ background-color: variables.$gantt-container-background-color;
71
+ }
72
+
73
+ &-active {
74
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
75
+ &:hover {
76
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
77
+ }
78
+ }
79
+ }
80
+
81
+ @mixin gantt-items-drag-drop() {
82
+ .cdk-drag-preview.gantt-table-item {
83
+ box-sizing: border-box;
84
+ box-shadow: 0px 0px 8px 2px rgba(0, 0, 0, 0.08);
85
+ opacity: 0.9;
86
+ @include gantt-table-item();
87
+ }
88
+
89
+ .gantt-table.gantt-table-draggable {
90
+ .cdk-drag-placeholder {
91
+ display: none !important;
92
+ & + .cdk-drop-list {
93
+ display: none !important;
94
+ }
95
+ }
96
+
97
+ .cdk-drag-disabled.gantt-table-item {
98
+ .gantt-drag-handle {
99
+ svg {
100
+ display: none;
101
+ }
102
+ }
103
+ }
104
+
105
+ .drop-position-inside {
106
+ // border: 2px dashed variables.$gantt-primary-color !important;
107
+ .gantt-table-column {
108
+ height: 100%;
109
+ border-top: 2px dashed variables.$gantt-primary-color !important;
110
+ border-bottom: 2px dashed variables.$gantt-primary-color !important;
111
+ &:first-child {
112
+ border-left: 2px dashed variables.$gantt-primary-color !important;
113
+ }
114
+ &:last-child {
115
+ border-right: 2px dashed variables.$gantt-primary-color !important;
116
+ }
117
+ }
118
+ }
119
+
120
+ .drop-position-before {
121
+ background: #f5f5f5;
122
+ border-top: 2px solid variables.$gantt-primary-color !important;
123
+ }
124
+
125
+ .drop-position-after {
126
+ background: #f5f5f5;
127
+ border-bottom: 2px solid variables.$gantt-primary-color !important;
128
+ }
129
+
130
+ &.gantt-table-dragging {
131
+ .gantt-table-item {
132
+ &:hover {
133
+ background: unset !important;
134
+ .gantt-drag-handle {
135
+ visibility: hidden !important;
136
+ }
137
+ }
138
+ }
139
+ }
140
+ }
141
+ }
142
+
3
143
  .gantt-table {
4
144
  display: block;
145
+
5
146
  &-empty {
6
147
  height: 100%;
7
148
  position: relative;
@@ -24,48 +165,6 @@
24
165
  }
25
166
  }
26
167
 
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
168
  .gantt-table-header {
70
169
  text-align: center;
71
170
  position: sticky;
@@ -75,6 +174,8 @@
75
174
  height: variables.$gantt-header-height;
76
175
  line-height: variables.$gantt-header-height;
77
176
 
177
+ @include gantt-table-item-base();
178
+
78
179
  .gantt-table-column {
79
180
  font-weight: 400;
80
181
  }
@@ -102,52 +203,35 @@
102
203
  }
103
204
 
104
205
  .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
- }
206
+ @include gantt-table-item();
207
+ }
208
+ }
134
209
 
135
- &:hover {
136
- background-color: variables.$gantt-container-background-color;
137
- }
210
+ .table-resize-trigger,
211
+ .column-resize-handle {
212
+ width: variables.$gantt-table-header-drag-line-width;
213
+ position: absolute;
214
+ top: 0;
215
+ right: 0;
216
+ bottom: 0;
217
+ cursor: ew-resize;
218
+ z-index: 1;
138
219
 
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
- }
220
+ &:hover {
221
+ background: variables.$gantt-table-header-drag-line-color;
222
+ z-index: 2;
145
223
  }
224
+ }
146
225
 
147
- .gantt-expand-icon {
148
- display: inline-block;
149
- width: 20px;
150
- color: #aaa;
151
- }
226
+ .table-resize-line {
227
+ width: variables.$gantt-table-header-drag-line-width;
228
+ background: variables.$gantt-table-header-drag-line-color;
229
+ position: absolute;
230
+ top: 0;
231
+ bottom: 0;
232
+ z-index: 100;
233
+ display: none;
152
234
  }
153
235
  }
236
+
237
+ @include gantt-items-drag-drop();
@@ -0,0 +1,271 @@
1
+ @use '../../styles/variables';
2
+
3
+ @mixin gantt-table-item-base() {
4
+ display: flex;
5
+ box-sizing: border-box;
6
+ border-bottom: 1px solid variables.$gantt-border-color;
7
+
8
+ .gantt-table-column {
9
+ overflow: hidden;
10
+ border-right: 1px solid variables.$gantt-border-color;
11
+ box-sizing: border-box;
12
+ position: relative;
13
+
14
+ &:last-child {
15
+ border-right: none;
16
+ }
17
+ }
18
+ }
19
+
20
+ @mixin gantt-table-item {
21
+ @include gantt-table-item-base();
22
+ cursor: pointer;
23
+ &-first-level-group {
24
+ background: variables.$gantt-group-background-color;
25
+ }
26
+
27
+ &-with-group {
28
+ .gantt-table-column {
29
+ &:first-child {
30
+ padding: 0 15px 0 32px;
31
+ }
32
+ }
33
+ }
34
+
35
+ .gantt-table-column {
36
+ display: flex;
37
+ padding: variables.$gantt-table-td-padding;
38
+ }
39
+
40
+ .gantt-table-column-content {
41
+ flex: 1;
42
+ position: relative;
43
+ overflow: hidden;
44
+ text-overflow: ellipsis;
45
+ white-space: nowrap;
46
+ }
47
+
48
+ &:hover {
49
+ background-color: variables.$gantt-container-background-color;
50
+ }
51
+
52
+ &-active {
53
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
54
+ &:hover {
55
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
56
+ }
57
+ }
58
+
59
+ .gantt-table-column {
60
+ display: flex;
61
+ padding: variables.$gantt-table-td-padding;
62
+
63
+ &:last-child {
64
+ border-right: none;
65
+ }
66
+ }
67
+
68
+ .gantt-table-column-content {
69
+ flex: 1;
70
+ position: relative;
71
+ overflow: hidden;
72
+ text-overflow: ellipsis;
73
+ white-space: nowrap;
74
+ }
75
+
76
+ .gantt-expand-icon {
77
+ display: inline-block;
78
+ width: 20px;
79
+ color: #aaa;
80
+ }
81
+
82
+ .gantt-drag-handle {
83
+ width: 1rem;
84
+ padding: 0 5px 0 0;
85
+ display: flex;
86
+ align-items: center;
87
+ margin-left: -10px;
88
+ }
89
+
90
+ &:hover {
91
+ background-color: variables.$gantt-container-background-color;
92
+ }
93
+
94
+ &-active {
95
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
96
+ &:hover {
97
+ background-color: rgba($color: variables.$gantt-table-header-drag-line-color, $alpha: 0.1);
98
+ }
99
+ }
100
+ }
101
+
102
+ @mixin gantt-items-drag-drop() {
103
+ .cdk-drag-preview.gantt-table-item {
104
+ box-sizing: border-box;
105
+ box-shadow: 0px 0px 8px 2px rgba(0, 0, 0, 0.08);
106
+ opacity: 0.9;
107
+ @include gantt-table-item();
108
+ }
109
+
110
+ .gantt-table-body.gantt-table-draggable {
111
+ .cdk-drag-placeholder {
112
+ display: none !important;
113
+ & + .cdk-drop-list {
114
+ display: none !important;
115
+ }
116
+ }
117
+
118
+ .cdk-drag-disabled.gantt-table-item {
119
+ .gantt-drag-handle {
120
+ svg {
121
+ display: none;
122
+ }
123
+ }
124
+ }
125
+
126
+ &.gantt-table-dragging {
127
+ .gantt-table-item {
128
+ &:hover {
129
+ background: unset;
130
+ .gantt-drag-handle {
131
+ visibility: hidden !important;
132
+ }
133
+ }
134
+ }
135
+ }
136
+
137
+ .drag-item-hide {
138
+ display: none !important;
139
+ }
140
+
141
+ .drop-position-inside {
142
+ .gantt-table-column {
143
+ height: 100%;
144
+ border-top: 2px dashed variables.$gantt-primary-color !important;
145
+ border-bottom: 2px dashed variables.$gantt-primary-color !important;
146
+ &:first-child {
147
+ border-left: 2px dashed variables.$gantt-primary-color !important;
148
+ }
149
+ &:last-child {
150
+ border-right: 2px dashed variables.$gantt-primary-color !important;
151
+ }
152
+ }
153
+ }
154
+
155
+ .drop-position-before {
156
+ background: variables.$gantt-table-items-drop-background-color !important;
157
+ border-top: 2px solid variables.$gantt-primary-color !important;
158
+ }
159
+
160
+ .drop-position-after {
161
+ background: variables.$gantt-table-items-drop-background-color !important;
162
+ border-bottom: 2px solid variables.$gantt-primary-color !important;
163
+ }
164
+ }
165
+ }
166
+
167
+ .gantt-table-header {
168
+ text-align: center;
169
+ background: #fff;
170
+ height: variables.$gantt-header-height;
171
+ line-height: variables.$gantt-header-height;
172
+ box-shadow: variables.$gantt-side-shadow;
173
+ position: relative;
174
+ z-index: 3;
175
+ border-right: 1px solid variables.$gantt-border-color;
176
+
177
+ @include gantt-table-item();
178
+
179
+ .gantt-table-column {
180
+ font-weight: 400;
181
+ z-index: 1;
182
+ }
183
+ }
184
+
185
+ .gantt-table-body {
186
+ display: block;
187
+ .gantt-table-group {
188
+ display: flex;
189
+ height: variables.$gantt-group-height;
190
+ background: variables.$gantt-group-background-color;
191
+ padding: 0 10px;
192
+ align-items: center;
193
+ border-bottom: 1px solid variables.$gantt-border-color;
194
+ box-sizing: border-box;
195
+ position: relative;
196
+
197
+ .gantt-table-group-title {
198
+ cursor: pointer;
199
+
200
+ .expand-icon {
201
+ color: #aaa;
202
+ margin-right: 6px;
203
+ }
204
+ }
205
+ }
206
+
207
+ .gantt-table-item {
208
+ @include gantt-table-item();
209
+ }
210
+
211
+ .gantt-expand-icon {
212
+ display: inline-block;
213
+ width: 20px;
214
+ color: #aaa;
215
+ }
216
+ }
217
+
218
+ .gantt-table-empty {
219
+ height: 100%;
220
+ position: relative;
221
+ .gantt-table-body-container {
222
+ position: absolute;
223
+ text-align: center;
224
+ top: 50%;
225
+ left: 50%;
226
+ transform: translate(-50%, -50%);
227
+ margin-top: 22px;
228
+ .empty-icon {
229
+ svg {
230
+ height: 78px;
231
+ width: 78px;
232
+ }
233
+ }
234
+ .empty-text {
235
+ color: #cacaca;
236
+ }
237
+ }
238
+ }
239
+
240
+ .table-resize-handle,
241
+ .column-resize-handle {
242
+ width: variables.$gantt-table-header-drag-line-width;
243
+ position: absolute;
244
+ top: 0;
245
+ right: 0;
246
+ bottom: 0;
247
+ cursor: ew-resize;
248
+ height: 5000px;
249
+
250
+ &:hover {
251
+ background: variables.$gantt-table-header-drag-line-color;
252
+ }
253
+ }
254
+
255
+ .column-resize-handle {
256
+ height: unset;
257
+ z-index: 1;
258
+ }
259
+
260
+ .table-resize-auxiliary-line {
261
+ width: variables.$gantt-table-header-drag-line-width;
262
+ background: variables.$gantt-table-header-drag-line-color;
263
+ position: absolute;
264
+ top: 0;
265
+ bottom: 0;
266
+ z-index: 100;
267
+ display: none;
268
+ height: 5000px;
269
+ }
270
+
271
+ @include gantt-items-drag-drop();
@@ -0,0 +1,31 @@
1
+ import { QueryList, OnInit, ElementRef, OnDestroy, ChangeDetectorRef } from '@angular/core';
2
+ import { NgxGanttTableColumnComponent } from '../../../table/gantt-column.component';
3
+ import { CdkDragEnd, CdkDragMove, CdkDragStart } from '@angular/cdk/drag-drop';
4
+ import { GanttAbstractComponent } from '../../../gantt-abstract';
5
+ import * as i0 from "@angular/core";
6
+ export declare const defaultColumnWidth = 100;
7
+ export declare const minColumnWidth = 80;
8
+ export declare class GanttTableHeaderComponent implements OnInit, OnDestroy {
9
+ private elementRef;
10
+ private gantt;
11
+ private cdr;
12
+ dragStartLeft: number;
13
+ tableWidth: number;
14
+ private unsubscribe$;
15
+ columns: QueryList<NgxGanttTableColumnComponent>;
16
+ resizeLineElementRef: ElementRef<HTMLElement>;
17
+ className: string;
18
+ constructor(elementRef: ElementRef, gantt: GanttAbstractComponent, cdr: ChangeDetectorRef);
19
+ ngOnInit(): void;
20
+ private columnsChange;
21
+ private dragFixed;
22
+ onResizeStarted(event: CdkDragStart): void;
23
+ onResizeMoved(event: CdkDragMove, column?: NgxGanttTableColumnComponent): void;
24
+ onResizeEnded(event: CdkDragEnd, column: NgxGanttTableColumnComponent): void;
25
+ onOverallResizeEnded(event: CdkDragEnd): void;
26
+ private showAuxiliaryLine;
27
+ private hideAuxiliaryLine;
28
+ ngOnDestroy(): void;
29
+ static ɵfac: i0.ɵɵFactoryDeclaration<GanttTableHeaderComponent, never>;
30
+ static ɵcmp: i0.ɵɵComponentDeclaration<GanttTableHeaderComponent, "gantt-table-header", never, { "columns": "columns"; }, {}, never, never, false, never>;
31
+ }
@@ -12,4 +12,8 @@ export class GanttBarClickEvent {
12
12
  }
13
13
  export class GanttSelectedEvent {
14
14
  }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9nYW50dC9zcmMvY2xhc3MvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFPLGNBQWM7Q0FFMUI7QUFFRCxNQUFNLE9BQU8sZUFBZTtDQUUzQjtBQUVELE1BQU0sT0FBTyxrQkFBa0I7Q0FJOUI7QUFFRCxNQUFNLE9BQU8sc0JBQXNCO0NBR2xDO0FBRUQsTUFBTSxPQUFPLG1CQUFtQjtDQUkvQjtBQUVELE1BQU0sT0FBTyxrQkFBa0I7Q0FHOUI7QUFFRCxNQUFNLE9BQU8sa0JBQWtCO0NBRzlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVlcnlMaXN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3hHYW50dFRhYmxlQ29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi4vdGFibGUvZ2FudHQtY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBHYW50dEl0ZW0gfSBmcm9tICcuL2l0ZW0nO1xuaW1wb3J0IHsgR2FudHRMaW5rVHlwZSB9IGZyb20gJy4vbGluayc7XG5cbmV4cG9ydCBjbGFzcyBHYW50dERyYWdFdmVudDxUID0gdW5rbm93bj4ge1xuICAgIGl0ZW06IEdhbnR0SXRlbTxUPjtcbn1cblxuZXhwb3J0IGNsYXNzIEdhbnR0VGFibGVFdmVudCB7XG4gICAgY29sdW1uczogUXVlcnlMaXN0PE5neEdhbnR0VGFibGVDb2x1bW5Db21wb25lbnQ+O1xufVxuXG5leHBvcnQgY2xhc3MgR2FudHRMaW5rRHJhZ0V2ZW50PFQgPSB1bmtub3duPiB7XG4gICAgc291cmNlOiBHYW50dEl0ZW08VD47XG4gICAgdGFyZ2V0PzogR2FudHRJdGVtPFQ+O1xuICAgIHR5cGU/OiBHYW50dExpbmtUeXBlO1xufVxuXG5leHBvcnQgY2xhc3MgR2FudHRMb2FkT25TY3JvbGxFdmVudCB7XG4gICAgc3RhcnQ6IG51bWJlcjtcbiAgICBlbmQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNsYXNzIEdhbnR0TGluZUNsaWNrRXZlbnQ8VCA9IHVua25vd24+IHtcbiAgICBldmVudDogTW91c2VFdmVudDtcbiAgICBzb3VyY2U6IEdhbnR0SXRlbTxUPjtcbiAgICB0YXJnZXQ6IEdhbnR0SXRlbTxUPjtcbn1cblxuZXhwb3J0IGNsYXNzIEdhbnR0QmFyQ2xpY2tFdmVudDxUID0gdW5rbm93bj4ge1xuICAgIGV2ZW50OiBFdmVudDtcbiAgICBpdGVtOiBHYW50dEl0ZW08VD47XG59XG5cbmV4cG9ydCBjbGFzcyBHYW50dFNlbGVjdGVkRXZlbnQ8VCA9IHVua25vd24+IHtcbiAgICBldmVudDogRXZlbnQ7XG4gICAgc2VsZWN0ZWRWYWx1ZTogR2FudHRJdGVtPFQ+IHwgR2FudHRJdGVtPFQ+W107XG59XG4iXX0=
15
+ export class GanttTableDragDroppedEvent {
16
+ }
17
+ export class GanttTableDragEnterPredicateContext {
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9nYW50dC9zcmMvY2xhc3MvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFPLGNBQWM7Q0FFMUI7QUFFRCxNQUFNLE9BQU8sZUFBZTtDQUUzQjtBQUVELE1BQU0sT0FBTyxrQkFBa0I7Q0FJOUI7QUFFRCxNQUFNLE9BQU8sc0JBQXNCO0NBR2xDO0FBRUQsTUFBTSxPQUFPLG1CQUFtQjtDQUkvQjtBQUVELE1BQU0sT0FBTyxrQkFBa0I7Q0FHOUI7QUFFRCxNQUFNLE9BQU8sa0JBQWtCO0NBRzlCO0FBRUQsTUFBTSxPQUFPLDBCQUEwQjtDQU10QztBQUlELE1BQU0sT0FBTyxtQ0FBbUM7Q0FJL0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5neEdhbnR0VGFibGVDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuLi90YWJsZS9nYW50dC1jb2x1bW4uY29tcG9uZW50JztcbmltcG9ydCB7IEdhbnR0SXRlbSB9IGZyb20gJy4vaXRlbSc7XG5pbXBvcnQgeyBHYW50dExpbmtUeXBlIH0gZnJvbSAnLi9saW5rJztcblxuZXhwb3J0IGNsYXNzIEdhbnR0RHJhZ0V2ZW50PFQgPSB1bmtub3duPiB7XG4gICAgaXRlbTogR2FudHRJdGVtPFQ+O1xufVxuXG5leHBvcnQgY2xhc3MgR2FudHRUYWJsZUV2ZW50IHtcbiAgICBjb2x1bW5zOiBRdWVyeUxpc3Q8Tmd4R2FudHRUYWJsZUNvbHVtbkNvbXBvbmVudD47XG59XG5cbmV4cG9ydCBjbGFzcyBHYW50dExpbmtEcmFnRXZlbnQ8VCA9IHVua25vd24+IHtcbiAgICBzb3VyY2U6IEdhbnR0SXRlbTxUPjtcbiAgICB0YXJnZXQ/OiBHYW50dEl0ZW08VD47XG4gICAgdHlwZT86IEdhbnR0TGlua1R5cGU7XG59XG5cbmV4cG9ydCBjbGFzcyBHYW50dExvYWRPblNjcm9sbEV2ZW50IHtcbiAgICBzdGFydDogbnVtYmVyO1xuICAgIGVuZDogbnVtYmVyO1xufVxuXG5leHBvcnQgY2xhc3MgR2FudHRMaW5lQ2xpY2tFdmVudDxUID0gdW5rbm93bj4ge1xuICAgIGV2ZW50OiBNb3VzZUV2ZW50O1xuICAgIHNvdXJjZTogR2FudHRJdGVtPFQ+O1xuICAgIHRhcmdldDogR2FudHRJdGVtPFQ+O1xufVxuXG5leHBvcnQgY2xhc3MgR2FudHRCYXJDbGlja0V2ZW50PFQgPSB1bmtub3duPiB7XG4gICAgZXZlbnQ6IEV2ZW50O1xuICAgIGl0ZW06IEdhbnR0SXRlbTxUPjtcbn1cblxuZXhwb3J0IGNsYXNzIEdhbnR0U2VsZWN0ZWRFdmVudDxUID0gdW5rbm93bj4ge1xuICAgIGV2ZW50OiBFdmVudDtcbiAgICBzZWxlY3RlZFZhbHVlOiBHYW50dEl0ZW08VD4gfCBHYW50dEl0ZW08VD5bXTtcbn1cblxuZXhwb3J0IGNsYXNzIEdhbnR0VGFibGVEcmFnRHJvcHBlZEV2ZW50PFQgPSB1bmtub3duPiB7XG4gICAgc291cmNlOiBHYW50dEl0ZW08VD47XG4gICAgc291cmNlUGFyZW50OiBHYW50dEl0ZW08VD47XG4gICAgdGFyZ2V0OiBHYW50dEl0ZW08VD47XG4gICAgdGFyZ2V0UGFyZW50OiBHYW50dEl0ZW08VD47XG4gICAgZHJvcFBvc2l0aW9uOiBHYW50dFRhYmxlRHJvcFBvc2l0aW9uO1xufVxuXG5leHBvcnQgdHlwZSBHYW50dFRhYmxlRHJvcFBvc2l0aW9uID0gJ2JlZm9yZScgfCAnaW5zaWRlJyB8ICdhZnRlcic7XG5cbmV4cG9ydCBjbGFzcyBHYW50dFRhYmxlRHJhZ0VudGVyUHJlZGljYXRlQ29udGV4dDxUID0gdW5rbm93bj4ge1xuICAgIHNvdXJjZTogR2FudHRJdGVtPFQ+O1xuICAgIHRhcmdldDogR2FudHRJdGVtPFQ+O1xuICAgIGRyb3BQb3NpdGlvbjogR2FudHRUYWJsZURyb3BQb3NpdGlvbjtcbn1cbiJdfQ==
@@ -11,7 +11,7 @@ export class GanttItemInternal {
11
11
  get refs() {
12
12
  return this.refs$.getValue();
13
13
  }
14
- constructor(item, options) {
14
+ constructor(item, level, options) {
15
15
  this.refs$ = new BehaviorSubject(null);
16
16
  this.origin = item;
17
17
  this.id = this.origin.id;
@@ -30,14 +30,16 @@ export class GanttItemInternal {
30
30
  this.barStyle = this.origin.barStyle;
31
31
  this.linkable = this.origin.linkable === undefined ? true : this.origin.linkable;
32
32
  this.draggable = this.origin.draggable === undefined ? true : this.origin.draggable;
33
+ this.itemDraggable = this.origin.itemDraggable;
33
34
  this.expandable = this.origin.expandable || (this.origin.children || []).length > 0;
34
35
  this.expanded = this.origin.expanded === undefined ? false : this.origin.expanded;
35
36
  this.start = item.start ? new GanttDate(item.start) : null;
36
37
  this.end = item.end ? new GanttDate(item.end) : null;
38
+ this.level = level;
37
39
  // 默认填充 30 天
38
40
  this.fillDays = options?.fillDays || 30;
39
41
  this.children = (item.children || []).map((subItem) => {
40
- return new GanttItemInternal(subItem, { fillDays: this.fillDays });
42
+ return new GanttItemInternal(subItem, level + 1, { fillDays: this.fillDays });
41
43
  });
42
44
  this.type = this.origin.type || GanttItemType.bar;
43
45
  this.progress = this.origin.progress;
@@ -64,10 +66,13 @@ export class GanttItemInternal {
64
66
  this.origin.start = this.start.getUnixTime();
65
67
  this.origin.end = this.end.getUnixTime();
66
68
  }
69
+ updateLevel(level) {
70
+ this.level = level;
71
+ }
67
72
  addChildren(items) {
68
73
  this.origin.children = items;
69
74
  this.children = (items || []).map((subItem) => {
70
- return new GanttItemInternal(subItem, { fillDays: this.fillDays });
75
+ return new GanttItemInternal(subItem, this.level + 1, { fillDays: this.fillDays });
71
76
  });
72
77
  }
73
78
  setExpand(expanded) {
@@ -79,4 +84,4 @@ export class GanttItemInternal {
79
84
  this.origin.links = this.links;
80
85
  }
81
86
  }
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.js","sourceRoot":"","sources":["../../../../packages/gantt/src/class/item.ts"],"names":[],"mappings":"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","sourcesContent":["import { GanttDate } from '../utils/date';\nimport { BehaviorSubject } from 'rxjs';\nimport { GanttLink, GanttLinkType } from './link';\n\nexport interface GanttItemRefs {\n    width: number;\n    x: number;\n    y: number;\n}\n\nexport enum GanttItemType {\n    bar = 'bar',\n    range = 'range',\n    custom = 'custom'\n}\n\nexport interface GanttItem<T = unknown> {\n    id: string;\n    title: string;\n    start?: number;\n    end?: number;\n    group_id?: string;\n    links?: (GanttLink | string)[];\n    draggable?: boolean;\n    linkable?: boolean;\n    expandable?: boolean;\n    expanded?: boolean;\n    children?: GanttItem[];\n    color?: string;\n    barStyle?: Partial<CSSStyleDeclaration>;\n    origin?: T;\n    type?: GanttItemType;\n    progress?: number;\n}\n\nexport class GanttItemInternal {\n    id: string;\n    title: string;\n    start: GanttDate;\n    end: GanttDate;\n    links: GanttLink[];\n    color?: string;\n    barStyle?: Partial<CSSStyleDeclaration>;\n    draggable?: boolean;\n    linkable?: boolean;\n    origin: GanttItem;\n    expandable?: boolean;\n    expanded?: boolean;\n    loading: boolean;\n    children: GanttItemInternal[];\n    type?: GanttItemType;\n    progress?: number;\n    fillDays?: number;\n\n    get refs() {\n        return this.refs$.getValue();\n    }\n\n    refs$ = new BehaviorSubject<{ width: number; x: number; y: number }>(null);\n\n    constructor(item: GanttItem, options?: { fillDays: number }) {\n        this.origin = item;\n        this.id = this.origin.id;\n        this.links = (this.origin.links || []).map((link) => {\n            if (typeof link === 'string') {\n                return {\n                    type: GanttLinkType.fs,\n                    link\n                };\n            } else {\n                return link;\n            }\n        });\n        this.color = this.origin.color;\n        this.barStyle = this.origin.barStyle;\n        this.linkable = this.origin.linkable === undefined ? true : this.origin.linkable;\n        this.draggable = this.origin.draggable === undefined ? true : this.origin.draggable;\n        this.expandable = this.origin.expandable || (this.origin.children || []).length > 0;\n        this.expanded = this.origin.expanded === undefined ? false : this.origin.expanded;\n        this.start = item.start ? new GanttDate(item.start) : null;\n        this.end = item.end ? new GanttDate(item.end) : null;\n        //  默认填充 30 天\n        this.fillDays = options?.fillDays || 30;\n        this.children = (item.children || []).map((subItem) => {\n            return new GanttItemInternal(subItem, { fillDays: this.fillDays });\n        });\n        this.type = this.origin.type || GanttItemType.bar;\n        this.progress = this.origin.progress;\n        // fill days when start or end is null\n        this.fillItemStartOrEnd(item);\n    }\n\n    fillItemStartOrEnd(item: GanttItem) {\n        if (this.fillDays > 0) {\n            const fillDays = this.fillDays - 1;\n            if (item.start && !item.end) {\n                this.end = new GanttDate(item.start).addDays(fillDays).endOfDay();\n            }\n            if (!item.start && item.end) {\n                this.start = new GanttDate(item.end).addDays(-fillDays).startOfDay();\n            }\n        }\n    }\n\n    updateRefs(refs: GanttItemRefs) {\n        this.refs$.next(refs);\n    }\n\n    updateDate(start: GanttDate, end: GanttDate) {\n        this.start = start.startOfDay();\n        this.end = end.endOfDay();\n        this.origin.start = this.start.getUnixTime();\n        this.origin.end = this.end.getUnixTime();\n    }\n\n    addChildren(items: GanttItem[]) {\n        this.origin.children = items;\n        this.children = (items || []).map((subItem) => {\n            return new GanttItemInternal(subItem, { fillDays: this.fillDays });\n        });\n    }\n\n    setExpand(expanded: boolean) {\n        this.expanded = expanded;\n        this.origin.expanded = expanded;\n    }\n\n    addLink(link: GanttLink) {\n        this.links = [...this.links, link];\n        this.origin.links = this.links;\n    }\n}\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.js","sourceRoot":"","sources":["../../../../packages/gantt/src/class/item.ts"],"names":[],"mappings":"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","sourcesContent":["import { GanttDate } from '../utils/date';\nimport { BehaviorSubject } from 'rxjs';\nimport { GanttLink, GanttLinkType } from './link';\nimport { GanttViewType } from './view-type';\n\nexport interface GanttItemRefs {\n    width: number;\n    x: number;\n    y: number;\n}\n\nexport enum GanttItemType {\n    bar = 'bar',\n    range = 'range',\n    custom = 'custom'\n}\n\nexport interface GanttItem<T = unknown> {\n    id: string;\n    title: string;\n    start?: number;\n    end?: number;\n    group_id?: string;\n    links?: (GanttLink | string)[];\n    draggable?: boolean;\n    itemDraggable?: boolean;\n    linkable?: boolean;\n    expandable?: boolean;\n    expanded?: boolean;\n    children?: GanttItem[];\n    color?: string;\n    barStyle?: Partial<CSSStyleDeclaration>;\n    origin?: T;\n    type?: GanttItemType;\n    progress?: number;\n}\n\nexport class GanttItemInternal {\n    id: string;\n    title: string;\n    start: GanttDate;\n    end: GanttDate;\n    links: GanttLink[];\n    color?: string;\n    barStyle?: Partial<CSSStyleDeclaration>;\n    draggable?: boolean;\n    itemDraggable?: boolean;\n    linkable?: boolean;\n    origin: GanttItem;\n    expandable?: boolean;\n    expanded?: boolean;\n    loading: boolean;\n    children: GanttItemInternal[];\n    type?: GanttItemType;\n    progress?: number;\n    fillDays?: number;\n    viewType?: GanttViewType;\n    level?: number;\n\n    get refs() {\n        return this.refs$.getValue();\n    }\n\n    refs$ = new BehaviorSubject<{ width: number; x: number; y: number }>(null);\n\n    constructor(item: GanttItem, level?: number, options?: { fillDays: number }) {\n        this.origin = item;\n        this.id = this.origin.id;\n        this.links = (this.origin.links || []).map((link) => {\n            if (typeof link === 'string') {\n                return {\n                    type: GanttLinkType.fs,\n                    link\n                };\n            } else {\n                return link;\n            }\n        });\n        this.color = this.origin.color;\n        this.barStyle = this.origin.barStyle;\n        this.linkable = this.origin.linkable === undefined ? true : this.origin.linkable;\n        this.draggable = this.origin.draggable === undefined ? true : this.origin.draggable;\n        this.itemDraggable = this.origin.itemDraggable;\n        this.expandable = this.origin.expandable || (this.origin.children || []).length > 0;\n        this.expanded = this.origin.expanded === undefined ? false : this.origin.expanded;\n        this.start = item.start ? new GanttDate(item.start) : null;\n        this.end = item.end ? new GanttDate(item.end) : null;\n        this.level = level;\n        //  默认填充 30 天\n        this.fillDays = options?.fillDays || 30;\n        this.children = (item.children || []).map((subItem) => {\n            return new GanttItemInternal(subItem, level + 1, { fillDays: this.fillDays });\n        });\n        this.type = this.origin.type || GanttItemType.bar;\n        this.progress = this.origin.progress;\n        // fill days when start or end is null\n        this.fillItemStartOrEnd(item);\n    }\n\n    fillItemStartOrEnd(item: GanttItem) {\n        if (this.fillDays > 0) {\n            const fillDays = this.fillDays - 1;\n            if (item.start && !item.end) {\n                this.end = new GanttDate(item.start).addDays(fillDays).endOfDay();\n            }\n            if (!item.start && item.end) {\n                this.start = new GanttDate(item.end).addDays(-fillDays).startOfDay();\n            }\n        }\n    }\n\n    updateRefs(refs: GanttItemRefs) {\n        this.refs$.next(refs);\n    }\n\n    updateDate(start: GanttDate, end: GanttDate) {\n        this.start = start.startOfDay();\n        this.end = end.endOfDay();\n        this.origin.start = this.start.getUnixTime();\n        this.origin.end = this.end.getUnixTime();\n    }\n\n    updateLevel(level: number) {\n        this.level = level;\n    }\n\n    addChildren(items: GanttItem[]) {\n        this.origin.children = items;\n        this.children = (items || []).map((subItem) => {\n            return new GanttItemInternal(subItem, this.level + 1, { fillDays: this.fillDays });\n        });\n    }\n\n    setExpand(expanded: boolean) {\n        this.expanded = expanded;\n        this.origin.expanded = expanded;\n    }\n\n    addLink(link: GanttLink) {\n        this.links = [...this.links, link];\n        this.origin.links = this.links;\n    }\n}\n"]}