@worktile/gantt 12.2.2 → 13.0.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 (77) hide show
  1. package/components/bar/bar.component.scss +201 -0
  2. package/components/calendar/calendar.component.scss +79 -0
  3. package/components/drag-backdrop/drag-backdrop.component.scss +50 -0
  4. package/components/icon/icon.component.scss +13 -0
  5. package/components/links/links.component.scss +29 -0
  6. package/components/range/range.component.scss +35 -0
  7. package/components/table/gantt-table.component.scss +153 -0
  8. package/{esm2015/class/date-point.js → esm2020/class/date-point.mjs} +0 -0
  9. package/{esm2015/class/event.js → esm2020/class/event.mjs} +0 -0
  10. package/{esm2015/class/group.js → esm2020/class/group.mjs} +0 -0
  11. package/{esm2015/class/index.js → esm2020/class/index.mjs} +0 -0
  12. package/{esm2015/class/item.js → esm2020/class/item.mjs} +0 -0
  13. package/{esm2015/class/link.js → esm2020/class/link.mjs} +0 -0
  14. package/{esm2015/class/view-type.js → esm2020/class/view-type.mjs} +0 -0
  15. package/esm2020/components/bar/bar-drag.mjs +308 -0
  16. package/{esm2015/components/bar/bar.component.js → esm2020/components/bar/bar.component.mjs} +5 -9
  17. package/{esm2015/components/calendar/calendar.component.js → esm2020/components/calendar/calendar.component.mjs} +5 -8
  18. package/{esm2015/components/drag-backdrop/drag-backdrop.component.js → esm2020/components/drag-backdrop/drag-backdrop.component.mjs} +6 -10
  19. package/{esm2015/components/icon/icon.component.js → esm2020/components/icon/icon.component.mjs} +3 -3
  20. package/{esm2015/components/icon/icons.js → esm2020/components/icon/icons.mjs} +0 -0
  21. package/esm2020/components/links/lines/curve.mjs +95 -0
  22. package/{esm2015/components/links/lines/factory.js → esm2020/components/links/lines/factory.mjs} +0 -0
  23. package/{esm2015/components/links/lines/line.js → esm2020/components/links/lines/line.mjs} +0 -0
  24. package/{esm2015/components/links/lines/straight.js → esm2020/components/links/lines/straight.mjs} +0 -0
  25. package/esm2020/components/links/links.component.mjs +178 -0
  26. package/{esm2015/components/main/gantt-main.component.js → esm2020/components/main/gantt-main.component.mjs} +5 -8
  27. package/{esm2015/components/range/range.component.js → esm2020/components/range/range.component.mjs} +5 -8
  28. package/esm2020/components/table/gantt-table.component.mjs +163 -0
  29. package/{esm2015/gantt-abstract.js → esm2020/gantt-abstract.mjs} +0 -0
  30. package/{esm2015/gantt-dom.service.js → esm2020/gantt-dom.service.mjs} +3 -3
  31. package/esm2020/gantt-drag-container.mjs +78 -0
  32. package/{esm2015/gantt-item-upper.js → esm2020/gantt-item-upper.mjs} +4 -4
  33. package/esm2020/gantt-print.service.mjs +94 -0
  34. package/esm2020/gantt-upper.mjs +339 -0
  35. package/{esm2015/gantt.component.js → esm2020/gantt.component.mjs} +7 -13
  36. package/{esm2015/gantt.config.js → esm2020/gantt.config.mjs} +0 -0
  37. package/{esm2015/gantt.module.js → esm2020/gantt.module.mjs} +4 -4
  38. package/{esm2015/gantt.pipe.js → esm2020/gantt.pipe.mjs} +9 -9
  39. package/{esm2015/gantt.styles.js → esm2020/gantt.styles.mjs} +0 -0
  40. package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
  41. package/{esm2015/root.component.js → esm2020/root.component.mjs} +6 -11
  42. package/{esm2015/table/gantt-column.component.js → esm2020/table/gantt-column.component.mjs} +3 -3
  43. package/{esm2015/table/gantt-table.component.js → esm2020/table/gantt-table.component.mjs} +3 -3
  44. package/{esm2015/utils/date.js → esm2020/utils/date.mjs} +0 -0
  45. package/{esm2015/utils/helpers.js → esm2020/utils/helpers.mjs} +0 -0
  46. package/{esm2015/utils/passive-listeners.js → esm2020/utils/passive-listeners.mjs} +0 -0
  47. package/{esm2015/utils/set-style-with-vendor-prefix.js → esm2020/utils/set-style-with-vendor-prefix.mjs} +0 -0
  48. package/{esm2015/views/day.js → esm2020/views/day.mjs} +0 -0
  49. package/{esm2015/views/factory.js → esm2020/views/factory.mjs} +0 -0
  50. package/{esm2015/views/month.js → esm2020/views/month.mjs} +0 -0
  51. package/{esm2015/views/quarter.js → esm2020/views/quarter.mjs} +0 -0
  52. package/{esm2015/views/view.js → esm2020/views/view.mjs} +5 -5
  53. package/{esm2015/views/week.js → esm2020/views/week.mjs} +0 -0
  54. package/{esm2015/views/year.js → esm2020/views/year.mjs} +0 -0
  55. package/{esm2015/worktile-gantt.js → esm2020/worktile-gantt.mjs} +0 -0
  56. package/fesm2015/worktile-gantt.mjs +3080 -0
  57. package/fesm2015/worktile-gantt.mjs.map +1 -0
  58. package/{fesm2015/worktile-gantt.js → fesm2020/worktile-gantt.mjs} +175 -199
  59. package/fesm2020/worktile-gantt.mjs.map +1 -0
  60. package/gantt-drag-container.d.ts +1 -1
  61. package/gantt-item-upper.d.ts +1 -1
  62. package/gantt-upper.d.ts +1 -1
  63. package/gantt.component.scss +83 -0
  64. package/package.json +33 -9
  65. package/styles/index.scss +9 -0
  66. package/styles/variables.scss +46 -0
  67. package/bundles/worktile-gantt.umd.js +0 -3717
  68. package/bundles/worktile-gantt.umd.js.map +0 -1
  69. package/esm2015/components/bar/bar-drag.js +0 -302
  70. package/esm2015/components/links/lines/curve.js +0 -96
  71. package/esm2015/components/links/links.component.js +0 -173
  72. package/esm2015/components/table/gantt-table.component.js +0 -167
  73. package/esm2015/gantt-drag-container.js +0 -77
  74. package/esm2015/gantt-print.service.js +0 -97
  75. package/esm2015/gantt-upper.js +0 -340
  76. package/fesm2015/worktile-gantt.js.map +0 -1
  77. package/main.bundle.scss +0 -688
