@worktile/gantt 12.1.2 → 12.2.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.
- package/bundles/worktile-gantt.umd.js +65 -13
- package/bundles/worktile-gantt.umd.js.map +1 -1
- package/class/item.d.ts +3 -2
- package/class/link.d.ts +39 -0
- package/components/links/links.component.d.ts +2 -13
- package/esm2015/class/item.js +14 -3
- package/esm2015/class/link.js +14 -0
- package/esm2015/components/links/links.component.js +53 -16
- package/fesm2015/worktile-gantt.js +77 -17
- package/fesm2015/worktile-gantt.js.map +1 -1
- package/package.json +1 -1
package/class/item.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { GanttDate } from '../utils/date';
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import { GanttViewType } from './view-type';
|
|
4
|
+
import { GanttLink } from './link';
|
|
4
5
|
interface GanttItemRefs {
|
|
5
6
|
width: number;
|
|
6
7
|
x: number;
|
|
@@ -17,7 +18,7 @@ export interface GanttItem<T = unknown> {
|
|
|
17
18
|
start?: number;
|
|
18
19
|
end?: number;
|
|
19
20
|
group_id?: string;
|
|
20
|
-
links?: string[];
|
|
21
|
+
links?: (GanttLink | string)[];
|
|
21
22
|
draggable?: boolean;
|
|
22
23
|
linkable?: boolean;
|
|
23
24
|
expandable?: boolean;
|
|
@@ -34,7 +35,7 @@ export declare class GanttItemInternal {
|
|
|
34
35
|
title: string;
|
|
35
36
|
start: GanttDate;
|
|
36
37
|
end: GanttDate;
|
|
37
|
-
links:
|
|
38
|
+
links: GanttLink[];
|
|
38
39
|
color?: string;
|
|
39
40
|
barStyle?: Partial<CSSStyleDeclaration>;
|
|
40
41
|
draggable?: boolean;
|
package/class/link.d.ts
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { GanttDate } from '../utils/date';
|
|
2
|
+
import { GanttItem } from './item';
|
|
3
|
+
export declare enum GanttLinkType {
|
|
4
|
+
fs = 0,
|
|
5
|
+
ss = 1,
|
|
6
|
+
ff = 2,
|
|
7
|
+
sf = 3
|
|
8
|
+
}
|
|
9
|
+
export declare enum LinkColors {
|
|
10
|
+
default = "#cacaca",
|
|
11
|
+
blocked = "#FF7575",
|
|
12
|
+
active = "#348FE4"
|
|
13
|
+
}
|
|
14
|
+
export interface GanttLink {
|
|
15
|
+
type: GanttLinkType;
|
|
16
|
+
link: string;
|
|
17
|
+
}
|
|
18
|
+
export interface GanttLinkItem {
|
|
19
|
+
id: string;
|
|
20
|
+
before: {
|
|
21
|
+
x: number;
|
|
22
|
+
y: number;
|
|
23
|
+
};
|
|
24
|
+
after: {
|
|
25
|
+
x: number;
|
|
26
|
+
y: number;
|
|
27
|
+
};
|
|
28
|
+
start: GanttDate;
|
|
29
|
+
end: GanttDate;
|
|
30
|
+
origin: GanttItem;
|
|
31
|
+
links: GanttLink[];
|
|
32
|
+
}
|
|
33
|
+
export interface LinkInternal {
|
|
34
|
+
path: string;
|
|
35
|
+
source: GanttItem;
|
|
36
|
+
target: GanttItem;
|
|
37
|
+
color: LinkColors;
|
|
38
|
+
type: GanttLinkType;
|
|
39
|
+
}
|
|
@@ -1,21 +1,11 @@
|
|
|
1
1
|
import { OnInit, EventEmitter, ChangeDetectorRef, ElementRef, OnDestroy, OnChanges } from '@angular/core';
|
|
2
2
|
import { GanttGroupInternal } from '../../class/group';
|
|
3
|
-
import { GanttItemInternal
|
|
3
|
+
import { GanttItemInternal } from './../../class/item';
|
|
4
4
|
import { GanttLineClickEvent } from '../../class/event';
|
|
5
5
|
import { GanttDragContainer } from '../../gantt-drag-container';
|
|
6
6
|
import { GanttUpper } from '../../gantt-upper';
|
|
7
|
+
import { LinkInternal } from '../../class/link';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
|
-
declare enum LinkColors {
|
|
9
|
-
default = "#cacaca",
|
|
10
|
-
blocked = "#FF7575",
|
|
11
|
-
active = "#348FE4"
|
|
12
|
-
}
|
|
13
|
-
interface LinkInternal {
|
|
14
|
-
path: string;
|
|
15
|
-
source: GanttItem;
|
|
16
|
-
target: GanttItem;
|
|
17
|
-
color: LinkColors;
|
|
18
|
-
}
|
|
19
9
|
export declare class GanttLinksComponent implements OnInit, OnChanges, OnDestroy {
|
|
20
10
|
ganttUpper: GanttUpper;
|
|
21
11
|
private cdr;
|
|
@@ -44,4 +34,3 @@ export declare class GanttLinksComponent implements OnInit, OnChanges, OnDestroy
|
|
|
44
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<GanttLinksComponent, never>;
|
|
45
35
|
static ɵcmp: i0.ɵɵComponentDeclaration<GanttLinksComponent, "gantt-links-overlay", never, { "groups": "groups"; "items": "items"; }, { "lineClick": "lineClick"; }, never, never>;
|
|
46
36
|
}
|
|
47
|
-
export {};
|
package/esm2015/class/item.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { GanttDate } from '../utils/date';
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import { GanttViewType } from './view-type';
|
|
4
|
+
import { GanttLinkType } from './link';
|
|
4
5
|
export var GanttItemType;
|
|
5
6
|
(function (GanttItemType) {
|
|
6
7
|
GanttItemType["bar"] = "bar";
|
|
@@ -12,7 +13,17 @@ export class GanttItemInternal {
|
|
|
12
13
|
this.refs$ = new BehaviorSubject(null);
|
|
13
14
|
this.origin = item;
|
|
14
15
|
this.id = this.origin.id;
|
|
15
|
-
this.links = this.origin.links || []
|
|
16
|
+
this.links = (this.origin.links || []).map((link) => {
|
|
17
|
+
if (typeof link === 'string') {
|
|
18
|
+
return {
|
|
19
|
+
type: GanttLinkType.fs,
|
|
20
|
+
link
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
return link;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
16
27
|
this.color = this.origin.color;
|
|
17
28
|
this.barStyle = this.origin.barStyle;
|
|
18
29
|
this.linkable = this.origin.linkable === undefined ? true : this.origin.linkable;
|
|
@@ -71,8 +82,8 @@ export class GanttItemInternal {
|
|
|
71
82
|
this.origin.expanded = expanded;
|
|
72
83
|
}
|
|
73
84
|
addLink(linkId) {
|
|
74
|
-
this.links = [...this.links, linkId];
|
|
85
|
+
this.links = [...this.links, { type: GanttLinkType.fs, link: linkId }];
|
|
75
86
|
this.origin.links = this.links;
|
|
76
87
|
}
|
|
77
88
|
}
|
|
78
|
-
//# 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 { GanttViewType } from './view-type';\n\ninterface 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?: 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: string[];\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    viewType?: GanttViewType;\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?: { viewType: GanttViewType }) {\n        this.origin = item;\n        this.id = this.origin.id;\n        this.links = this.origin.links || [];\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        this.viewType = options && options.viewType ? options.viewType : GanttViewType.month;\n        this.children = (item.children || []).map((subItem) => {\n            return new GanttItemInternal(subItem, { viewType: this.viewType });\n        });\n        this.type = this.origin.type || GanttItemType.bar;\n        this.progress = this.origin.progress;\n        // fill one month when start or end is null\n        this.fillItemStartOrEnd(item);\n    }\n\n    fillItemStartOrEnd(item: GanttItem) {\n        let addInterval: number;\n        switch (this.viewType) {\n            case GanttViewType.day:\n            case GanttViewType.week:\n                addInterval = 0;\n                break;\n            default:\n                addInterval = 30;\n                break;\n        }\n        if (item.start && !item.end) {\n            this.end = new GanttDate(item.start).addDays(addInterval).endOfDay();\n        }\n        if (!item.start && item.end) {\n            this.start = new GanttDate(item.end).addDays(-addInterval).startOfDay();\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, { viewType: this.viewType });\n        });\n    }\n\n    setExpand(expanded: boolean) {\n        this.expanded = expanded;\n        this.origin.expanded = expanded;\n    }\n\n    addLink(linkId: string) {\n        this.links = [...this.links, linkId];\n        this.origin.links = this.links;\n    }\n}\n"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item.js","sourceRoot":"","sources":["../../../../packages/gantt/src/class/item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAa,aAAa,EAAE,MAAM,QAAQ,CAAC;AAQlD,MAAM,CAAN,IAAY,aAIX;AAJD,WAAY,aAAa;IACrB,4BAAW,CAAA;IACX,gCAAe,CAAA;IACf,kCAAiB,CAAA;AACrB,CAAC,EAJW,aAAa,KAAb,aAAa,QAIxB;AAqBD,MAAM,OAAO,iBAAiB;IAyB1B,YAAY,IAAe,EAAE,OAAqC;QAFlE,UAAK,GAAG,IAAI,eAAe,CAA0C,IAAI,CAAC,CAAC;QAGvE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChD,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;gBAC1B,OAAO;oBACH,IAAI,EAAE,aAAa,CAAC,EAAE;oBACtB,IAAI;iBACP,CAAC;aACL;iBAAM;gBACH,OAAO,IAAI,CAAC;aACf;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QACrC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QACjF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QACpF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QACpF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QAClF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC3D,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACrD,IAAI,CAAC,QAAQ,GAAG,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC;QACrF,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YAClD,OAAO,IAAI,iBAAiB,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,aAAa,CAAC,GAAG,CAAC;QAClD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QACrC,2CAA2C;QAC3C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAnCD,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAmCD,kBAAkB,CAAC,IAAe;QAC9B,IAAI,WAAmB,CAAC;QACxB,QAAQ,IAAI,CAAC,QAAQ,EAAE;YACnB,KAAK,aAAa,CAAC,GAAG,CAAC;YACvB,KAAK,aAAa,CAAC,IAAI;gBACnB,WAAW,GAAG,CAAC,CAAC;gBAChB,MAAM;YACV;gBACI,WAAW,GAAG,EAAE,CAAC;gBACjB,MAAM;SACb;QACD,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,GAAG,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;SACxE;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,KAAK,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,CAAC;SAC3E;IACL,CAAC;IAED,UAAU,CAAC,IAAmB;QAC1B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,UAAU,CAAC,KAAgB,EAAE,GAAc;QACvC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,UAAU,EAAE,CAAC;QAChC,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAED,WAAW,CAAC,KAAkB;QAC1B,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,QAAQ,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YAC1C,OAAO,IAAI,iBAAiB,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS,CAAC,QAAiB;QACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;IACpC,CAAC;IAED,OAAO,CAAC,MAAc;QAClB,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvE,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;IACnC,CAAC;CACJ","sourcesContent":["import { GanttDate } from '../utils/date';\nimport { BehaviorSubject } from 'rxjs';\nimport { GanttViewType } from './view-type';\nimport { GanttLink, GanttLinkType } from './link';\n\ninterface 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    viewType?: GanttViewType;\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?: { viewType: GanttViewType }) {\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        this.viewType = options && options.viewType ? options.viewType : GanttViewType.month;\n        this.children = (item.children || []).map((subItem) => {\n            return new GanttItemInternal(subItem, { viewType: this.viewType });\n        });\n        this.type = this.origin.type || GanttItemType.bar;\n        this.progress = this.origin.progress;\n        // fill one month when start or end is null\n        this.fillItemStartOrEnd(item);\n    }\n\n    fillItemStartOrEnd(item: GanttItem) {\n        let addInterval: number;\n        switch (this.viewType) {\n            case GanttViewType.day:\n            case GanttViewType.week:\n                addInterval = 0;\n                break;\n            default:\n                addInterval = 30;\n                break;\n        }\n        if (item.start && !item.end) {\n            this.end = new GanttDate(item.start).addDays(addInterval).endOfDay();\n        }\n        if (!item.start && item.end) {\n            this.start = new GanttDate(item.end).addDays(-addInterval).startOfDay();\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, { viewType: this.viewType });\n        });\n    }\n\n    setExpand(expanded: boolean) {\n        this.expanded = expanded;\n        this.origin.expanded = expanded;\n    }\n\n    addLink(linkId: string) {\n        this.links = [...this.links, { type: GanttLinkType.fs, link: linkId }];\n        this.origin.links = this.links;\n    }\n}\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export var GanttLinkType;
|
|
2
|
+
(function (GanttLinkType) {
|
|
3
|
+
GanttLinkType[GanttLinkType["fs"] = 0] = "fs";
|
|
4
|
+
GanttLinkType[GanttLinkType["ss"] = 1] = "ss";
|
|
5
|
+
GanttLinkType[GanttLinkType["ff"] = 2] = "ff";
|
|
6
|
+
GanttLinkType[GanttLinkType["sf"] = 3] = "sf";
|
|
7
|
+
})(GanttLinkType || (GanttLinkType = {}));
|
|
8
|
+
export var LinkColors;
|
|
9
|
+
(function (LinkColors) {
|
|
10
|
+
LinkColors["default"] = "#cacaca";
|
|
11
|
+
LinkColors["blocked"] = "#FF7575";
|
|
12
|
+
LinkColors["active"] = "#348FE4";
|
|
13
|
+
})(LinkColors || (LinkColors = {}));
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dhbnR0L3NyYy9jbGFzcy9saW5rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sQ0FBTixJQUFZLGFBS1g7QUFMRCxXQUFZLGFBQWE7SUFDckIsNkNBQU0sQ0FBQTtJQUNOLDZDQUFNLENBQUE7SUFDTiw2Q0FBTSxDQUFBO0lBQ04sNkNBQU0sQ0FBQTtBQUNWLENBQUMsRUFMVyxhQUFhLEtBQWIsYUFBYSxRQUt4QjtBQUVELE1BQU0sQ0FBTixJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDbEIsaUNBQW1CLENBQUE7SUFDbkIsaUNBQW1CLENBQUE7SUFDbkIsZ0NBQWtCLENBQUE7QUFDdEIsQ0FBQyxFQUpXLFVBQVUsS0FBVixVQUFVLFFBSXJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2FudHREYXRlIH0gZnJvbSAnLi4vdXRpbHMvZGF0ZSc7XG5pbXBvcnQgeyBHYW50dEl0ZW0gfSBmcm9tICcuL2l0ZW0nO1xuXG5leHBvcnQgZW51bSBHYW50dExpbmtUeXBlIHtcbiAgICBmcyA9IDAsXG4gICAgc3MgPSAxLFxuICAgIGZmID0gMixcbiAgICBzZiA9IDNcbn1cblxuZXhwb3J0IGVudW0gTGlua0NvbG9ycyB7XG4gICAgZGVmYXVsdCA9ICcjY2FjYWNhJyxcbiAgICBibG9ja2VkID0gJyNGRjc1NzUnLFxuICAgIGFjdGl2ZSA9ICcjMzQ4RkU0J1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdhbnR0TGluayB7XG4gICAgdHlwZTogR2FudHRMaW5rVHlwZTtcbiAgICBsaW5rOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2FudHRMaW5rSXRlbSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBiZWZvcmU6IHsgeDogbnVtYmVyOyB5OiBudW1iZXIgfTtcbiAgICBhZnRlcjogeyB4OiBudW1iZXI7IHk6IG51bWJlciB9O1xuICAgIHN0YXJ0OiBHYW50dERhdGU7XG4gICAgZW5kOiBHYW50dERhdGU7XG4gICAgb3JpZ2luOiBHYW50dEl0ZW07XG4gICAgbGlua3M6IEdhbnR0TGlua1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExpbmtJbnRlcm5hbCB7XG4gICAgcGF0aDogc3RyaW5nO1xuICAgIHNvdXJjZTogR2FudHRJdGVtO1xuICAgIHRhcmdldDogR2FudHRJdGVtO1xuICAgIGNvbG9yOiBMaW5rQ29sb3JzO1xuICAgIHR5cGU6IEdhbnR0TGlua1R5cGU7XG59XG4iXX0=
|
|
@@ -3,16 +3,11 @@ import { merge, Subject } from 'rxjs';
|
|
|
3
3
|
import { takeUntil, skip } from 'rxjs/operators';
|
|
4
4
|
import { recursiveItems } from '../../utils/helpers';
|
|
5
5
|
import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
|
|
6
|
+
import { LinkColors, GanttLinkType } from '../../class/link';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../gantt-drag-container";
|
|
8
9
|
import * as i2 from "@angular/common";
|
|
9
10
|
import * as i3 from "../../gantt-upper";
|
|
10
|
-
var LinkColors;
|
|
11
|
-
(function (LinkColors) {
|
|
12
|
-
LinkColors["default"] = "#cacaca";
|
|
13
|
-
LinkColors["blocked"] = "#FF7575";
|
|
14
|
-
LinkColors["active"] = "#348FE4";
|
|
15
|
-
})(LinkColors || (LinkColors = {}));
|
|
16
11
|
export class GanttLinksComponent {
|
|
17
12
|
constructor(ganttUpper, cdr, elementRef, ganttDragContainer) {
|
|
18
13
|
this.ganttUpper = ganttUpper;
|
|
@@ -87,12 +82,53 @@ export class GanttLinksComponent {
|
|
|
87
82
|
});
|
|
88
83
|
}
|
|
89
84
|
}
|
|
90
|
-
generatePath(source, target) {
|
|
85
|
+
generatePath(source, target, type) {
|
|
91
86
|
if (source.before && source.after && target.before && target.after) {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
87
|
+
let x1 = source.after.x;
|
|
88
|
+
let y1 = source.after.y;
|
|
89
|
+
let x4 = target.before.x;
|
|
90
|
+
let y4 = target.before.y;
|
|
91
|
+
let isMirror;
|
|
92
|
+
const control = Math.abs(y4 - y1) / 2;
|
|
93
|
+
switch (type) {
|
|
94
|
+
case GanttLinkType.ss:
|
|
95
|
+
x1 = source.before.x;
|
|
96
|
+
y1 = source.before.y;
|
|
97
|
+
x4 = target.before.x;
|
|
98
|
+
y4 = target.before.y;
|
|
99
|
+
isMirror = y4 > y1 ? 0 : 1;
|
|
100
|
+
if (x4 > x1) {
|
|
101
|
+
return `M ${x1} ${y1}
|
|
102
|
+
A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}
|
|
103
|
+
L ${x1} ${y4} ${x4} ${y4}`;
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
return `M ${x1} ${y1}
|
|
107
|
+
L ${x1} ${y1} ${x4} ${y1}
|
|
108
|
+
A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;
|
|
109
|
+
}
|
|
110
|
+
case GanttLinkType.ff:
|
|
111
|
+
x1 = source.after.x;
|
|
112
|
+
y1 = source.after.y;
|
|
113
|
+
x4 = target.after.x;
|
|
114
|
+
y4 = target.after.y;
|
|
115
|
+
isMirror = y4 > y1 ? 1 : 0;
|
|
116
|
+
if (x4 > x1) {
|
|
117
|
+
return `M ${x1} ${y1}
|
|
118
|
+
L ${x1} ${y1} ${x4} ${y1}
|
|
119
|
+
A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
return `M ${x1} ${y1}
|
|
123
|
+
A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}
|
|
124
|
+
L ${x1} ${y4} ${x4} ${y4}`;
|
|
125
|
+
}
|
|
126
|
+
case GanttLinkType.sf:
|
|
127
|
+
x1 = target.after.x;
|
|
128
|
+
y1 = target.after.y;
|
|
129
|
+
x4 = source.before.x;
|
|
130
|
+
y4 = source.before.y;
|
|
131
|
+
}
|
|
96
132
|
const dx = Math.abs(x4 - x1) * this.bezierWeight;
|
|
97
133
|
const x2 = x1 - dx;
|
|
98
134
|
const x3 = x4 + dx;
|
|
@@ -150,13 +186,14 @@ export class GanttLinksComponent {
|
|
|
150
186
|
this.links = [];
|
|
151
187
|
this.linkItems.forEach((source) => {
|
|
152
188
|
if (source.origin.start || source.origin.end) {
|
|
153
|
-
source.links.forEach((
|
|
154
|
-
const target = this.linkItems.find((item) => item.id ===
|
|
189
|
+
source.links.forEach((link) => {
|
|
190
|
+
const target = this.linkItems.find((item) => item.id === link.link);
|
|
155
191
|
if (target && (target.origin.start || target.origin.end)) {
|
|
156
192
|
this.links.push({
|
|
157
|
-
path: this.generatePath(source, target),
|
|
193
|
+
path: this.generatePath(source, target, link.type),
|
|
158
194
|
source: source.origin,
|
|
159
195
|
target: target.origin,
|
|
196
|
+
type: link.type,
|
|
160
197
|
color: source.end.getTime() > target.start.getTime() ? LinkColors.blocked : LinkColors.default
|
|
161
198
|
});
|
|
162
199
|
}
|
|
@@ -190,7 +227,7 @@ export class GanttLinksComponent {
|
|
|
190
227
|
}
|
|
191
228
|
}
|
|
192
229
|
GanttLinksComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.2", ngImport: i0, type: GanttLinksComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.GanttDragContainer }], target: i0.ɵɵFactoryTarget.Component });
|
|
193
|
-
GanttLinksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.2", 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
|
|
230
|
+
GanttLinksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.2", 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 [style]=\"'marker-end: url(#triangle' + i + ')'\"\n ></path>\n <g>\n <path\n class=\"link-line\"\n (click)=\"onLineClick($event, link)\"\n (mouseenter)=\"mouseEnterPath(link)\"\n (mouseleave)=\"mouseLeavePath(link)\"\n [attr.d]=\"link.path\"\n stroke=\"transparent\"\n stroke-width=\"9\"\n fill=\"none\"\n cursor=\"pointer\"\n ></path>\n </g>\n <!-- <defs>\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 </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"] }] });
|
|
194
231
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.2", ngImport: i0, type: GanttLinksComponent, decorators: [{
|
|
195
232
|
type: Component,
|
|
196
233
|
args: [{
|
|
@@ -210,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.2", ngImpor
|
|
|
210
247
|
type: HostBinding,
|
|
211
248
|
args: ['class.gantt-links-overlay']
|
|
212
249
|
}] } });
|
|
213
|
-
//# 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":"AAAA,OAAO,EACH,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,EACZ,WAAW,EACX,MAAM,EAKT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAKjD,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAc,MAAM,mBAAmB,CAAC;;;;;AAElE,IAAK,UAIJ;AAJD,WAAK,UAAU;IACX,iCAAmB,CAAA;IACnB,iCAAmB,CAAA;IACnB,gCAAkB,CAAA;AACtB,CAAC,EAJI,UAAU,KAAV,UAAU,QAId;AAuBD,MAAM,OAAO,mBAAmB;IAmB5B,YACsC,UAAsB,EAChD,GAAsB,EACtB,UAAsB,EACtB,kBAAsC;QAHZ,eAAU,GAAV,UAAU,CAAY;QAChD,QAAG,GAAH,GAAG,CAAmB;QACtB,eAAU,GAAV,UAAU,CAAY;QACtB,uBAAkB,GAAlB,kBAAkB,CAAoB;QAtBzC,WAAM,GAAyB,EAAE,CAAC;QAElC,UAAK,GAAwB,EAAE,CAAC;QAE/B,cAAS,GAAG,IAAI,YAAY,EAAuB,CAAC;QAEvD,UAAK,GAAmB,EAAE,CAAC;QAE1B,cAAS,GAAoB,EAAE,CAAC;QAEhC,iBAAY,GAAG,CAAC,GAAG,CAAC;QAEpB,gBAAW,GAAG,IAAI,CAAC;QAEnB,iBAAY,GAAG,IAAI,OAAO,EAAE,CAAC;QAEK,sBAAiB,GAAG,IAAI,CAAC;IAOhE,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAClF,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,KAAK,CACD,IAAI,CAAC,UAAU,CAAC,UAAU,EAC1B,IAAI,CAAC,UAAU,CAAC,YAAY,EAC5B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAC3B,IAAI,CAAC,UAAU,CAAC,SAAS,EACzB,IAAI,CAAC,UAAU,CAAC,aAAa,CAChC;aACI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;aAC3C,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;YAC3D,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;IACL,CAAC;IAEO,mBAAmB;QACvB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC;QACrD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC;QACnD,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,IAAI,OAAO,GAAG,CAAC,CAAC;YAChB,IAAI,QAAQ,GAAG,CAAC,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC1B,QAAQ,EAAE,CAAC;gBACX,IAAI,KAAK,CAAC,QAAQ,EAAE;oBAChB,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAC1C,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE;wBAC9B,MAAM,CAAC,GAAG,CAAC,QAAQ,GAAG,OAAO,GAAG,SAAS,CAAC,GAAG,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC;wBACtF,IAAI,CAAC,SAAS,CAAC,IAAI,iCACZ,IAAI,KACP,MAAM,EAAE;gCACJ,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gCACd,CAAC;6BACJ,EACD,KAAK,EAAE;gCACH,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK;gCAChC,CAAC;6BACJ,IACH,CAAC;oBACP,CAAC,CAAC,CAAC;oBACH,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC;iBAC3B;YACL,CAAC,CAAC,CAAC;SACN;aAAM;YACH,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE;gBAC9B,MAAM,CAAC,GAAG,SAAS,GAAG,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC;gBAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,iCACZ,IAAI,KACP,MAAM,EAAE;wBACJ,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;wBACd,CAAC;qBACJ,EACD,KAAK,EAAE;wBACH,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK;wBAChC,CAAC;qBACJ,IACH,CAAC;YACP,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAEO,YAAY,CAAC,MAAqB,EAAE,MAAqB;QAC7D,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,KAAK,EAAE;YAChE,MAAM,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YAC1B,MAAM,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YAE1B,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAC3B,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YAE3B,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC;YACjD,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACnB,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YAEnB,MAAM,OAAO,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;YAC9B,MAAM,OAAO,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;YAE9B,IAAI,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC;YACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC;YAEvD,IAAI,EAAE,IAAI,EAAE,EAAE;gBACV,IAAI,EAAE,GAAG,EAAE,EAAE;oBACT,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE;wBACxD,OAAO,KAAK,EAAE,IAAI,EAAE;4BAChB,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ;4BAC5E,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO;;4BAEzC,EAAE,IAAI,EAAE;4BACR,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ;4BAC5E,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;qBACnD;yBAAM;wBACH,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC;wBAC7C,OAAO,KAAK,EAAE,IAAI,EAAE;4BAChB,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO;;;4BAG3E,EAAE,IAAI,EAAE;4BACR,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;qBACrF;iBACJ;qBAAM;oBACH,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE;wBACxD,OAAO,KAAK,EAAE,IAAI,EAAE;4BAChB,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ;4BAC5E,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO;;4BAEzC,EAAE,IAAI,EAAE;4BACR,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ;4BAC5E,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO;yBAC5C,CAAC;qBACL;yBAAM;wBACH,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC;wBAC7C,OAAO,KAAK,EAAE,IAAI,EAAE;4BAChB,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO;;4BAE3E,EAAE,IAAI,EAAE;4BACR,EAAE,GAAG,QAAQ,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,IAAI,EAAE,GAAG,QAAQ,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;qBACrF;iBACJ;aACJ;YAED,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;SAChE;IACL,CAAC;IAED,UAAU;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC9B,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;gBAC1C,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;oBAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;oBACjE,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;wBACtD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;4BACZ,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC;4BACvC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO;yBACjG,CAAC,CAAC;qBACN;gBACL,CAAC,CAAC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,KAAa;QACjB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,WAAW,CAAC,KAAiB,EAAE,IAAkB;QAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAChB,KAAK;YACL,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM;SACtB,CAAC,CAAC;IACP,CAAC;IAED,cAAc,CAAC,IAAkB;QAC7B,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,OAAO,EAAE;YACnC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC;SAClC;IACL,CAAC;IAED,cAAc,CAAC,IAAkB;QAC7B,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,MAAM,EAAE;YAClC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;SACnC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;;gHAnNQ,mBAAmB,kBAoBhB,iBAAiB;oGApBpB,mBAAmB,oPClDhC,4tBAmBA;2FD+Ba,mBAAmB;kBAJ/B,SAAS;mBAAC;oBACP,QAAQ,EAAE,qBAAqB;oBAC/B,WAAW,EAAE,wBAAwB;iBACxC;;0BAqBQ,MAAM;2BAAC,iBAAiB;sIAnBpB,MAAM;sBAAd,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEI,SAAS;sBAAlB,MAAM;gBAYmC,iBAAiB;sBAA1D,WAAW;uBAAC,2BAA2B","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 } from 'rxjs/operators';\nimport { GanttGroupInternal } from '../../class/group';\nimport { GanttItemInternal, GanttItem } from './../../class/item';\nimport { GanttLineClickEvent } from '../../class/event';\nimport { GanttDragContainer } from '../../gantt-drag-container';\nimport { recursiveItems } from '../../utils/helpers';\nimport { GanttDate } from '../../utils/date';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../gantt-upper';\n\nenum LinkColors {\n    default = '#cacaca',\n    blocked = '#FF7575',\n    active = '#348FE4'\n}\n\ninterface GanttLinkItem {\n    id: string;\n    before: { x: number; y: number };\n    after: { x: number; y: number };\n    start: GanttDate;\n    end: GanttDate;\n    origin: GanttItem;\n    links: string[];\n}\n\ninterface LinkInternal {\n    path: string;\n    source: GanttItem;\n    target: GanttItem;\n    color: LinkColors;\n}\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    private linkItems: GanttLinkItem[] = [];\n\n    private bezierWeight = -0.5;\n\n    private firstChange = true;\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.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(takeUntil(this.unsubscribe$), skip(1))\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    private generatePath(source: GanttLinkItem, target: GanttLinkItem) {\n        if (source.before && source.after && target.before && target.after) {\n            const x1 = source.after.x;\n            const y1 = source.after.y;\n\n            const x4 = target.before.x;\n            const y4 = target.before.y;\n\n            const dx = Math.abs(x4 - x1) * this.bezierWeight;\n            const x2 = x1 - dx;\n            const x3 = x4 + dx;\n\n            const centerX = (x1 + x4) / 2;\n            const centerY = (y1 + y4) / 2;\n\n            let controlX = this.ganttUpper.styles.lineHeight / 2;\n            const controlY = this.ganttUpper.styles.lineHeight / 2;\n\n            if (x1 >= x4) {\n                if (y4 > y1) {\n                    if (Math.abs(y4 - y1) <= this.ganttUpper.styles.lineHeight) {\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 + controlX} ${x1} ${y1 + controlY}\n                        L ${x1} ${y1 + controlY} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 - controlX} ${x4} ${y4 - controlY}\n                        L ${x4} ${y4 - controlY} ${centerX} ${centerY}`;\n                    } else {\n                        controlX = this.ganttUpper.styles.lineHeight;\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 + controlX} ${centerX} ${centerY}\n\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 - controlX} ${centerX} ${centerY}`;\n                    }\n                } else {\n                    if (Math.abs(y4 - y1) <= this.ganttUpper.styles.lineHeight) {\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 - controlX} ${x1} ${y1 - controlY}\n                        L ${x1} ${y1 - controlY} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 + controlX} ${x4} ${y4 + controlY}\n                        L ${x4} ${y4 + controlY} ${centerX} ${centerY}\n                        `;\n                    } else {\n                        controlX = this.ganttUpper.styles.lineHeight;\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 - controlX} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 + controlX} ${centerX} ${centerY}`;\n                    }\n                }\n            }\n\n            return `M ${x1} ${y1} C ${x2} ${y1} ${x3} ${y4} ${x4} ${y4}`;\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((linkId) => {\n                    const target = this.linkItems.find((item) => item.id === linkId);\n                    if (target && (target.origin.start || target.origin.end)) {\n                        this.links.push({\n                            path: this.generatePath(source, target),\n                            source: source.origin,\n                            target: target.origin,\n                            color: source.end.getTime() > target.start.getTime() ? LinkColors.blocked : LinkColors.default\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) {\n        if (link.color === LinkColors.default) {\n            link.color = LinkColors.active;\n        }\n    }\n\n    mouseLeavePath(link: LinkInternal) {\n        if (link.color === LinkColors.active) {\n            link.color = LinkColors.default;\n        }\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 [attr.d]=\"link.path\" fill=\"transparent\" stroke-width=\"2\" [attr.stroke]=\"link.color\" pointer-events=\"none\"></path>\n    <g>\n      <path\n        class=\"link-line\"\n        (click)=\"onLineClick($event, link)\"\n        (mouseenter)=\"mouseEnterPath(link)\"\n        (mouseleave)=\"mouseLeavePath(link)\"\n        [attr.d]=\"link.path\"\n        stroke=\"transparent\"\n        stroke-width=\"9\"\n        fill=\"none\"\n        cursor=\"pointer\"\n      ></path>\n    </g>\n  </ng-container>\n  <line class=\"link-dragging-line\"></line>\n</svg>\n"]}
|
|
250
|
+
//# 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 } 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';\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    private linkItems: GanttLinkItem[] = [];\n\n    private bezierWeight = -0.5;\n\n    private firstChange = true;\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.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(takeUntil(this.unsubscribe$), skip(1))\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    private generatePath(source: GanttLinkItem, target: GanttLinkItem, type: GanttLinkType) {\n        if (source.before && source.after && target.before && target.after) {\n            let x1 = source.after.x;\n            let y1 = source.after.y;\n            let x4 = target.before.x;\n            let y4 = target.before.y;\n            let isMirror: number;\n            const control = Math.abs(y4 - y1) / 2;\n\n            switch (type) {\n                case GanttLinkType.ss:\n                    x1 = source.before.x;\n                    y1 = source.before.y;\n                    x4 = target.before.x;\n                    y4 = target.before.y;\n                    isMirror = y4 > y1 ? 0 : 1;\n\n                    if (x4 > x1) {\n                        return `M ${x1} ${y1}\n                            A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}\n                            L ${x1} ${y4} ${x4} ${y4}`;\n                    } else {\n                        return `M ${x1} ${y1}\n                        L ${x1} ${y1} ${x4} ${y1}\n                        A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;\n                    }\n\n                case GanttLinkType.ff:\n                    x1 = source.after.x;\n                    y1 = source.after.y;\n                    x4 = target.after.x;\n                    y4 = target.after.y;\n                    isMirror = y4 > y1 ? 1 : 0;\n                    if (x4 > x1) {\n                        return `M ${x1} ${y1}\n                        L ${x1} ${y1} ${x4} ${y1}\n                        A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;\n                    } else {\n                        return `M ${x1} ${y1}\n                            A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}\n                            L ${x1} ${y4} ${x4} ${y4}`;\n                    }\n\n                case GanttLinkType.sf:\n                    x1 = target.after.x;\n                    y1 = target.after.y;\n                    x4 = source.before.x;\n                    y4 = source.before.y;\n            }\n\n            const dx = Math.abs(x4 - x1) * this.bezierWeight;\n\n            const x2 = x1 - dx;\n            const x3 = x4 + dx;\n            const centerX = (x1 + x4) / 2;\n            const centerY = (y1 + y4) / 2;\n\n            let controlX = this.ganttUpper.styles.lineHeight / 2;\n            const controlY = this.ganttUpper.styles.lineHeight / 2;\n\n            if (x1 >= x4) {\n                if (y4 > y1) {\n                    if (Math.abs(y4 - y1) <= this.ganttUpper.styles.lineHeight) {\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 + controlX} ${x1} ${y1 + controlY}\n                        L ${x1} ${y1 + controlY} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 - controlX} ${x4} ${y4 - controlY}\n                        L ${x4} ${y4 - controlY} ${centerX} ${centerY}`;\n                    } else {\n                        controlX = this.ganttUpper.styles.lineHeight;\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 + controlX} ${centerX} ${centerY}\n\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 - controlX} ${centerX} ${centerY}`;\n                    }\n                } else {\n                    if (Math.abs(y4 - y1) <= this.ganttUpper.styles.lineHeight) {\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 - controlX} ${x1} ${y1 - controlY}\n                        L ${x1} ${y1 - controlY} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 + controlX} ${x4} ${y4 + controlY}\n                        L ${x4} ${y4 + controlY} ${centerX} ${centerY}\n                        `;\n                    } else {\n                        controlX = this.ganttUpper.styles.lineHeight;\n                        return `M ${x1} ${y1}\n                        C ${x1 + controlX} ${y1} ${x1 + controlX} ${y1 - controlX} ${centerX} ${centerY}\n\n                        M ${x4} ${y4}\n                        C ${x4 - controlX} ${y4} ${x4 - controlX} ${y4 + controlX} ${centerX} ${centerY}`;\n                    }\n                }\n            }\n\n            return `M ${x1} ${y1} C ${x2} ${y1} ${x3} ${y4} ${x4} ${y4}`;\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                        this.links.push({\n                            path: this.generatePath(source, target, link.type),\n                            source: source.origin,\n                            target: target.origin,\n                            type: link.type,\n                            color: source.end.getTime() > target.start.getTime() ? LinkColors.blocked : LinkColors.default\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) {\n        if (link.color === LinkColors.default) {\n            link.color = LinkColors.active;\n        }\n    }\n\n    mouseLeavePath(link: LinkInternal) {\n        if (link.color === LinkColors.active) {\n            link.color = LinkColors.default;\n        }\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      [style]=\"'marker-end: url(#triangle' + i + ')'\"\n    ></path>\n    <g>\n      <path\n        class=\"link-line\"\n        (click)=\"onLineClick($event, link)\"\n        (mouseenter)=\"mouseEnterPath(link)\"\n        (mouseleave)=\"mouseLeavePath(link)\"\n        [attr.d]=\"link.path\"\n        stroke=\"transparent\"\n        stroke-width=\"9\"\n        fill=\"none\"\n        cursor=\"pointer\"\n      ></path>\n    </g>\n    <!-- <defs>\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    </defs> -->\n  </ng-container>\n  <line class=\"link-dragging-line\"></line>\n</svg>\n"]}
|
|
@@ -201,6 +201,20 @@ var GanttViewType;
|
|
|
201
201
|
GanttViewType["week"] = "week";
|
|
202
202
|
})(GanttViewType || (GanttViewType = {}));
|
|
203
203
|
|
|
204
|
+
var GanttLinkType;
|
|
205
|
+
(function (GanttLinkType) {
|
|
206
|
+
GanttLinkType[GanttLinkType["fs"] = 0] = "fs";
|
|
207
|
+
GanttLinkType[GanttLinkType["ss"] = 1] = "ss";
|
|
208
|
+
GanttLinkType[GanttLinkType["ff"] = 2] = "ff";
|
|
209
|
+
GanttLinkType[GanttLinkType["sf"] = 3] = "sf";
|
|
210
|
+
})(GanttLinkType || (GanttLinkType = {}));
|
|
211
|
+
var LinkColors;
|
|
212
|
+
(function (LinkColors) {
|
|
213
|
+
LinkColors["default"] = "#cacaca";
|
|
214
|
+
LinkColors["blocked"] = "#FF7575";
|
|
215
|
+
LinkColors["active"] = "#348FE4";
|
|
216
|
+
})(LinkColors || (LinkColors = {}));
|
|
217
|
+
|
|
204
218
|
var GanttItemType;
|
|
205
219
|
(function (GanttItemType) {
|
|
206
220
|
GanttItemType["bar"] = "bar";
|
|
@@ -212,7 +226,17 @@ class GanttItemInternal {
|
|
|
212
226
|
this.refs$ = new BehaviorSubject(null);
|
|
213
227
|
this.origin = item;
|
|
214
228
|
this.id = this.origin.id;
|
|
215
|
-
this.links = this.origin.links || []
|
|
229
|
+
this.links = (this.origin.links || []).map((link) => {
|
|
230
|
+
if (typeof link === 'string') {
|
|
231
|
+
return {
|
|
232
|
+
type: GanttLinkType.fs,
|
|
233
|
+
link
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
else {
|
|
237
|
+
return link;
|
|
238
|
+
}
|
|
239
|
+
});
|
|
216
240
|
this.color = this.origin.color;
|
|
217
241
|
this.barStyle = this.origin.barStyle;
|
|
218
242
|
this.linkable = this.origin.linkable === undefined ? true : this.origin.linkable;
|
|
@@ -271,7 +295,7 @@ class GanttItemInternal {
|
|
|
271
295
|
this.origin.expanded = expanded;
|
|
272
296
|
}
|
|
273
297
|
addLink(linkId) {
|
|
274
|
-
this.links = [...this.links, linkId];
|
|
298
|
+
this.links = [...this.links, { type: GanttLinkType.fs, link: linkId }];
|
|
275
299
|
this.origin.links = this.links;
|
|
276
300
|
}
|
|
277
301
|
}
|
|
@@ -1832,12 +1856,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.2", ngImpor
|
|
|
1832
1856
|
args: ['mainTemplate', { static: true }]
|
|
1833
1857
|
}] } });
|
|
1834
1858
|
|
|
1835
|
-
var LinkColors;
|
|
1836
|
-
(function (LinkColors) {
|
|
1837
|
-
LinkColors["default"] = "#cacaca";
|
|
1838
|
-
LinkColors["blocked"] = "#FF7575";
|
|
1839
|
-
LinkColors["active"] = "#348FE4";
|
|
1840
|
-
})(LinkColors || (LinkColors = {}));
|
|
1841
1859
|
class GanttLinksComponent {
|
|
1842
1860
|
constructor(ganttUpper, cdr, elementRef, ganttDragContainer) {
|
|
1843
1861
|
this.ganttUpper = ganttUpper;
|
|
@@ -1912,12 +1930,53 @@ class GanttLinksComponent {
|
|
|
1912
1930
|
});
|
|
1913
1931
|
}
|
|
1914
1932
|
}
|
|
1915
|
-
generatePath(source, target) {
|
|
1933
|
+
generatePath(source, target, type) {
|
|
1916
1934
|
if (source.before && source.after && target.before && target.after) {
|
|
1917
|
-
|
|
1918
|
-
|
|
1919
|
-
|
|
1920
|
-
|
|
1935
|
+
let x1 = source.after.x;
|
|
1936
|
+
let y1 = source.after.y;
|
|
1937
|
+
let x4 = target.before.x;
|
|
1938
|
+
let y4 = target.before.y;
|
|
1939
|
+
let isMirror;
|
|
1940
|
+
const control = Math.abs(y4 - y1) / 2;
|
|
1941
|
+
switch (type) {
|
|
1942
|
+
case GanttLinkType.ss:
|
|
1943
|
+
x1 = source.before.x;
|
|
1944
|
+
y1 = source.before.y;
|
|
1945
|
+
x4 = target.before.x;
|
|
1946
|
+
y4 = target.before.y;
|
|
1947
|
+
isMirror = y4 > y1 ? 0 : 1;
|
|
1948
|
+
if (x4 > x1) {
|
|
1949
|
+
return `M ${x1} ${y1}
|
|
1950
|
+
A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}
|
|
1951
|
+
L ${x1} ${y4} ${x4} ${y4}`;
|
|
1952
|
+
}
|
|
1953
|
+
else {
|
|
1954
|
+
return `M ${x1} ${y1}
|
|
1955
|
+
L ${x1} ${y1} ${x4} ${y1}
|
|
1956
|
+
A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;
|
|
1957
|
+
}
|
|
1958
|
+
case GanttLinkType.ff:
|
|
1959
|
+
x1 = source.after.x;
|
|
1960
|
+
y1 = source.after.y;
|
|
1961
|
+
x4 = target.after.x;
|
|
1962
|
+
y4 = target.after.y;
|
|
1963
|
+
isMirror = y4 > y1 ? 1 : 0;
|
|
1964
|
+
if (x4 > x1) {
|
|
1965
|
+
return `M ${x1} ${y1}
|
|
1966
|
+
L ${x1} ${y1} ${x4} ${y1}
|
|
1967
|
+
A ${control} ${control} 0 1 ${isMirror} ${x4} ${y4}`;
|
|
1968
|
+
}
|
|
1969
|
+
else {
|
|
1970
|
+
return `M ${x1} ${y1}
|
|
1971
|
+
A ${control} ${control} 0 1 ${isMirror} ${x1} ${y4}
|
|
1972
|
+
L ${x1} ${y4} ${x4} ${y4}`;
|
|
1973
|
+
}
|
|
1974
|
+
case GanttLinkType.sf:
|
|
1975
|
+
x1 = target.after.x;
|
|
1976
|
+
y1 = target.after.y;
|
|
1977
|
+
x4 = source.before.x;
|
|
1978
|
+
y4 = source.before.y;
|
|
1979
|
+
}
|
|
1921
1980
|
const dx = Math.abs(x4 - x1) * this.bezierWeight;
|
|
1922
1981
|
const x2 = x1 - dx;
|
|
1923
1982
|
const x3 = x4 + dx;
|
|
@@ -1975,13 +2034,14 @@ class GanttLinksComponent {
|
|
|
1975
2034
|
this.links = [];
|
|
1976
2035
|
this.linkItems.forEach((source) => {
|
|
1977
2036
|
if (source.origin.start || source.origin.end) {
|
|
1978
|
-
source.links.forEach((
|
|
1979
|
-
const target = this.linkItems.find((item) => item.id ===
|
|
2037
|
+
source.links.forEach((link) => {
|
|
2038
|
+
const target = this.linkItems.find((item) => item.id === link.link);
|
|
1980
2039
|
if (target && (target.origin.start || target.origin.end)) {
|
|
1981
2040
|
this.links.push({
|
|
1982
|
-
path: this.generatePath(source, target),
|
|
2041
|
+
path: this.generatePath(source, target, link.type),
|
|
1983
2042
|
source: source.origin,
|
|
1984
2043
|
target: target.origin,
|
|
2044
|
+
type: link.type,
|
|
1985
2045
|
color: source.end.getTime() > target.start.getTime() ? LinkColors.blocked : LinkColors.default
|
|
1986
2046
|
});
|
|
1987
2047
|
}
|
|
@@ -2015,7 +2075,7 @@ class GanttLinksComponent {
|
|
|
2015
2075
|
}
|
|
2016
2076
|
}
|
|
2017
2077
|
GanttLinksComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.2", ngImport: i0, type: GanttLinksComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: GanttDragContainer }], target: i0.ɵɵFactoryTarget.Component });
|
|
2018
|
-
GanttLinksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.2", 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
|
|
2078
|
+
GanttLinksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.2", 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 [style]=\"'marker-end: url(#triangle' + i + ')'\"\n ></path>\n <g>\n <path\n class=\"link-line\"\n (click)=\"onLineClick($event, link)\"\n (mouseenter)=\"mouseEnterPath(link)\"\n (mouseleave)=\"mouseLeavePath(link)\"\n [attr.d]=\"link.path\"\n stroke=\"transparent\"\n stroke-width=\"9\"\n fill=\"none\"\n cursor=\"pointer\"\n ></path>\n </g>\n <!-- <defs>\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 </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"] }] });
|
|
2019
2079
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.2", ngImport: i0, type: GanttLinksComponent, decorators: [{
|
|
2020
2080
|
type: Component,
|
|
2021
2081
|
args: [{
|