@@ -1,173 +0,0 @@
1
- import { Component, Input, Output, EventEmitter, HostBinding, Inject } from '@angular/core';
2
- import { merge, Subject } from 'rxjs';
3
- import { takeUntil, skip, debounceTime } from 'rxjs/operators';
4
- import { recursiveItems } from '../../utils/helpers';
5
- import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
6
- import { LinkColors, GanttLinkType } from '../../class/link';
7
- import { createLineGenerator } from './lines/factory';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../../gantt-drag-container";
10
- import * as i2 from "@angular/common";
11
- import * as i3 from "../../gantt-upper";
12
- export class GanttLinksComponent {
13
- constructor(ganttUpper, cdr, elementRef, ganttDragContainer) {
14
- this.ganttUpper = ganttUpper;
15
- this.cdr = cdr;
16
- this.elementRef = elementRef;
17
- this.ganttDragContainer = ganttDragContainer;
18
- this.groups = [];
19
- this.items = [];
20
- this.lineClick = new EventEmitter();
21
- this.links = [];
22
- this.ganttLinkTypes = GanttLinkType;
23
- this.showArrow = false;
24
- this.linkItems = [];
25
- this.firstChange = true;
26
- this.unsubscribe$ = new Subject();
27
- this.ganttLinksOverlay = true;
28
- }
29
- ngOnInit() {
30
- this.linkLine = createLineGenerator(this.ganttUpper.linkOptions.lineType, this.ganttUpper);
31
- this.showArrow = this.ganttUpper.linkOptions.showArrow;
32
- this.buildLinks();
33
- this.firstChange = false;
34
- this.ganttDragContainer.dragStarted.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
35
- this.elementRef.nativeElement.style.visibility = 'hidden';
36
- });
37
- merge(this.ganttUpper.viewChange, this.ganttUpper.expandChange, this.ganttUpper.view.start$, this.ganttUpper.dragEnded, this.ganttUpper.linkDragEnded)
38
- .pipe(skip(1), debounceTime(0), takeUntil(this.unsubscribe$))
39
- .subscribe(() => {
40
- this.elementRef.nativeElement.style.visibility = 'visible';
41
- this.buildLinks();
42
- this.cdr.detectChanges();
43
- });
44
- }
45
- ngOnChanges() {
46
- if (!this.firstChange) {
47
- this.buildLinks();
48
- }
49
- }
50
- computeItemPosition() {
51
- const lineHeight = this.ganttUpper.styles.lineHeight;
52
- const barHeight = this.ganttUpper.styles.barHeight;
53
- this.linkItems = [];
54
- if (this.groups.length > 0) {
55
- let itemNum = 0;
56
- let groupNum = 0;
57
- this.groups.forEach((group) => {
58
- groupNum++;
59
- if (group.expanded) {
60
- const items = recursiveItems(group.items);
61
- items.forEach((item, itemIndex) => {
62
- const y = (groupNum + itemNum + itemIndex) * lineHeight + item.refs.y + barHeight / 2;
63
- this.linkItems.push(Object.assign(Object.assign({}, item), { before: {
64
- x: item.refs.x,
65
- y
66
- }, after: {
67
- x: item.refs.x + item.refs.width,
68
- y
69
- } }));
70
- });
71
- itemNum += items.length;
72
- }
73
- });
74
- }
75
- else {
76
- const items = recursiveItems(this.items);
77
- items.forEach((item, itemIndex) => {
78
- const y = itemIndex * lineHeight + item.refs.y + barHeight / 2;
79
- this.linkItems.push(Object.assign(Object.assign({}, item), { before: {
80
- x: item.refs.x,
81
- y
82
- }, after: {
83
- x: item.refs.x + item.refs.width,
84
- y
85
- } }));
86
- });
87
- }
88
- }
89
- buildLinks() {
90
- this.computeItemPosition();
91
- this.links = [];
92
- this.linkItems.forEach((source) => {
93
- if (source.origin.start || source.origin.end) {
94
- source.links.forEach((link) => {
95
- const target = this.linkItems.find((item) => item.id === link.link);
96
- if (target && (target.origin.start || target.origin.end)) {
97
- let defaultColor = LinkColors.default;
98
- let activeColor = LinkColors.active;
99
- if (link.type === GanttLinkType.fs && source.end.getTime() > target.start.getTime()) {
100
- defaultColor = LinkColors.blocked;
101
- activeColor = LinkColors.blocked;
102
- }
103
- if (link.color) {
104
- if (typeof link.color === 'string') {
105
- defaultColor = link.color;
106
- activeColor = link.color;
107
- }
108
- else {
109
- defaultColor = link.color.default;
110
- activeColor = link.color.active;
111
- }
112
- }
113
- this.links.push({
114
- path: this.linkLine.generatePath(source, target, link.type),
115
- source: source.origin,
116
- target: target.origin,
117
- type: link.type,
118
- color: defaultColor,
119
- defaultColor,
120
- activeColor
121
- });
122
- }
123
- });
124
- }
125
- });
126
- }
127
- trackBy(index) {
128
- return index;
129
- }
130
- onLineClick(event, link) {
131
- this.lineClick.emit({
132
- event,
133
- source: link.source,
134
- target: link.target
135
- });
136
- }
137
- mouseEnterPath(link, index) {
138
- link.color = link.activeColor || link.defaultColor;
139
- if (index < this.links.length - 1) {
140
- this.links.splice(index, 1);
141
- this.links.push(link);
142
- }
143
- }
144
- mouseLeavePath(link) {
145
- link.color = link.defaultColor;
146
- }
147
- ngOnDestroy() {
148
- this.unsubscribe$.next();
149
- this.unsubscribe$.complete();
150
- }
151
- }
152
- GanttLinksComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttLinksComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.GanttDragContainer }], target: i0.ɵɵFactoryTarget.Component });
153
- GanttLinksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: GanttLinksComponent, selector: "gantt-links-overlay", inputs: { groups: "groups", items: "items" }, outputs: { lineClick: "lineClick" }, host: { properties: { "class.gantt-links-overlay": "this.ganttLinksOverlay" } }, usesOnChanges: true, ngImport: i0, template: "<svg [attr.width]=\"ganttUpper.view.width\" class=\"gantt-links-overlay-main\">\n <ng-container *ngFor=\"let link of links; let i = index; trackBy: trackBy\">\n <path\n [attr.d]=\"link.path\"\n fill=\"transparent\"\n stroke-width=\"2\"\n [attr.stroke]=\"link.color\"\n pointer-events=\"none\"\n [attr.style]=\"link.type === ganttLinkTypes.sf ? 'marker-start: url(#triangle' + i + ')' : 'marker-end: url(#triangle' + i + ')'\"\n ></path>\n\n <g>\n <path\n class=\"link-line\"\n (click)=\"onLineClick($event, link)\"\n [attr.d]=\"link.path\"\n (mouseenter)=\"mouseEnterPath(link, i)\"\n (mouseleave)=\"mouseLeavePath(link)\"\n stroke=\"transparent\"\n stroke-width=\"9\"\n fill=\"none\"\n cursor=\"pointer\"\n ></path>\n </g>\n <defs *ngIf=\"showArrow\">\n <marker\n *ngIf=\"link.type === ganttLinkTypes.sf; else markerEnd\"\n [id]=\"'triangle' + i\"\n markerUnits=\"strokeWidth\"\n markerWidth=\"5\"\n markerHeight=\"4\"\n refX=\"5\"\n refY=\"2\"\n orient=\"180\"\n >\n <path [attr.fill]=\"link.color\" [attr.stroke]=\"link.color\" d=\"M 0 0 L 5 2 L 0 4 z\" />\n </marker>\n\n <ng-template #markerEnd>\n <marker [id]=\"'triangle' + i\" markerUnits=\"strokeWidth\" markerWidth=\"5\" markerHeight=\"4\" refX=\"5\" refY=\"2\" orient=\"auto\">\n <path [attr.fill]=\"link.color\" [attr.stroke]=\"link.color\" d=\"M 0 0 L 5 2 L 0 4 z\" />\n </marker>\n </ng-template>\n </defs>\n </ng-container>\n <line class=\"link-dragging-line\"></line>\n</svg>\n", directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
154
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttLinksComponent, decorators: [{
155
- type: Component,
156
- args: [{
157
- selector: 'gantt-links-overlay',
158
- templateUrl: './links.component.html'
159
- }]
160
- }], ctorParameters: function () { return [{ type: i3.GanttUpper, decorators: [{
161
- type: Inject,
162
- args: [GANTT_UPPER_TOKEN]
163
- }] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.GanttDragContainer }]; }, propDecorators: { groups: [{
164
- type: Input
165
- }], items: [{
166
- type: Input
167
- }], lineClick: [{
168
- type: Output
169
- }], ganttLinksOverlay: [{
170
- type: HostBinding,
171
- args: ['class.gantt-links-overlay']
172
- }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"links.component.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/links/links.component.ts","../../../../../packages/gantt/src/components/links/links.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    Input,\n    Output,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    ChangeDetectorRef,\n    ElementRef,\n    OnDestroy,\n    OnChanges\n} from '@angular/core';\nimport { merge, Subject } from 'rxjs';\nimport { takeUntil, skip, debounceTime } from 'rxjs/operators';\nimport { GanttGroupInternal } from '../../class/group';\nimport { GanttItemInternal } from './../../class/item';\nimport { GanttLineClickEvent } from '../../class/event';\nimport { GanttDragContainer } from '../../gantt-drag-container';\nimport { recursiveItems } from '../../utils/helpers';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../gantt-upper';\nimport { GanttLinkItem, LinkInternal, LinkColors, GanttLinkType } from '../../class/link';\nimport { GanttLinkLine } from './lines/line';\nimport { createLineGenerator } from './lines/factory';\n\n@Component({\n    selector: 'gantt-links-overlay',\n    templateUrl: './links.component.html'\n})\nexport class GanttLinksComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() groups: GanttGroupInternal[] = [];\n\n    @Input() items: GanttItemInternal[] = [];\n\n    @Output() lineClick = new EventEmitter<GanttLineClickEvent>();\n\n    public links: LinkInternal[] = [];\n\n    public ganttLinkTypes = GanttLinkType;\n\n    public showArrow = false;\n\n    private linkItems: GanttLinkItem[] = [];\n\n    private firstChange = true;\n\n    private linkLine: GanttLinkLine;\n\n    private unsubscribe$ = new Subject();\n\n    @HostBinding('class.gantt-links-overlay') ganttLinksOverlay = true;\n\n    constructor(\n        @Inject(GANTT_UPPER_TOKEN) public ganttUpper: GanttUpper,\n        private cdr: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private ganttDragContainer: GanttDragContainer\n    ) {}\n\n    ngOnInit() {\n        this.linkLine = createLineGenerator(this.ganttUpper.linkOptions.lineType, this.ganttUpper);\n\n        this.showArrow = this.ganttUpper.linkOptions.showArrow;\n        this.buildLinks();\n        this.firstChange = false;\n\n        this.ganttDragContainer.dragStarted.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.elementRef.nativeElement.style.visibility = 'hidden';\n        });\n\n        merge(\n            this.ganttUpper.viewChange,\n            this.ganttUpper.expandChange,\n            this.ganttUpper.view.start$,\n            this.ganttUpper.dragEnded,\n            this.ganttUpper.linkDragEnded\n        )\n            .pipe(skip(1), debounceTime(0), takeUntil(this.unsubscribe$))\n            .subscribe(() => {\n                this.elementRef.nativeElement.style.visibility = 'visible';\n                this.buildLinks();\n                this.cdr.detectChanges();\n            });\n    }\n\n    ngOnChanges() {\n        if (!this.firstChange) {\n            this.buildLinks();\n        }\n    }\n\n    private computeItemPosition() {\n        const lineHeight = this.ganttUpper.styles.lineHeight;\n        const barHeight = this.ganttUpper.styles.barHeight;\n        this.linkItems = [];\n        if (this.groups.length > 0) {\n            let itemNum = 0;\n            let groupNum = 0;\n            this.groups.forEach((group) => {\n                groupNum++;\n                if (group.expanded) {\n                    const items = recursiveItems(group.items);\n                    items.forEach((item, itemIndex) => {\n                        const y = (groupNum + itemNum + itemIndex) * lineHeight + item.refs.y + barHeight / 2;\n                        this.linkItems.push({\n                            ...item,\n                            before: {\n                                x: item.refs.x,\n                                y\n                            },\n                            after: {\n                                x: item.refs.x + item.refs.width,\n                                y\n                            }\n                        });\n                    });\n                    itemNum += items.length;\n                }\n            });\n        } else {\n            const items = recursiveItems(this.items);\n            items.forEach((item, itemIndex) => {\n                const y = itemIndex * lineHeight + item.refs.y + barHeight / 2;\n                this.linkItems.push({\n                    ...item,\n                    before: {\n                        x: item.refs.x,\n                        y\n                    },\n                    after: {\n                        x: item.refs.x + item.refs.width,\n                        y\n                    }\n                });\n            });\n        }\n    }\n\n    buildLinks() {\n        this.computeItemPosition();\n        this.links = [];\n        this.linkItems.forEach((source) => {\n            if (source.origin.start || source.origin.end) {\n                source.links.forEach((link) => {\n                    const target = this.linkItems.find((item) => item.id === link.link);\n                    if (target && (target.origin.start || target.origin.end)) {\n                        let defaultColor: string = LinkColors.default;\n                        let activeColor: string = LinkColors.active;\n\n                        if (link.type === GanttLinkType.fs && source.end.getTime() > target.start.getTime()) {\n                            defaultColor = LinkColors.blocked;\n                            activeColor = LinkColors.blocked;\n                        }\n                        if (link.color) {\n                            if (typeof link.color === 'string') {\n                                defaultColor = link.color;\n                                activeColor = link.color;\n                            } else {\n                                defaultColor = link.color.default;\n                                activeColor = link.color.active;\n                            }\n                        }\n\n                        this.links.push({\n                            path: this.linkLine.generatePath(source, target, link.type),\n                            source: source.origin,\n                            target: target.origin,\n                            type: link.type,\n                            color: defaultColor,\n                            defaultColor,\n                            activeColor\n                        });\n                    }\n                });\n            }\n        });\n    }\n\n    trackBy(index: number) {\n        return index;\n    }\n\n    onLineClick(event: MouseEvent, link: LinkInternal) {\n        this.lineClick.emit({\n            event,\n            source: link.source,\n            target: link.target\n        });\n    }\n\n    mouseEnterPath(link: LinkInternal, index: number) {\n        link.color = link.activeColor || link.defaultColor;\n        if (index < this.links.length - 1) {\n            this.links.splice(index, 1);\n            this.links.push(link);\n        }\n    }\n\n    mouseLeavePath(link: LinkInternal) {\n        link.color = link.defaultColor;\n    }\n\n    ngOnDestroy() {\n        this.unsubscribe$.next();\n        this.unsubscribe$.complete();\n    }\n}\n","<svg [attr.width]=\"ganttUpper.view.width\" class=\"gantt-links-overlay-main\">\n  <ng-container *ngFor=\"let link of links; let i = index; trackBy: trackBy\">\n    <path\n      [attr.d]=\"link.path\"\n      fill=\"transparent\"\n      stroke-width=\"2\"\n      [attr.stroke]=\"link.color\"\n      pointer-events=\"none\"\n      [attr.style]=\"link.type === ganttLinkTypes.sf ? 'marker-start: url(#triangle' + i + ')' : 'marker-end: url(#triangle' + i + ')'\"\n    ></path>\n\n    <g>\n      <path\n        class=\"link-line\"\n        (click)=\"onLineClick($event, link)\"\n        [attr.d]=\"link.path\"\n        (mouseenter)=\"mouseEnterPath(link, i)\"\n        (mouseleave)=\"mouseLeavePath(link)\"\n        stroke=\"transparent\"\n        stroke-width=\"9\"\n        fill=\"none\"\n        cursor=\"pointer\"\n      ></path>\n    </g>\n    <defs *ngIf=\"showArrow\">\n      <marker\n        *ngIf=\"link.type === ganttLinkTypes.sf; else markerEnd\"\n        [id]=\"'triangle' + i\"\n        markerUnits=\"strokeWidth\"\n        markerWidth=\"5\"\n        markerHeight=\"4\"\n        refX=\"5\"\n        refY=\"2\"\n        orient=\"180\"\n      >\n        <path [attr.fill]=\"link.color\" [attr.stroke]=\"link.color\" d=\"M 0 0 L 5 2 L 0 4 z\" />\n      </marker>\n\n      <ng-template #markerEnd>\n        <marker [id]=\"'triangle' + i\" markerUnits=\"strokeWidth\" markerWidth=\"5\" markerHeight=\"4\" refX=\"5\" refY=\"2\" orient=\"auto\">\n          <path [attr.fill]=\"link.color\" [attr.stroke]=\"link.color\" d=\"M 0 0 L 5 2 L 0 4 z\" />\n        </marker>\n      </ng-template>\n    </defs>\n  </ng-container>\n  <line class=\"link-dragging-line\"></line>\n</svg>\n"]}
@@ -1,167 +0,0 @@
1
- import { Component, HostBinding, Input, ViewChild, Inject, Output, EventEmitter } from '@angular/core';
2
- import { coerceCssPixelValue } from '@angular/cdk/coercion';
3
- import { GANTT_ABSTRACT_TOKEN } from '../../gantt-abstract';
4
- import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
5
- import { setStyleWithVendorPrefix } from '../../utils/set-style-with-vendor-prefix';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "../icon/icon.component";
8
- import * as i2 from "@angular/common";
9
- import * as i3 from "@angular/cdk/drag-drop";
10
- import * as i4 from "../../gantt.pipe";
11
- import * as i5 from "../../gantt-upper";
12
- export const defaultColumnWidth = 100;
13
- export const minColumnWidth = 80;
14
- export class GanttTableComponent {
15
- constructor(gantt, ganttUpper, elementRef) {
16
- this.gantt = gantt;
17
- this.ganttUpper = ganttUpper;
18
- this.elementRef = elementRef;
19
- this.itemClick = new EventEmitter();
20
- this.ganttTableClass = true;
21
- this.ganttTableEmptyClass = false;
22
- }
23
- set columns(columns) {
24
- columns.forEach((column) => {
25
- if (!column.columnWidth) {
26
- column.columnWidth = coerceCssPixelValue(defaultColumnWidth);
27
- }
28
- });
29
- this.columnList = columns;
30
- }
31
- ngOnChanges(changes) {
32
- var _a, _b;
33
- if (!((_a = changes.groups.currentValue) === null || _a === void 0 ? void 0 : _a.length) && !((_b = changes.items.currentValue) === null || _b === void 0 ? void 0 : _b.length)) {
34
- this.ganttTableEmptyClass = true;
35
- }
36
- else {
37
- this.ganttTableEmptyClass = false;
38
- }
39
- }
40
- dragFixed(config) {
41
- if (config.movedWidth < config.minWidth) {
42
- setStyleWithVendorPrefix({
43
- element: config.target,
44
- style: 'transform',
45
- value: `translate3d(${config.minWidth - config.originWidth}px, 0, 0)`
46
- });
47
- }
48
- }
49
- expandGroup(group) {
50
- this.gantt.expandGroup(group);
51
- }
52
- expandChildren(event, item) {
53
- event.stopPropagation();
54
- this.gantt.expandChildren(item);
55
- }
56
- dragStarted(event) {
57
- const target = event.source.element.nativeElement;
58
- this.dragStartLeft = target.getBoundingClientRect().left;
59
- }
60
- dragMoved(event, column) {
61
- const target = event.source.element.nativeElement;
62
- const left = target.getBoundingClientRect().left;
63
- let originWidth;
64
- let movedWidth;
65
- let minWidth;
66
- if (column) {
67
- originWidth = parseInt(column.columnWidth, 10);
68
- movedWidth = originWidth + (left - this.dragStartLeft);
69
- minWidth = minColumnWidth;
70
- }
71
- else {
72
- originWidth = this.elementRef.nativeElement.getBoundingClientRect().width;
73
- movedWidth = originWidth + (left - this.dragStartLeft);
74
- minWidth = minColumnWidth * this.columnList.length;
75
- }
76
- this.dragFixed({
77
- target,
78
- originWidth,
79
- movedWidth,
80
- minWidth
81
- });
82
- this.showAuxiliaryLine(event);
83
- }
84
- columnDragEnded(event, column) {
85
- const target = event.source.element.nativeElement;
86
- const left = target.getBoundingClientRect().left;
87
- const width = parseInt(column.columnWidth, 10) + (left - this.dragStartLeft);
88
- const columnWidth = Math.max(width || 0, minColumnWidth);
89
- column.columnWidth = coerceCssPixelValue(columnWidth);
90
- if (this.gantt.table) {
91
- this.gantt.table.columnChanges.emit({ columns: this.columnList });
92
- }
93
- this.hideAuxiliaryLine();
94
- event.source.reset();
95
- }
96
- tableDragEnded(event) {
97
- const target = event.source.element.nativeElement;
98
- const left = target.getBoundingClientRect().left;
99
- const tableWidth = this.elementRef.nativeElement.getBoundingClientRect().width;
100
- const dragWidth = left - this.dragStartLeft;
101
- this.columnList.forEach((column) => {
102
- const lastColumnWidth = parseInt(column.columnWidth, 10);
103
- const distributeWidth = parseInt(String(dragWidth * (lastColumnWidth / tableWidth)), 10);
104
- const columnWidth = Math.max(lastColumnWidth + distributeWidth || 0, minColumnWidth);
105
- column.columnWidth = coerceCssPixelValue(columnWidth);
106
- });
107
- if (this.gantt.table) {
108
- this.gantt.table.columnChanges.emit({ columns: this.columnList });
109
- }
110
- this.hideAuxiliaryLine();
111
- event.source.reset();
112
- }
113
- showAuxiliaryLine(event) {
114
- const tableRect = this.elementRef.nativeElement.getBoundingClientRect();
115
- const targetRect = event.source.element.nativeElement.getBoundingClientRect();
116
- const distance = { x: targetRect.left - tableRect.left, y: targetRect.top - tableRect.top };
117
- this.draglineElementRef.nativeElement.style.left = `${distance.x}px`;
118
- this.draglineElementRef.nativeElement.style.display = 'block';
119
- }
120
- hideAuxiliaryLine() {
121
- this.draglineElementRef.nativeElement.style.display = 'none';
122
- }
123
- trackBy(index, item) {
124
- return item.id || index;
125
- }
126
- }
127
- GanttTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttTableComponent, deps: [{ token: GANTT_ABSTRACT_TOKEN }, { token: GANTT_UPPER_TOKEN }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
128
- GanttTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: GanttTableComponent, selector: "gantt-table", inputs: { groups: "groups", items: "items", columns: "columns", groupTemplate: "groupTemplate", emptyTemplate: "emptyTemplate", rowBeforeTemplate: "rowBeforeTemplate", rowAfterTemplate: "rowAfterTemplate" }, outputs: { itemClick: "itemClick" }, host: { properties: { "class.gantt-table": "this.ganttTableClass", "class.gantt-table-empty": "this.ganttTableEmptyClass" } }, viewQueries: [{ propertyName: "draglineElementRef", first: true, predicate: ["dragLine"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"gantt-table-header gantt-table-row\">\n <div class=\"gantt-table-column\" *ngFor=\"let column of columnList; 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=\"gantt-table-drag-trigger\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"dragMoved($event, column)\"\n (cdkDragStarted)=\"dragStarted($event)\"\n (cdkDragEnded)=\"columnDragEnded($event, column)\"\n ></div>\n </div>\n</div>\n<div class=\"gantt-table-body\">\n <ng-container *ngIf=\"!groups.length && !items.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=\"groups && groups.length > 0; else itemsTemplate\">\n <ng-container *ngFor=\"let group of groups; trackBy: trackBy\">\n <div class=\"gantt-table-group\" [ngClass]=\"group.class\">\n <div class=\"gantt-table-group-title\" [class.expanded]=\"group.expanded\" (click)=\"expandGroup(group)\">\n <gantt-icon class=\"expand-icon\" [iconName]=\"group.expanded ? 'angle-down' : 'angle-right'\"></gantt-icon>\n <ng-container *ngIf=\"groupTemplate; else default\">\n <ng-template\n [ngTemplateOutlet]=\"groupTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: group.origin, group: group.origin }\"\n ></ng-template>\n </ng-container>\n <ng-template #default>\n <span class=\"group-title\">{{ group.title }}</span>\n </ng-template>\n </div>\n </div>\n\n <ng-container *ngIf=\"group.expanded\">\n <ng-template\n [ngTemplateOutlet]=\"ganttItems\"\n [ngTemplateOutletContext]=\"{ group: group, items: group.items, level: 0 }\"\n ></ng-template>\n </ng-container>\n </ng-container>\n </ng-container>\n</div>\n\n<div\n class=\"gantt-table-drag-trigger\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n cdkDragBoundary=\".gantt\"\n (cdkDragMoved)=\"dragMoved($event)\"\n (cdkDragStarted)=\"dragStarted($event)\"\n (cdkDragEnded)=\"tableDragEnded($event)\"\n></div>\n\n<div #dragLine class=\"gantt-table-drag-auxiliary-line\"></div>\n\n<ng-template #itemsTemplate>\n <ng-template [ngTemplateOutlet]=\"ganttItems\" [ngTemplateOutletContext]=\"{ items: items, level: 0 }\"></ng-template>\n</ng-template>\n\n<ng-template #ganttItems let-group=\"group\" let-items=\"items\" let-level=\"level\">\n <ng-container *ngFor=\"let item of items; trackBy: trackBy\">\n <div\n (click)=\"itemClick.emit({ event: $event, selectedValue: this.item.origin })\"\n class=\"gantt-table-item gantt-table-row\"\n [class.gantt-table-item-first-level-group]=\"level === 0 && (item.type | isGanttRangeItem)\"\n [class.gantt-table-item-with-group]=\"group\"\n [class.gantt-table-item-active]=\"ganttUpper.isSelected(item.id)\"\n [style.height.px]=\"gantt.styles.lineHeight\"\n [style.lineHeight.px]=\"gantt.styles.lineHeight\"\n >\n <ng-template\n [ngTemplateOutlet]=\"rowBeforeTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n ></ng-template>\n <div class=\"gantt-table-column\" *ngFor=\"let column of columnList; let first = first\" [style.width]=\"column.columnWidth\">\n <div *ngIf=\"first\" class=\"gantt-expand-icon\" [style.marginLeft.px]=\"level * 20\">\n <ng-container *ngIf=\"level < gantt.maxLevel - 1 && item.expandable\">\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 ></gantt-icon>\n <gantt-icon *ngIf=\"item.loading\" [iconName]=\"'loading'\"></gantt-icon>\n </ng-container>\n </div>\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-template\n *ngIf=\"item.children && item.expanded\"\n [ngTemplateOutlet]=\"ganttItems\"\n [ngTemplateOutletContext]=\"{ items: item.children, level: level + 1, group: group }\"\n ></ng-template>\n </ng-container>\n</ng-template>\n", components: [{ type: i1.GanttIconComponent, selector: "gantt-icon", inputs: ["iconName"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragDisabled", "cdkDragStartDelay", "cdkDragLockAxis", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragBoundary", "cdkDragRootElement", "cdkDragData", "cdkDragFreeDragPosition"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "isGanttRangeItem": i4.IsGanttRangeItemPipe } });
129
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttTableComponent, decorators: [{
130
- type: Component,
131
- args: [{
132
- selector: 'gantt-table',
133
- templateUrl: './gantt-table.component.html'
134
- }]
135
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
136
- type: Inject,
137
- args: [GANTT_ABSTRACT_TOKEN]
138
- }] }, { type: i5.GanttUpper, decorators: [{
139
- type: Inject,
140
- args: [GANTT_UPPER_TOKEN]
141
- }] }, { type: i0.ElementRef }]; }, propDecorators: { groups: [{
142
- type: Input
143
- }], items: [{
144
- type: Input
145
- }], columns: [{
146
- type: Input
147
- }], groupTemplate: [{
148
- type: Input
149
- }], emptyTemplate: [{
150
- type: Input
151
- }], rowBeforeTemplate: [{
152
- type: Input
153
- }], rowAfterTemplate: [{
154
- type: Input
155
- }], itemClick: [{
156
- type: Output
157
- }], draglineElementRef: [{
158
- type: ViewChild,
159
- args: ['dragLine', { static: true }]
160
- }], ganttTableClass: [{
161
- type: HostBinding,
162
- args: ['class.gantt-table']
163
- }], ganttTableEmptyClass: [{
164
- type: HostBinding,
165
- args: ['class.gantt-table-empty']
166
- }] } });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gantt-table.component.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/table/gantt-table.component.ts","../../../../../packages/gantt/src/components/table/gantt-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    TemplateRef,\n    QueryList,\n    Input,\n    ViewChild,\n    ElementRef,\n    OnChanges,\n    SimpleChanges,\n    Inject,\n    Output,\n    EventEmitter\n} from '@angular/core';\nimport { GanttItemInternal, GanttGroupInternal, GanttSelectedEvent } from '../../class';\nimport { NgxGanttTableColumnComponent } from '../../table/gantt-column.component';\n// import { defaultColumnWidth, minColumnWidth } from '../../gantt.component';\nimport { CdkDragEnd, CdkDragMove, CdkDragStart } from '@angular/cdk/drag-drop';\nimport { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { GanttAbstractComponent, GANTT_ABSTRACT_TOKEN } from '../../gantt-abstract';\nimport { GanttUpper, GANTT_UPPER_TOKEN } from '../../gantt-upper';\nimport { setStyleWithVendorPrefix } from '../../utils/set-style-with-vendor-prefix';\n\nexport const defaultColumnWidth = 100;\nexport const minColumnWidth = 80;\n\ninterface DragFixedConfig {\n    target: HTMLElement;\n    originWidth: number;\n    movedWidth: number;\n    minWidth: number;\n}\n@Component({\n    selector: 'gantt-table',\n    templateUrl: './gantt-table.component.html'\n})\nexport class GanttTableComponent implements OnChanges {\n    public columnList: QueryList<NgxGanttTableColumnComponent>;\n\n    public dragStartLeft: number;\n\n    @Input() groups: GanttGroupInternal[];\n\n    @Input() items: GanttItemInternal[];\n\n    @Input()\n    set columns(columns: QueryList<NgxGanttTableColumnComponent>) {\n        columns.forEach((column) => {\n            if (!column.columnWidth) {\n                column.columnWidth = coerceCssPixelValue(defaultColumnWidth);\n            }\n        });\n        this.columnList = columns;\n    }\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    @Output() itemClick = new EventEmitter<GanttSelectedEvent>();\n\n    @ViewChild('dragLine', { static: true }) draglineElementRef: ElementRef<HTMLElement>;\n\n    @HostBinding('class.gantt-table') ganttTableClass = true;\n\n    @HostBinding('class.gantt-table-empty') ganttTableEmptyClass = false;\n\n    constructor(\n        @Inject(GANTT_ABSTRACT_TOKEN) public gantt: GanttAbstractComponent,\n        @Inject(GANTT_UPPER_TOKEN) public ganttUpper: GanttUpper,\n        private elementRef: ElementRef\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (!changes.groups.currentValue?.length && !changes.items.currentValue?.length) {\n            this.ganttTableEmptyClass = true;\n        } else {\n            this.ganttTableEmptyClass = false;\n        }\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    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    dragStarted(event: CdkDragStart) {\n        const target = event.source.element.nativeElement;\n        this.dragStartLeft = target.getBoundingClientRect().left;\n    }\n\n    dragMoved(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.columnList.length;\n        }\n\n        this.dragFixed({\n            target,\n            originWidth,\n            movedWidth,\n            minWidth\n        });\n\n        this.showAuxiliaryLine(event);\n    }\n\n    columnDragEnded(event: CdkDragEnd, column: NgxGanttTableColumnComponent) {\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.columnList });\n        }\n\n        this.hideAuxiliaryLine();\n        event.source.reset();\n    }\n\n    tableDragEnded(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        this.columnList.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        });\n\n        if (this.gantt.table) {\n            this.gantt.table.columnChanges.emit({ columns: this.columnList });\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.draglineElementRef.nativeElement.style.left = `${distance.x}px`;\n        this.draglineElementRef.nativeElement.style.display = 'block';\n    }\n\n    private hideAuxiliaryLine() {\n        this.draglineElementRef.nativeElement.style.display = 'none';\n    }\n\n    trackBy(index: number, item: GanttGroupInternal | GanttItemInternal) {\n        return item.id || index;\n    }\n}\n","<div class=\"gantt-table-header gantt-table-row\">\n  <div class=\"gantt-table-column\" *ngFor=\"let column of columnList; 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=\"gantt-table-drag-trigger\"\n      cdkDrag\n      cdkDragLockAxis=\"x\"\n      cdkDragBoundary=\".gantt\"\n      (cdkDragMoved)=\"dragMoved($event, column)\"\n      (cdkDragStarted)=\"dragStarted($event)\"\n      (cdkDragEnded)=\"columnDragEnded($event, column)\"\n    ></div>\n  </div>\n</div>\n<div class=\"gantt-table-body\">\n  <ng-container *ngIf=\"!groups.length && !items.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=\"groups && groups.length > 0; else itemsTemplate\">\n    <ng-container *ngFor=\"let group of groups; trackBy: trackBy\">\n      <div class=\"gantt-table-group\" [ngClass]=\"group.class\">\n        <div class=\"gantt-table-group-title\" [class.expanded]=\"group.expanded\" (click)=\"expandGroup(group)\">\n          <gantt-icon class=\"expand-icon\" [iconName]=\"group.expanded ? 'angle-down' : 'angle-right'\"></gantt-icon>\n          <ng-container *ngIf=\"groupTemplate; else default\">\n            <ng-template\n              [ngTemplateOutlet]=\"groupTemplate\"\n              [ngTemplateOutletContext]=\"{ $implicit: group.origin, group: group.origin }\"\n            ></ng-template>\n          </ng-container>\n          <ng-template #default>\n            <span class=\"group-title\">{{ group.title }}</span>\n          </ng-template>\n        </div>\n      </div>\n\n      <ng-container *ngIf=\"group.expanded\">\n        <ng-template\n          [ngTemplateOutlet]=\"ganttItems\"\n          [ngTemplateOutletContext]=\"{ group: group, items: group.items, level: 0 }\"\n        ></ng-template>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n</div>\n\n<div\n  class=\"gantt-table-drag-trigger\"\n  cdkDrag\n  cdkDragLockAxis=\"x\"\n  cdkDragBoundary=\".gantt\"\n  (cdkDragMoved)=\"dragMoved($event)\"\n  (cdkDragStarted)=\"dragStarted($event)\"\n  (cdkDragEnded)=\"tableDragEnded($event)\"\n></div>\n\n<div #dragLine class=\"gantt-table-drag-auxiliary-line\"></div>\n\n<ng-template #itemsTemplate>\n  <ng-template [ngTemplateOutlet]=\"ganttItems\" [ngTemplateOutletContext]=\"{ items: items, level: 0 }\"></ng-template>\n</ng-template>\n\n<ng-template #ganttItems let-group=\"group\" let-items=\"items\" let-level=\"level\">\n  <ng-container *ngFor=\"let item of items; trackBy: trackBy\">\n    <div\n      (click)=\"itemClick.emit({ event: $event, selectedValue: this.item.origin })\"\n      class=\"gantt-table-item gantt-table-row\"\n      [class.gantt-table-item-first-level-group]=\"level === 0 && (item.type | isGanttRangeItem)\"\n      [class.gantt-table-item-with-group]=\"group\"\n      [class.gantt-table-item-active]=\"ganttUpper.isSelected(item.id)\"\n      [style.height.px]=\"gantt.styles.lineHeight\"\n      [style.lineHeight.px]=\"gantt.styles.lineHeight\"\n    >\n      <ng-template\n        [ngTemplateOutlet]=\"rowBeforeTemplate\"\n        [ngTemplateOutletContext]=\"{ $implicit: item.origin, item: item.origin }\"\n      ></ng-template>\n      <div class=\"gantt-table-column\" *ngFor=\"let column of columnList; let first = first\" [style.width]=\"column.columnWidth\">\n        <div *ngIf=\"first\" class=\"gantt-expand-icon\" [style.marginLeft.px]=\"level * 20\">\n          <ng-container *ngIf=\"level < gantt.maxLevel - 1 && item.expandable\">\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            ></gantt-icon>\n            <gantt-icon *ngIf=\"item.loading\" [iconName]=\"'loading'\"></gantt-icon>\n          </ng-container>\n        </div>\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-template\n      *ngIf=\"item.children && item.expanded\"\n      [ngTemplateOutlet]=\"ganttItems\"\n      [ngTemplateOutletContext]=\"{ items: item.children, level: level + 1, group: group }\"\n    ></ng-template>\n  </ng-container>\n</ng-template>\n"]}
@@ -1,77 +0,0 @@
1
- import { Injectable, EventEmitter, Inject } from '@angular/core';
2
- import { GanttLinkType } from './class';
3
- import { GANTT_UPPER_TOKEN } from './gantt-upper';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "./gantt-upper";
6
- function getDependencyType(path, dependencyTypes) {
7
- if (dependencyTypes.includes(GanttLinkType.ss) && path.from.pos === InBarPosition.start && path.to.pos === InBarPosition.start) {
8
- return GanttLinkType.ss;
9
- }
10
- if (dependencyTypes.includes(GanttLinkType.ff) && path.from.pos === InBarPosition.finish && path.to.pos === InBarPosition.finish) {
11
- return GanttLinkType.ff;
12
- }
13
- if (dependencyTypes.includes(GanttLinkType.sf) && path.from.pos === InBarPosition.start && path.to.pos === InBarPosition.finish) {
14
- return GanttLinkType.sf;
15
- }
16
- return GanttLinkType.fs;
17
- }
18
- export var InBarPosition;
19
- (function (InBarPosition) {
20
- InBarPosition["start"] = "start";
21
- InBarPosition["finish"] = "finish";
22
- })(InBarPosition || (InBarPosition = {}));
23
- export class GanttDragContainer {
24
- constructor(ganttUpper) {
25
- this.ganttUpper = ganttUpper;
26
- this.dragStarted = new EventEmitter();
27
- this.dragMoved = new EventEmitter();
28
- this.dragEnded = new EventEmitter();
29
- this.linkDragStarted = new EventEmitter();
30
- this.linkDragEntered = new EventEmitter();
31
- this.linkDragEnded = new EventEmitter();
32
- this.linkDragPath = { from: null, to: null };
33
- }
34
- emitLinkDragStarted(from) {
35
- this.linkDraggingId = from.item.id;
36
- this.linkDragPath.from = from;
37
- this.linkDragStarted.emit({
38
- source: from.item.origin,
39
- target: null
40
- });
41
- }
42
- emitLinkDragEntered(to) {
43
- this.linkDragPath.to = to;
44
- this.linkDragEntered.emit({
45
- source: this.linkDragPath.from.item.origin,
46
- target: to.item.origin
47
- });
48
- }
49
- emitLinkDragLeaved() {
50
- this.linkDragPath.to = null;
51
- }
52
- emitLinkDragEnded(to) {
53
- var _a;
54
- this.linkDragPath.to = to;
55
- const dependencyType = getDependencyType(this.linkDragPath, (_a = this.ganttUpper.linkOptions) === null || _a === void 0 ? void 0 : _a.dependencyTypes);
56
- this.linkDragPath.from.item.addLink({
57
- link: this.linkDragPath.to.item.id,
58
- type: dependencyType
59
- });
60
- this.linkDragEnded.emit({
61
- source: this.linkDragPath.from.item.origin,
62
- target: this.linkDragPath.to.item.origin,
63
- type: dependencyType
64
- });
65
- this.linkDraggingId = null;
66
- this.linkDragPath = { from: null, to: null };
67
- }
68
- }
69
- GanttDragContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttDragContainer, deps: [{ token: GANTT_UPPER_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable });
70
- GanttDragContainer.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttDragContainer });
71
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: GanttDragContainer, decorators: [{
72
- type: Injectable
73
- }], ctorParameters: function () { return [{ type: i1.GanttUpper, decorators: [{
74
- type: Inject,
75
- args: [GANTT_UPPER_TOKEN]
76
- }] }]; } });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FudHQtZHJhZy1jb250YWluZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9nYW50dC9zcmMvZ2FudHQtZHJhZy1jb250YWluZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFHeEMsT0FBTyxFQUFjLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFFOUQsU0FBUyxpQkFBaUIsQ0FBQyxJQUFrQixFQUFFLGVBQWdDO0lBQzNFLElBQUksZUFBZSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssYUFBYSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxhQUFhLENBQUMsS0FBSyxFQUFFO1FBQzVILE9BQU8sYUFBYSxDQUFDLEVBQUUsQ0FBQztLQUMzQjtJQUNELElBQUksZUFBZSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssYUFBYSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxhQUFhLENBQUMsTUFBTSxFQUFFO1FBQzlILE9BQU8sYUFBYSxDQUFDLEVBQUUsQ0FBQztLQUMzQjtJQUNELElBQUksZUFBZSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssYUFBYSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxhQUFhLENBQUMsTUFBTSxFQUFFO1FBQzdILE9BQU8sYUFBYSxDQUFDLEVB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QVU7OzBCQWtCTSxNQUFNOzJCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEV2ZW50RW1pdHRlciwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHYW50dExpbmtUeXBlIH0gZnJvbSAnLi9jbGFzcyc7XG5pbXBvcnQgeyBHYW50dERyYWdFdmVudCwgR2FudHRMaW5rRHJhZ0V2ZW50IH0gZnJvbSAnLi9jbGFzcy9ldmVudCc7XG5pbXBvcnQgeyBHYW50dEl0ZW1JbnRlcm5hbCB9IGZyb20gJy4vY2xhc3MvaXRlbSc7XG5pbXBvcnQgeyBHYW50dFVwcGVyLCBHQU5UVF9VUFBFUl9UT0tFTiB9IGZyb20gJy4vZ2FudHQtdXBwZXInO1xuXG5mdW5jdGlvbiBnZXREZXBlbmRlbmN5VHlwZShwYXRoOiBMaW5rRHJhZ1BhdGgsIGRlcGVuZGVuY3lUeXBlczogR2FudHRMaW5rVHlwZVtdKTogR2FudHRMaW5rVHlwZSB7XG4gICAgaWYgKGRlcGVuZGVuY3lUeXBlcy5pbmNsdWRlcyhHYW50dExpbmtUeXBlLnNzKSAmJiBwYXRoLmZyb20ucG9zID09PSBJbkJhclBvc2l0aW9uLnN0YXJ0ICYmIHBhdGgudG8ucG9zID09PSBJbkJhclBvc2l0aW9uLnN0YXJ0KSB7XG4gICAgICAgIHJldHVybiBHYW50dExpbmtUeXBlLnNzO1xuICAgIH1cbiAgICBpZiAoZGVwZW5kZW5jeVR5cGVzLmluY2x1ZGVzKEdhbnR0TGlua1R5cGUuZmYpICYmIHBhdGguZnJvbS5wb3MgPT09IEluQmFyUG9zaXRpb24uZmluaXNoICYmIHBhdGgudG8ucG9zID09PSBJbkJhclBvc2l0aW9uLmZpbmlzaCkge1xuICAgICAgICByZXR1cm4gR2FudHRMaW5rVHlwZS5mZjtcbiAgICB9XG4gICAgaWYgKGRlcGVuZGVuY3lUeXBlcy5pbmNsdWRlcyhHYW50dExpbmtUeXBlLnNmKSAmJiBwYXRoLmZyb20ucG9zID09PSBJbkJhclBvc2l0aW9uLnN0YXJ0ICYmIHBhdGgudG8ucG9zID09PSBJbkJhclBvc2l0aW9uLmZpbmlzaCkge1xuICAgICAgICByZXR1cm4gR2FudHRMaW5rVHlwZS5zZjtcbiAgICB9XG4gICAgcmV0dXJuIEdhbnR0TGlua1R5cGUuZnM7XG59XG5cbmV4cG9ydCBlbnVtIEluQmFyUG9zaXRpb24ge1xuICAgIHN0YXJ0ID0gJ3N0YXJ0JyxcbiAgICBmaW5pc2ggPSAnZmluaXNoJ1xufVxuXG5leHBvcnQgdHlwZSBMaW5rRHJhZ1Bvc2l0aW9uID0ge1xuICAgIGVsZW1lbnQ6IEhUTUxFbGVtZW50O1xuICAgIGl0ZW06IEdhbnR0SXRlbUludGVybmFsO1xuICAgIHBvcz86IEluQmFyUG9zaXRpb247XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIExpbmtEcmFnUGF0aCB7XG4gICAgZnJvbT86IExpbmtEcmFnUG9zaXRpb247XG4gICAgdG8/OiBMaW5rRHJhZ1Bvc2l0aW9uO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgR2FudHREcmFnQ29udGFpbmVyIHtcbiAgICBkcmFnU3RhcnRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8R2FudHREcmFnRXZlbnQ+KCk7XG5cbiAgICBkcmFnTW92ZWQgPSBuZXcgRXZlbnRFbWl0dGVyPEdhbnR0RHJhZ0V2ZW50PigpO1xuXG4gICAgZHJhZ0VuZGVkID0gbmV3IEV2ZW50RW1pdHRlcjxHYW50dERyYWdFdmVudD4oKTtcblxuICAgIGxpbmtEcmFnU3RhcnRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8R2FudHRMaW5rRHJhZ0V2ZW50PigpO1xuXG4gICAgbGlua0RyYWdFbnRlcmVkID0gbmV3IEV2ZW50RW1pdHRlcjxHYW50dExpbmtEcmFnRXZlbnQ+KCk7XG5cbiAgICBsaW5rRHJhZ0VuZGVkID0gbmV3IEV2ZW50RW1pdHRlcjxHYW50dExpbmtEcmFnRXZlbnQ+KCk7XG5cbiAgICBsaW5rRHJhZ2dpbmdJZDogc3RyaW5nO1xuXG4gICAgbGlua0RyYWdQYXRoOiBMaW5rRHJhZ1BhdGggPSB7IGZyb206IG51bGwsIHRvOiBudWxsIH07XG5cbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KEdBTlRUX1VQUEVSX1RPS0VOKSBwdWJsaWMgZ2FudHRVcHBlcjogR2FudHRVcHBlcikge31cblxuICAgIGVtaXRMaW5rRHJhZ1N0YXJ0ZWQoZnJvbTogTGlua0RyYWdQb3NpdGlvbikge1xuICAgICAgICB0aGlzLmxpbmtEcmFnZ2luZ0lkID0gZnJvbS5pdGVtLmlkO1xuICAgICAgICB0aGlzLmxpbmtEcmFnUGF0aC5mcm9tID0gZnJvbTtcbiAgICAgICAgdGhpcy5saW5rRHJhZ1N0YXJ0ZWQuZW1pdCh7XG4gICAgICAgICAgICBzb3VyY2U6IGZyb20uaXRlbS5vcmlnaW4sXG4gICAgICAgICAgICB0YXJnZXQ6IG51bGxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgZW1pdExpbmtEcmFnRW50ZXJlZCh0bzogTGlua0RyYWdQb3NpdGlvbikge1xuICAgICAgICB0aGlzLmxpbmtEcmFnUGF0aC50byA9IHRvO1xuICAgICAgICB0aGlzLmxpbmtEcmFnRW50ZXJlZC5lbWl0KHtcbiAgICAgICAgICAgIHNvdXJjZTogdGhpcy5saW5rRHJhZ1BhdGguZnJvbS5pdGVtLm9yaWdpbixcbiAgICAgICAgICAgIHRhcmdldDogdG8uaXRlbS5vcmlnaW5cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgZW1pdExpbmtEcmFnTGVhdmVkKCkge1xuICAgICAgICB0aGlzLmxpbmtEcmFnUGF0aC50byA9IG51bGw7XG4gICAgfVxuXG4gICAgZW1pdExpbmtEcmFnRW5kZWQodG86IExpbmtEcmFnUG9zaXRpb24pIHtcbiAgICAgICAgdGhpcy5saW5rRHJhZ1BhdGgudG8gPSB0bztcbiAgICAgICAgY29uc3QgZGVwZW5kZW5jeVR5cGUgPSBnZXREZXBlbmRlbmN5VHlwZSh0aGlzLmxpbmtEcmFnUGF0aCwgdGhpcy5nYW50dFVwcGVyLmxpbmtPcHRpb25zPy5kZXBlbmRlbmN5VHlwZXMpO1xuICAgICAgICB0aGlzLmxpbmtEcmFnUGF0aC5mcm9tLml0ZW0uYWRkTGluayh7XG4gICAgICAgICAgICBsaW5rOiB0aGlzLmxpbmtEcmFnUGF0aC50by5pdGVtLmlkLFxuICAgICAgICAgICAgdHlwZTogZGVwZW5kZW5jeVR5cGVcbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMubGlua0RyYWdFbmRlZC5lbWl0KHtcbiAgICAgICAgICAgIHNvdXJjZTogdGhpcy5saW5rRHJhZ1BhdGguZnJvbS5pdGVtLm9yaWdpbixcbiAgICAgICAgICAgIHRhcmdldDogdGhpcy5saW5rRHJhZ1BhdGgudG8uaXRlbS5vcmlnaW4sXG4gICAgICAgICAgICB0eXBlOiBkZXBlbmRlbmN5VHlwZVxuICAgICAgICB9KTtcbiAgICAgICAgdGhpcy5saW5rRHJhZ2dpbmdJZCA9IG51bGw7XG4gICAgICAgIHRoaXMubGlua0RyYWdQYXRoID0geyBmcm9tOiBudWxsLCB0bzogbnVsbCB9O1xuICAgIH1cbn1cbiJdfQ==