@worktile/gantt 17.0.0-next.0 → 18.0.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/class/date-point.d.ts +2 -2
- package/components/bar/bar.component.scss +3 -0
- package/components/calendar/calendar.scss +0 -1
- package/components/calendar/grid/calendar-grid.component.d.ts +0 -1
- package/components/calendar/header/calendar-header.component.d.ts +1 -1
- package/components/drag-backdrop/drag-backdrop.component.d.ts +3 -0
- package/components/drag-backdrop/drag-backdrop.component.scss +0 -1
- package/components/links/links.component.scss +0 -1
- package/components/table/gantt-table.scss +0 -3
- package/components/table/header/gantt-table-header.component.d.ts +2 -0
- package/components/toolbar/toolbar.component.d.ts +1 -0
- package/esm2022/class/date-point.mjs +1 -1
- package/esm2022/components/bar/bar-drag.mjs +3 -3
- package/esm2022/components/bar/bar.component.mjs +3 -3
- package/esm2022/components/baseline/baseline.component.mjs +3 -3
- package/esm2022/components/calendar/grid/calendar-grid.component.mjs +6 -7
- package/esm2022/components/calendar/header/calendar-header.component.mjs +14 -8
- package/esm2022/components/drag-backdrop/drag-backdrop.component.mjs +15 -7
- package/esm2022/components/icon/icon.component.mjs +3 -3
- package/esm2022/components/links/links.component.mjs +3 -3
- package/esm2022/components/loader/loader.component.mjs +3 -3
- package/esm2022/components/main/gantt-main.component.mjs +5 -5
- package/esm2022/components/range/range.component.mjs +3 -3
- package/esm2022/components/table/body/gantt-table-body.component.mjs +5 -5
- package/esm2022/components/table/header/gantt-table-header.component.mjs +16 -4
- package/esm2022/components/toolbar/toolbar.component.mjs +10 -4
- package/esm2022/gantt-abstract.mjs +1 -1
- package/esm2022/gantt-dom.service.mjs +3 -3
- package/esm2022/gantt-drag-container.mjs +3 -3
- package/esm2022/gantt-item-upper.mjs +3 -3
- package/esm2022/gantt-print.service.mjs +3 -3
- package/esm2022/gantt-upper.mjs +7 -7
- package/esm2022/gantt.component.mjs +6 -6
- package/esm2022/gantt.config.mjs +6 -1
- package/esm2022/gantt.module.mjs +4 -4
- package/esm2022/gantt.pipe.mjs +9 -9
- package/esm2022/gantt.styles.mjs +1 -6
- package/esm2022/root.component.mjs +3 -3
- package/esm2022/table/gantt-column.component.mjs +3 -3
- package/esm2022/table/gantt-table.component.mjs +3 -3
- package/esm2022/views/hour.mjs +11 -1
- package/esm2022/views/month.mjs +2 -2
- package/esm2022/views/quarter.mjs +2 -2
- package/esm2022/views/view.mjs +3 -3
- package/esm2022/views/year.mjs +2 -2
- package/fesm2022/worktile-gantt.mjs +153 -113
- package/fesm2022/worktile-gantt.mjs.map +1 -1
- package/gantt-abstract.d.ts +2 -2
- package/gantt-upper.d.ts +2 -3
- package/gantt.component.scss +0 -5
- package/gantt.config.d.ts +6 -0
- package/gantt.pipe.d.ts +3 -3
- package/gantt.styles.d.ts +0 -6
- package/package.json +1 -1
- package/styles/variables.scss +4 -2
- package/utils/date.d.ts +0 -1
- package/utils/helpers.d.ts +2 -2
- package/views/hour.d.ts +1 -0
- package/views/view.d.ts +2 -2
package/class/date-point.d.ts
CHANGED
|
@@ -3,13 +3,13 @@ export declare class GanttDatePoint {
|
|
|
3
3
|
start: GanttDate;
|
|
4
4
|
text: string;
|
|
5
5
|
x: number;
|
|
6
|
-
y: number;
|
|
6
|
+
y: number | string;
|
|
7
7
|
additions?: {
|
|
8
8
|
isWeekend: boolean;
|
|
9
9
|
isToday: boolean;
|
|
10
10
|
};
|
|
11
11
|
style?: Partial<CSSStyleDeclaration>;
|
|
12
|
-
constructor(start: GanttDate, text: string, x: number, y: number, additions?: {
|
|
12
|
+
constructor(start: GanttDate, text: string, x: number, y: number | string, additions?: {
|
|
13
13
|
isWeekend: boolean;
|
|
14
14
|
isToday: boolean;
|
|
15
15
|
}, style?: Partial<CSSStyleDeclaration>);
|
|
@@ -148,6 +148,9 @@ $gantt-bar-link-drop-border: 5px;
|
|
|
148
148
|
background: variables.$gantt-bar-background-color;
|
|
149
149
|
overflow: hidden;
|
|
150
150
|
box-sizing: border-box;
|
|
151
|
+
display: flex;
|
|
152
|
+
align-items: center;
|
|
153
|
+
white-space: nowrap;
|
|
151
154
|
|
|
152
155
|
.gantt-bar-content-progress {
|
|
153
156
|
position: absolute;
|
|
@@ -9,7 +9,6 @@ export declare class GanttCalendarGridComponent implements OnInit, OnDestroy {
|
|
|
9
9
|
private elementRef;
|
|
10
10
|
get view(): import("@worktile/gantt").GanttView;
|
|
11
11
|
private unsubscribe$;
|
|
12
|
-
headerHeight: number;
|
|
13
12
|
mainHeight: number;
|
|
14
13
|
todayBorderRadius: number;
|
|
15
14
|
viewTypes: typeof GanttViewType;
|
|
@@ -9,9 +9,9 @@ export declare class GanttCalendarHeaderComponent implements OnInit {
|
|
|
9
9
|
private elementRef;
|
|
10
10
|
get view(): import("@worktile/gantt").GanttView;
|
|
11
11
|
private unsubscribe$;
|
|
12
|
-
headerHeight: number;
|
|
13
12
|
viewTypes: typeof GanttViewType;
|
|
14
13
|
className: string;
|
|
14
|
+
get height(): string;
|
|
15
15
|
constructor(ganttUpper: GanttUpper, ngZone: NgZone, elementRef: ElementRef<HTMLElement>);
|
|
16
16
|
ngOnInit(): void;
|
|
17
17
|
setTodayPoint(): void;
|
|
@@ -1,5 +1,8 @@
|
|
|
1
|
+
import { GanttUpper } from '../../gantt-upper';
|
|
1
2
|
import * as i0 from "@angular/core";
|
|
2
3
|
export declare class GanttDragBackdropComponent {
|
|
4
|
+
ganttUpper: GanttUpper;
|
|
5
|
+
constructor(ganttUpper: GanttUpper);
|
|
3
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<GanttDragBackdropComponent, never>;
|
|
4
7
|
static ɵcmp: i0.ɵɵComponentDeclaration<GanttDragBackdropComponent, "gantt-drag-backdrop", never, {}, {}, never, never, true, never>;
|
|
5
8
|
}
|
|
@@ -167,8 +167,6 @@
|
|
|
167
167
|
.gantt-table-header {
|
|
168
168
|
text-align: center;
|
|
169
169
|
background: #fff;
|
|
170
|
-
height: variables.$gantt-header-height;
|
|
171
|
-
line-height: variables.$gantt-header-height;
|
|
172
170
|
box-shadow: variables.$gantt-side-shadow;
|
|
173
171
|
position: relative;
|
|
174
172
|
z-index: 3;
|
|
@@ -190,7 +188,6 @@
|
|
|
190
188
|
display: block;
|
|
191
189
|
.gantt-table-group {
|
|
192
190
|
display: flex;
|
|
193
|
-
height: variables.$gantt-group-height;
|
|
194
191
|
background: variables.$gantt-group-background-color;
|
|
195
192
|
padding: 0 10px;
|
|
196
193
|
align-items: center;
|
|
@@ -15,6 +15,8 @@ export declare class GanttTableHeaderComponent implements OnInit, OnDestroy {
|
|
|
15
15
|
columns: QueryList<NgxGanttTableColumnComponent>;
|
|
16
16
|
resizeLineElementRef: ElementRef<HTMLElement>;
|
|
17
17
|
className: string;
|
|
18
|
+
get height(): string;
|
|
19
|
+
get lineHeight(): string;
|
|
18
20
|
constructor(elementRef: ElementRef, gantt: GanttAbstractComponent, cdr: ChangeDetectorRef);
|
|
19
21
|
ngOnInit(): void;
|
|
20
22
|
private columnsChange;
|
|
@@ -8,4 +8,4 @@ export class GanttDatePoint {
|
|
|
8
8
|
this.style = style;
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1wb2ludC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dhbnR0L3NyYy9jbGFzcy9kYXRlLXBvaW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxjQUFjO0lBQ3ZCLFlBQ1csS0FBZ0IsRUFDaEIsSUFBWSxFQUNaLENBQVMsRUFDVCxDQUFrQixFQUNsQixTQUdOLEVBQ00sS0FBb0M7UUFScEMsVUFBSyxHQUFMLEtBQUssQ0FBVztRQUNoQixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQ1osTUFBQyxHQUFELENBQUMsQ0FBUTtRQUNULE1BQUMsR0FBRCxDQUFDLENBQWlCO1FBQ2xCLGNBQVMsR0FBVCxTQUFTLENBR2Y7UUFDTSxVQUFLLEdBQUwsS0FBSyxDQUErQjtJQUM1QyxDQUFDO0NBQ1AiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHYW50dERhdGUgfSBmcm9tICcuLi91dGlscy9kYXRlJztcblxuZXhwb3J0IGNsYXNzIEdhbnR0RGF0ZVBvaW50IHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHVibGljIHN0YXJ0OiBHYW50dERhdGUsXG4gICAgICAgIHB1YmxpYyB0ZXh0OiBzdHJpbmcsXG4gICAgICAgIHB1YmxpYyB4OiBudW1iZXIsXG4gICAgICAgIHB1YmxpYyB5OiBudW1iZXIgfCBzdHJpbmcsXG4gICAgICAgIHB1YmxpYyBhZGRpdGlvbnM/OiB7XG4gICAgICAgICAgICBpc1dlZWtlbmQ6IGJvb2xlYW47XG4gICAgICAgICAgICBpc1RvZGF5OiBib29sZWFuO1xuICAgICAgICB9LFxuICAgICAgICBwdWJsaWMgc3R5bGU/OiBQYXJ0aWFsPENTU1N0eWxlRGVjbGFyYXRpb24+XG4gICAgKSB7fVxufVxuIl19
|
|
@@ -515,10 +515,10 @@ export class GanttBarDrag {
|
|
|
515
515
|
this.stopScrolling();
|
|
516
516
|
this.stopScrollTimers$.complete();
|
|
517
517
|
}
|
|
518
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
519
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
518
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttBarDrag, deps: [{ token: i1.DragDrop }, { token: i2.GanttDomService }, { token: i3.GanttDragContainer }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
519
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttBarDrag }); }
|
|
520
520
|
}
|
|
521
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
521
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttBarDrag, decorators: [{
|
|
522
522
|
type: Injectable
|
|
523
523
|
}], ctorParameters: () => [{ type: i1.DragDrop }, { type: i2.GanttDomService }, { type: i3.GanttDragContainer }, { type: i0.NgZone }] });
|
|
524
524
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-drag.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/bar/bar-drag.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragDrop, DragRef } from '@angular/cdk/drag-drop';\nimport { ElementRef, Injectable, NgZone, OnDestroy } from '@angular/core';\nimport { Subject, animationFrameScheduler, fromEvent, interval } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { GanttViewType } from '../../class';\nimport { GanttItemInternal } from '../../class/item';\nimport { GanttLinkType } from '../../class/link';\nimport { GanttDomService } from '../../gantt-dom.service';\nimport { GanttDragContainer, InBarPosition } from '../../gantt-drag-container';\nimport { GanttUpper } from '../../gantt-upper';\nimport { GanttDate } from '../../utils/date';\nimport {\n    AutoScrollHorizontalDirection,\n    getAutoScrollSpeedRates,\n    getHorizontalScrollDirection,\n    isPointerNearClientRect\n} from '../../utils/drag-scroll';\nimport { passiveListenerOptions } from '../../utils/passive-listeners';\n\n/**\n * Proximity, as a ratio to width/height, at which a\n * dragged item will affect the drop container.\n */\nconst DROP_PROXIMITY_THRESHOLD = 0.05;\n\nconst dragMinWidth = 10;\nconst autoScrollBaseStep = 2;\nconst activeClass = 'gantt-bar-active';\nconst dropActiveClass = 'gantt-bar-drop-active';\nconst singleDropActiveClass = 'gantt-bar-single-drop-active';\n\nfunction createSvgElement(qualifiedName: string, className: string) {\n    const element = document.createElementNS('http://www.w3.org/2000/svg', qualifiedName);\n    element.classList.add(className);\n    return element;\n}\n\n@Injectable()\nexport class GanttBarDrag implements OnDestroy {\n    private ganttUpper: GanttUpper;\n\n    private barElement: HTMLElement;\n\n    private item: GanttItemInternal;\n\n    private get dragDisabled() {\n        return !this.item.draggable || !this.ganttUpper.draggable;\n    }\n\n    private get linkDragDisabled() {\n        return !this.item.linkable || !this.ganttUpper.linkable;\n    }\n\n    private get barHandleDragMoveAndScrollDistance() {\n        return this.barHandleDragMoveDistance + this.dragScrollDistance;\n    }\n\n    private get autoScrollStep() {\n        return Math.pow(autoScrollBaseStep, this.autoScrollSpeedRates);\n    }\n\n    private linkDraggingLine: SVGElement;\n\n    private barDragRef: DragRef;\n\n    private dragRefs: DragRef[] = [];\n\n    private destroy$ = new Subject<void>();\n\n    /** Used to signal to the current auto-scroll sequence when to stop. */\n    private stopScrollTimers$ = new Subject<void>();\n\n    /** container element scrollLeft */\n    private containerScrollLeft: number;\n\n    /** move distance when drag bar */\n    private barDragMoveDistance = 0;\n\n    /** move distance when drag bar handle */\n    private barHandleDragMoveDistance = 0;\n\n    /** scrolling state when drag */\n    private dragScrolling = false;\n\n    /** dragScrollDistance */\n    private dragScrollDistance = 0;\n\n    /** Horizontal direction in which the list is currently scrolling. */\n    private _horizontalScrollDirection = AutoScrollHorizontalDirection.NONE;\n\n    /** Record bar days when bar handle drag move. */\n    private barHandleDragMoveRecordDiffs: number;\n\n    /** Speed ratio for auto scroll */\n    private autoScrollSpeedRates = 1;\n\n    constructor(\n        private dragDrop: DragDrop,\n        private dom: GanttDomService,\n        private dragContainer: GanttDragContainer,\n        private _ngZone: NgZone\n    ) {}\n\n    private createDragRef<T = any>(element: ElementRef<HTMLElement> | HTMLElement): DragRef<T> {\n        const dragRef = this.dragDrop.createDrag(element);\n        return dragRef;\n    }\n\n    private createDragScrollEvent(dragRef: DragRef) {\n        return fromEvent(this.dom.mainContainer, 'scroll', passiveListenerOptions).pipe(takeUntil(dragRef.ended));\n    }\n\n    private createMouseEvents() {\n        const dropClass =\n            this.ganttUpper.config.linkOptions?.dependencyTypes?.length === 1 &&\n            this.ganttUpper.config.linkOptions?.dependencyTypes[0] === GanttLinkType.fs\n                ? singleDropActiveClass\n                : dropActiveClass;\n\n        fromEvent(this.barElement, 'mouseenter', passiveListenerOptions)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                if (this.dragContainer.linkDraggingId && this.dragContainer.linkDraggingId !== this.item.id) {\n                    if (this.item.linkable) {\n                        this.barElement.classList.add(dropClass);\n                        this.dragContainer.emitLinkDragEntered({\n                            item: this.item,\n                            element: this.barElement\n                        });\n                    }\n                } else {\n                    this.barElement.classList.add(activeClass);\n                }\n            });\n\n        fromEvent(this.barElement, 'mouseleave', passiveListenerOptions)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                if (!this.dragContainer.linkDraggingId) {\n                    this.barElement.classList.remove(activeClass);\n                } else {\n                    this.dragContainer.emitLinkDragLeaved();\n                }\n                this.barElement.classList.remove(dropClass);\n            });\n    }\n\n    private createBarDrag() {\n        const dragRef = this.createDragRef(this.barElement);\n        dragRef.lockAxis = 'x';\n        dragRef.withBoundaryElement(this.dom.mainItems as HTMLElement);\n        dragRef.started.subscribe(() => {\n            this.setDraggingStyles();\n            this.containerScrollLeft = this.dom.mainContainer.scrollLeft;\n            this.createDragScrollEvent(dragRef).subscribe(() => {\n                if (dragRef.isDragging()) {\n                    const dragScrollDistance = this.dom.mainContainer.scrollLeft - this.containerScrollLeft;\n                    this.dragScrollDistance = dragScrollDistance;\n                    dragRef['_boundaryRect'] = this.dom.mainItems.getBoundingClientRect();\n                    this.barDragMove();\n                }\n            });\n            this.dragContainer.dragStarted.emit({ item: this.item.origin });\n        });\n\n        dragRef.moved.subscribe((event) => {\n            this.startScrollingIfNecessary(event.pointerPosition.x, event.pointerPosition.y);\n            this.barDragMoveDistance = event.distance.x;\n            if (!this.dragScrolling) {\n                this.barDragMove();\n            }\n        });\n\n        dragRef.ended.subscribe((event) => {\n            this.clearDraggingStyles();\n            this.closeDragBackdrop();\n            event.source.reset();\n            this.stopScrolling();\n            this.dragScrolling = false;\n            this.dragScrollDistance = 0;\n            this.barDragMoveDistance = 0;\n            this.item.updateRefs({\n                width: this.ganttUpper.view.getDateRangeWidth(this.item.start, this.item.end),\n                x: this.ganttUpper.view.getXPointByDate(this.item.start),\n                y: (this.ganttUpper.styles.lineHeight - this.ganttUpper.styles.barHeight) / 2 - 1\n            });\n            this.dragContainer.dragEnded.emit({ item: this.item.origin });\n        });\n        this.barDragRef = dragRef;\n\n        return dragRef;\n    }\n\n    private createBarHandleDrags() {\n        const dragRefs = [];\n        const handles = this.barElement.querySelectorAll<HTMLElement>('.drag-handles .handle');\n        handles.forEach((handle, index) => {\n            const isBefore = index === 0;\n            const dragRef = this.createDragRef(handle);\n            dragRef.lockAxis = 'x';\n            dragRef.withBoundaryElement(this.dom.mainItems as HTMLElement);\n            dragRef.started.subscribe(() => {\n                this.setDraggingStyles();\n                this.containerScrollLeft = this.dom.mainContainer.scrollLeft;\n                this.createDragScrollEvent(dragRef).subscribe(() => {\n                    if (dragRef.isDragging()) {\n                        const dragScrollDistance = this.dom.mainContainer.scrollLeft - this.containerScrollLeft;\n                        this.dragScrollDistance = dragScrollDistance;\n                        dragRef['_boundaryRect'] = this.dom.mainItems.getBoundingClientRect();\n\n                        if (this.dragScrolling && this.isStartGreaterThanEndWhenBarHandleDragMove(isBefore)) {\n                            this.stopScrolling();\n                            this.dragScrolling = false;\n                        }\n\n                        if (isBefore) {\n                            this.barBeforeHandleDragMove();\n                        } else {\n                            this.barAfterHandleDragMove();\n                        }\n                    }\n                });\n                this.dragContainer.dragStarted.emit({ item: this.item.origin });\n            });\n\n            dragRef.moved.subscribe((event) => {\n                if (this.barHandleDragMoveRecordDiffs && this.barHandleDragMoveRecordDiffs > 0) {\n                    this.startScrollingIfNecessary(event.pointerPosition.x, event.pointerPosition.y);\n                }\n                this.barHandleDragMoveDistance = event.distance.x;\n                if (!this.dragScrolling) {\n                    if (isBefore) {\n                        this.barBeforeHandleDragMove();\n                    } else {\n                        this.barAfterHandleDragMove();\n                    }\n                }\n            });\n\n            dragRef.ended.subscribe((event) => {\n                this.clearDraggingStyles();\n                this.closeDragBackdrop();\n                event.source.reset();\n                this.stopScrolling();\n                this.dragScrolling = false;\n                this.dragScrollDistance = 0;\n                this.barHandleDragMoveDistance = 0;\n                this.item.updateRefs({\n                    width: this.ganttUpper.view.getDateRangeWidth(this.item.start, this.item.end),\n                    x: this.ganttUpper.view.getXPointByDate(this.item.start),\n                    y: (this.ganttUpper.styles.lineHeight - this.ganttUpper.styles.barHeight) / 2 - 1\n                });\n                this.dragContainer.dragEnded.emit({ item: this.item.origin });\n            });\n            dragRefs.push(dragRef);\n        });\n        return dragRefs;\n    }\n\n    private createLinkHandleDrags() {\n        const dragRefs = [];\n        const handles = this.barElement.querySelectorAll<HTMLElement>('.link-handles .handle');\n        handles.forEach((handle, index) => {\n            const isBegin = index === 0;\n            const dragRef = this.dragDrop.createDrag(handle);\n            dragRef.withBoundaryElement(this.dom.root as HTMLElement);\n            dragRef.beforeStarted.subscribe(() => {\n                handle.style.pointerEvents = 'none';\n                if (this.barDragRef) {\n                    this.barDragRef.disabled = true;\n                }\n                this.createLinkDraggingLine();\n                this.dragContainer.emitLinkDragStarted({\n                    element: this.barElement,\n                    item: this.item,\n                    pos: isBegin ? InBarPosition.start : InBarPosition.finish\n                });\n            });\n\n            dragRef.moved.subscribe(() => {\n                const positions = this.calcLinkLinePositions(handle, isBegin);\n                this.linkDraggingLine.setAttribute('x1', positions.x1.toString());\n                this.linkDraggingLine.setAttribute('y1', positions.y1.toString());\n                this.linkDraggingLine.setAttribute('x2', positions.x2.toString());\n                this.linkDraggingLine.setAttribute('y2', positions.y2.toString());\n            });\n\n            dragRef.ended.subscribe((event) => {\n                handle.style.pointerEvents = '';\n                if (this.barDragRef) {\n                    this.barDragRef.disabled = false;\n                }\n                // 计算line拖动的落点位于目标Bar的值，如果值大于Bar宽度的一半，说明是拖动到Begin位置，否则则为拖动到End位置\n                if (this.dragContainer.linkDragPath.to) {\n                    const placePointX =\n                        event.source.getRootElement().getBoundingClientRect().x -\n                        this.dragContainer.linkDragPath.to.element.getBoundingClientRect().x;\n\n                    this.dragContainer.emitLinkDragEnded({\n                        ...this.dragContainer.linkDragPath.to,\n                        pos:\n                            placePointX < this.dragContainer.linkDragPath.to.item.refs.width / 2\n                                ? InBarPosition.start\n                                : InBarPosition.finish\n                    });\n                } else {\n                    this.dragContainer.emitLinkDragEnded();\n                }\n                event.source.reset();\n                this.barElement.classList.remove(activeClass);\n                this.destroyLinkDraggingLine();\n            });\n\n            dragRefs.push(dragRef);\n        });\n        return dragRefs;\n    }\n\n    private openDragBackdrop(dragElement: HTMLElement, start: GanttDate, end: GanttDate) {\n        const dragBackdropElement = this.dom.root.querySelector('.gantt-drag-backdrop') as HTMLElement;\n        const dragMaskElement = this.dom.root.querySelector('.gantt-drag-mask') as HTMLElement;\n        const rootRect = this.dom.root.getBoundingClientRect();\n        const dragRect = dragElement.getBoundingClientRect();\n        let left = dragRect.left - rootRect.left - (this.dom.side.clientWidth + 1);\n        if (this.dragScrolling) {\n            if (this._horizontalScrollDirection === AutoScrollHorizontalDirection.LEFT) {\n                left += this.autoScrollStep;\n            } else if (this._horizontalScrollDirection === AutoScrollHorizontalDirection.RIGHT) {\n                left -= this.autoScrollStep;\n            }\n        }\n        const width = dragRect.right - dragRect.left;\n\n        // Note: updating styles will cause re-layout so we have to place them consistently one by one.\n        dragMaskElement.style.left = left + 'px';\n        dragMaskElement.style.width = width + 'px';\n        dragMaskElement.style.display = 'block';\n        dragBackdropElement.style.display = 'block';\n        // This will invalidate the layout, but we won't need re-layout, because we set styles previously.\n        dragMaskElement.querySelector('.start').innerHTML = start.format(this.ganttUpper.view.options.dragPreviewDateFormat);\n        dragMaskElement.querySelector('.end').innerHTML = end.format(this.ganttUpper.view.options.dragPreviewDateFormat);\n    }\n\n    private closeDragBackdrop() {\n        const dragBackdropElement = this.dom.root.querySelector('.gantt-drag-backdrop') as HTMLElement;\n        const dragMaskElement = this.dom.root.querySelector('.gantt-drag-mask') as HTMLElement;\n        dragMaskElement.style.display = 'none';\n        dragBackdropElement.style.display = 'none';\n    }\n\n    private setDraggingStyles() {\n        this.barElement.classList.add('gantt-bar-draggable-drag');\n    }\n\n    private clearDraggingStyles() {\n        this.barElement.classList.remove('gantt-bar-draggable-drag');\n    }\n\n    private barDragMove() {\n        const currentX = this.item.refs.x + this.barDragMoveDistance + this.dragScrollDistance;\n        const currentDate = this.ganttUpper.view.getDateByXPoint(currentX);\n        const currentStartX = this.ganttUpper.view.getXPointByDate(currentDate);\n\n        const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item.end, this.item.start);\n\n        let start = currentDate;\n        let end = currentDate.add(diffs, this.ganttUpper.view?.options?.datePrecisionUnit);\n\n        // 日视图特殊逻辑处理\n        if (this.ganttUpper.view.viewType === GanttViewType.day) {\n            const dayWidth = this.ganttUpper.view.getDayOccupancyWidth(currentDate);\n            if (currentX > currentStartX + dayWidth / 2) {\n                start = start.addDays(1);\n                end = end.addDays(1);\n            }\n        }\n\n        if (this.dragScrolling) {\n            const left = currentX - this.barDragMoveDistance;\n            this.barElement.style.left = left + 'px';\n        }\n\n        this.openDragBackdrop(\n            this.barElement,\n            this.ganttUpper.view.getDateByXPoint(currentX),\n            this.ganttUpper.view.getDateByXPoint(currentX + this.item.refs.width)\n        );\n\n        if (!this.isStartOrEndInsideView(start, end)) {\n            return;\n        }\n        this.updateItemDate(start, end);\n        this.dragContainer.dragMoved.emit({ item: this.item.origin });\n    }\n\n    private barBeforeHandleDragMove() {\n        const { x, start, minRangeWidthWidth } = this.startOfBarHandle();\n        const width = this.item.refs.width + this.barHandleDragMoveAndScrollDistance * -1;\n        const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item.end, start);\n\n        if (width > dragMinWidth && diffs > 0) {\n            this.barElement.style.width = width + 'px';\n            this.barElement.style.left = x + 'px';\n            this.openDragBackdrop(this.barElement, start, this.item.end);\n\n            if (!this.isStartOrEndInsideView(start, this.item.end)) {\n                return;\n            }\n\n            this.updateItemDate(start, this.item.end);\n        } else {\n            if (this.barHandleDragMoveRecordDiffs > 0 && diffs <= 0) {\n                this.barElement.style.width = minRangeWidthWidth + 'px';\n                const x = this.ganttUpper.view.getXPointByDate(this.item.end);\n                this.barElement.style.left = x + 'px';\n            }\n            this.openDragBackdrop(this.barElement, this.item.end, this.item.end);\n            this.updateItemDate(this.item.end, this.item.end);\n        }\n        this.barHandleDragMoveRecordDiffs = diffs;\n\n        this.dragContainer.dragMoved.emit({ item: this.item.origin });\n    }\n\n    private barAfterHandleDragMove() {\n        const { width, end } = this.endOfBarHandle();\n        const diffs = this.ganttUpper.view.differenceByPrecisionUnit(end, this.item.start);\n\n        if (width > dragMinWidth && diffs > 0) {\n            this.barElement.style.width = width + 'px';\n            this.openDragBackdrop(this.barElement, this.item.start, end);\n            if (!this.isStartOrEndInsideView(this.item.start, end)) {\n                return;\n            }\n            this.updateItemDate(this.item.start, end);\n        } else {\n            if (this.barHandleDragMoveRecordDiffs > 0 && diffs <= 0) {\n                const minRangeWidth = this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item.start);\n                this.barElement.style.width = minRangeWidth + 'px';\n            }\n            this.openDragBackdrop(this.barElement, this.item.start, this.item.start);\n            this.updateItemDate(this.item.start, this.item.start);\n        }\n        this.barHandleDragMoveRecordDiffs = diffs;\n        this.dragContainer.dragMoved.emit({ item: this.item.origin });\n    }\n\n    private calcLinkLinePositions(target: HTMLElement, isBefore: boolean) {\n        const rootRect = this.dom.root.getBoundingClientRect();\n        const targetRect = target.getBoundingClientRect();\n        const layerRect = target.parentElement.parentElement.getBoundingClientRect();\n        return {\n            x1: layerRect.left + (isBefore ? 0 : layerRect.width) - rootRect.left,\n            y1: layerRect.top + layerRect.height / 2 - rootRect.top,\n            x2: targetRect.left - rootRect.left + targetRect.width / 2,\n            y2: targetRect.top - rootRect.top + targetRect.height / 2\n        };\n    }\n\n    private createLinkDraggingLine() {\n        if (!this.linkDraggingLine) {\n            const svgElement = createSvgElement('svg', 'gantt-link-drag-container');\n            const linElement = createSvgElement('line', 'link-dragging-line');\n            linElement.style.pointerEvents = 'none';\n            svgElement.appendChild(linElement);\n            this.dom.root.appendChild(svgElement);\n            this.linkDraggingLine = linElement;\n        }\n    }\n\n    private destroyLinkDraggingLine() {\n        if (this.linkDraggingLine) {\n            this.linkDraggingLine.parentElement.remove();\n            this.linkDraggingLine = null;\n        }\n    }\n\n    private startScrollInterval = () => {\n        this.stopScrolling();\n        interval(0, animationFrameScheduler)\n            .pipe(takeUntil(this.stopScrollTimers$))\n            .subscribe(() => {\n                const node = this.dom.mainContainer;\n                const scrollStep = this.autoScrollStep;\n                if (this._horizontalScrollDirection === AutoScrollHorizontalDirection.LEFT) {\n                    node.scrollBy(-scrollStep, 0);\n                } else if (this._horizontalScrollDirection === AutoScrollHorizontalDirection.RIGHT) {\n                    node.scrollBy(scrollStep, 0);\n                }\n            });\n    };\n\n    private startScrollingIfNecessary(pointerX: number, pointerY: number) {\n        const clientRect = this.dom.mainContainer.getBoundingClientRect();\n        const scrollLeft = this.dom.mainContainer.scrollLeft;\n        if (isPointerNearClientRect(clientRect, DROP_PROXIMITY_THRESHOLD, pointerX, pointerY)) {\n            const horizontalScrollDirection = getHorizontalScrollDirection(clientRect, pointerX);\n\n            if (\n                (horizontalScrollDirection === AutoScrollHorizontalDirection.LEFT && scrollLeft > 0) ||\n                (horizontalScrollDirection === AutoScrollHorizontalDirection.RIGHT &&\n                    scrollLeft < this.ganttUpper.view.width - clientRect.width)\n            ) {\n                this._horizontalScrollDirection = horizontalScrollDirection;\n                this.autoScrollSpeedRates = getAutoScrollSpeedRates(clientRect, pointerX, horizontalScrollDirection);\n                this.dragScrolling = true;\n                this._ngZone.runOutsideAngular(this.startScrollInterval);\n            } else {\n                this.dragScrolling = false;\n                this.stopScrolling();\n            }\n        }\n    }\n\n    // Conditions to stop auto-scroll: when the start is greater than the end and the bar appears in the view\n    private isStartGreaterThanEndWhenBarHandleDragMove(isBefore: boolean) {\n        let isStartGreaterThanEnd: boolean;\n        let isBarAppearsInView: boolean;\n\n        const scrollLeft = this.dom.mainContainer.scrollLeft;\n        const clientWidth = this.dom.mainContainer.clientWidth;\n        const xThreshold = clientWidth * DROP_PROXIMITY_THRESHOLD;\n\n        if (isBefore) {\n            const { start, minRangeWidthWidth } = this.startOfBarHandle();\n            const xPointerByEndDate = this.ganttUpper.view.getXPointByDate(this.item.end);\n\n            isStartGreaterThanEnd = start.value > this.item.end.value;\n            isBarAppearsInView = xPointerByEndDate + minRangeWidthWidth + xThreshold <= scrollLeft + clientWidth;\n        } else {\n            const { end } = this.endOfBarHandle();\n            const xPointerByStartDate = this.ganttUpper.view.getXPointByDate(this.item.start);\n\n            isStartGreaterThanEnd = end.value < this.item.start.value;\n            isBarAppearsInView = scrollLeft + xThreshold <= xPointerByStartDate;\n        }\n\n        return isStartGreaterThanEnd && isBarAppearsInView ? true : false;\n    }\n\n    // Some data information about dragging start until it is equal to or greater than end\n    private startOfBarHandle() {\n        const x = this.item.refs.x + this.barHandleDragMoveAndScrollDistance;\n        return {\n            x,\n            start: this.ganttUpper.view.getDateByXPoint(x),\n            minRangeWidthWidth: this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item.end)\n        };\n    }\n\n    // Some data information about dragging end of bar handle\n    private endOfBarHandle() {\n        const width = this.item.refs.width + this.barHandleDragMoveAndScrollDistance;\n\n        return {\n            width,\n            end: this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width)\n        };\n    }\n\n    private stopScrolling() {\n        this.stopScrollTimers$.next();\n    }\n\n    private isStartOrEndInsideView(start: GanttDate, end: GanttDate) {\n        const itemStart = start.getUnixTime();\n        const itemEnd = end.getUnixTime();\n        const viewStart = this.ganttUpper.view.start.getUnixTime();\n        const viewEnd = this.ganttUpper.view.end.getUnixTime();\n        if (itemStart < viewStart || itemEnd > viewEnd) {\n            return false;\n        } else {\n            return true;\n        }\n    }\n\n    private updateItemDate(start: GanttDate, end: GanttDate) {\n        this.item.updateDate(this.ganttUpper.view.startOfPrecision(start), this.ganttUpper.view.endOfPrecision(end));\n    }\n\n    createDrags(elementRef: ElementRef, item: GanttItemInternal, ganttUpper: GanttUpper) {\n        this.item = item;\n        this.barElement = elementRef.nativeElement;\n\n        this.ganttUpper = ganttUpper;\n        if (this.dragDisabled && this.linkDragDisabled) {\n            return;\n        } else {\n            this.createMouseEvents();\n            if (!this.dragDisabled) {\n                const dragRef = this.createBarDrag();\n                const dragHandlesRefs = this.createBarHandleDrags();\n                this.dragRefs.push(dragRef, ...dragHandlesRefs);\n            }\n            if (!this.linkDragDisabled) {\n                const linkDragRefs = this.createLinkHandleDrags();\n                this.dragRefs.push(...linkDragRefs);\n            }\n        }\n    }\n\n    updateItem(item: GanttItemInternal) {\n        this.item = item;\n    }\n\n    ngOnDestroy() {\n        this.closeDragBackdrop();\n        this.dragRefs.forEach((dragRef) => dragRef.dispose());\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.stopScrolling();\n        this.stopScrollTimers$.complete();\n    }\n}\n"]}
|
|
@@ -108,10 +108,10 @@ export class NgxGanttBarComponent extends GanttItemUpper {
|
|
|
108
108
|
stopPropagation(event) {
|
|
109
109
|
event.stopPropagation();
|
|
110
110
|
}
|
|
111
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
112
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
111
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttBarComponent, deps: [{ token: i1.GanttDragContainer }, { token: i2.GanttBarDrag }, { token: i0.ElementRef }, { token: GANTT_UPPER_TOKEN }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
112
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: NgxGanttBarComponent, isStandalone: true, selector: "ngx-gantt-bar,gantt-bar", outputs: { barClick: "barClick" }, host: { properties: { "class.gantt-bar": "this.ganttItemClass" } }, providers: [GanttBarDrag], viewQueries: [{ propertyName: "contentElementRef", first: true, predicate: ["content"], descendants: true }, { propertyName: "handles", predicate: ["handle"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"gantt-bar-layer\">\n <div class=\"drag-handles\">\n <ng-container *ngIf=\"item.draggable && ganttUpper.draggable\">\n <span class=\"handle\" #handle></span>\n <span class=\"handle\" #handle></span>\n </ng-container>\n </div>\n <div *ngIf=\"item.linkable && ganttUpper.linkable\" class=\"link-handles\">\n <span class=\"handle\"><span class=\"point\"></span></span>\n <span class=\"handle\"> <span class=\"point\"></span></span>\n </div>\n</div>\n<div class=\"gantt-bar-border\"></div>\n<div #content class=\"gantt-bar-content\" (click)=\"onBarClick($event)\">\n <div class=\"gantt-bar-content-progress\" *ngIf=\"item.progress >= 0\" [style.width.%]=\"item.progress * 100\"></div>\n <ng-template [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item.origin, refs: item.refs }\"> </ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
|
|
113
113
|
}
|
|
114
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
114
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttBarComponent, decorators: [{
|
|
115
115
|
type: Component,
|
|
116
116
|
args: [{ selector: 'ngx-gantt-bar,gantt-bar', providers: [GanttBarDrag], standalone: true, imports: [NgIf, NgTemplateOutlet], template: "<div class=\"gantt-bar-layer\">\n <div class=\"drag-handles\">\n <ng-container *ngIf=\"item.draggable && ganttUpper.draggable\">\n <span class=\"handle\" #handle></span>\n <span class=\"handle\" #handle></span>\n </ng-container>\n </div>\n <div *ngIf=\"item.linkable && ganttUpper.linkable\" class=\"link-handles\">\n <span class=\"handle\"><span class=\"point\"></span></span>\n <span class=\"handle\"> <span class=\"point\"></span></span>\n </div>\n</div>\n<div class=\"gantt-bar-border\"></div>\n<div #content class=\"gantt-bar-content\" (click)=\"onBarClick($event)\">\n <div class=\"gantt-bar-content-progress\" *ngIf=\"item.progress >= 0\" [style.width.%]=\"item.progress * 100\"></div>\n <ng-template [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item.origin, refs: item.refs }\"> </ng-template>\n</div>\n" }]
|
|
117
117
|
}], ctorParameters: () => [{ type: i1.GanttDragContainer }, { type: i2.GanttBarDrag }, { type: i0.ElementRef }, { type: i3.GanttUpper, decorators: [{
|
|
@@ -23,10 +23,10 @@ export class NgxGanttBaselineComponent {
|
|
|
23
23
|
itemElement.style.bottom = '2px';
|
|
24
24
|
itemElement.style.width = this.baselineItem.refs.width + 'px';
|
|
25
25
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
27
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttBaselineComponent, deps: [{ token: i0.ElementRef }, { token: GANTT_UPPER_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: NgxGanttBaselineComponent, isStandalone: true, selector: "ngx-gantt-baseline,gantt-baseline", inputs: { baselineItem: "baselineItem", template: "template" }, host: { properties: { "class.gantt-baseline": "this.ganttBaselineClass" } }, ngImport: i0, template: "<div #content *ngIf=\"baselineItem\" class=\"baseline-content\">\n <ng-template\n [ngTemplateOutlet]=\"template\"\n [ngTemplateOutletContext]=\"{ item: baselineItem.origin, refs: baselineItem.refs }\"\n ></ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
|
|
28
28
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: NgxGanttBaselineComponent, decorators: [{
|
|
30
30
|
type: Component,
|
|
31
31
|
args: [{ selector: 'ngx-gantt-baseline,gantt-baseline', standalone: true, imports: [NgIf, NgTemplateOutlet], template: "<div #content *ngIf=\"baselineItem\" class=\"baseline-content\">\n <ng-template\n [ngTemplateOutlet]=\"template\"\n [ngTemplateOutletContext]=\"{ item: baselineItem.origin, refs: baselineItem.refs }\"\n ></ng-template>\n</div>\n" }]
|
|
32
32
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.GanttUpper, decorators: [{
|
|
@@ -4,7 +4,7 @@ import { take, takeUntil } from 'rxjs/operators';
|
|
|
4
4
|
import { isNumber } from '../../../utils/helpers';
|
|
5
5
|
import { GANTT_UPPER_TOKEN } from '../../../gantt-upper';
|
|
6
6
|
import { GanttViewType } from './../../../class/view-type';
|
|
7
|
-
import {
|
|
7
|
+
import { todayBorderRadius } from '../../../gantt.styles';
|
|
8
8
|
import { NgIf, NgFor } from '@angular/common';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../../../gantt-upper";
|
|
@@ -18,7 +18,6 @@ export class GanttCalendarGridComponent {
|
|
|
18
18
|
this.ngZone = ngZone;
|
|
19
19
|
this.elementRef = elementRef;
|
|
20
20
|
this.unsubscribe$ = new Subject();
|
|
21
|
-
this.headerHeight = headerHeight;
|
|
22
21
|
this.mainHeight = mainHeight;
|
|
23
22
|
this.todayBorderRadius = todayBorderRadius;
|
|
24
23
|
this.viewTypes = GanttViewType;
|
|
@@ -55,12 +54,12 @@ export class GanttCalendarGridComponent {
|
|
|
55
54
|
this.unsubscribe$.next();
|
|
56
55
|
this.unsubscribe$.complete();
|
|
57
56
|
}
|
|
58
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
59
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
57
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttCalendarGridComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttCalendarGridComponent, isStandalone: true, selector: "gantt-calendar-grid", host: { properties: { "class": "this.className" } }, ngImport: i0, template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-line\" *ngIf=\"ganttUpper.showTodayLine\"> </span>\n</div>\n\n<svg class=\"gantt-calendar-grid-main\" [attr.width]=\"view.width\" [attr.height]=\"ganttUpper.styles.headerHeight - 1\">\n <g>\n <g *ngIf=\"view.showTimeline\">\n <line\n *ngFor=\"let point of view.secondaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.cellWidth\"\n [attr.x2]=\"(i + 1) * view.cellWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"secondary-line\"\n ></line>\n </g>\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n </g>\n</svg>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
60
59
|
}
|
|
61
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttCalendarGridComponent, decorators: [{
|
|
62
61
|
type: Component,
|
|
63
|
-
args: [{ selector: 'gantt-calendar-grid', standalone: true, imports: [NgIf, NgFor], template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-line\" *ngIf=\"ganttUpper.showTodayLine\"> </span>\n</div>\n\n<svg class=\"gantt-calendar-grid-main\" [attr.width]=\"view.width\" [attr.height]=\"headerHeight - 1\">\n <g>\n <g *ngIf=\"view.showTimeline\">\n <line\n *ngFor=\"let point of view.secondaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.cellWidth\"\n [attr.x2]=\"(i + 1) * view.cellWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"secondary-line\"\n ></line>\n </g>\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n </g>\n</svg>\n" }]
|
|
62
|
+
args: [{ selector: 'gantt-calendar-grid', standalone: true, imports: [NgIf, NgFor], template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-line\" *ngIf=\"ganttUpper.showTodayLine\"> </span>\n</div>\n\n<svg class=\"gantt-calendar-grid-main\" [attr.width]=\"view.width\" [attr.height]=\"ganttUpper.styles.headerHeight - 1\">\n <g>\n <g *ngIf=\"view.showTimeline\">\n <line\n *ngFor=\"let point of view.secondaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.cellWidth\"\n [attr.x2]=\"(i + 1) * view.cellWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"secondary-line\"\n ></line>\n </g>\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"mainHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n </g>\n</svg>\n" }]
|
|
64
63
|
}], ctorParameters: () => [{ type: i1.GanttUpper, decorators: [{
|
|
65
64
|
type: Inject,
|
|
66
65
|
args: [GANTT_UPPER_TOKEN]
|
|
@@ -68,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
68
67
|
type: HostBinding,
|
|
69
68
|
args: ['class']
|
|
70
69
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItZ3JpZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9nYW50dC9zcmMvY29tcG9uZW50cy9jYWxlbmRhci9ncmlkL2NhbGVuZGFyLWdyaWQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ2FudHQvc3JjL2NvbXBvbmVudHMvY2FsZW5kYXIvZ3JpZC9jYWxlbmRhci1ncmlkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsV0FBVyxFQUErQyxNQUFNLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFFaEksT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVqRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFbEQsT0FBTyxFQUFFLGlCQUFpQixFQUFjLE1BQU0sc0JBQXNCLENBQUM7QUFDckUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQUU5QyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUM7QUFReEIsTUFBTSxPQUFPLDBCQUEwQjtJQUNuQyxJQUFJLElBQUk7UUFDSixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFXRCxZQUNzQyxVQUFzQixFQUNoRCxNQUFjLEVBQ2QsVUFBbUM7UUFGVCxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ2hELFdBQU0sR0FBTixNQUFNLENBQVE7UUFDZCxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQWJ2QyxpQkFBWSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFFM0MsZUFBVSxHQUFHLFVBQVUsQ0FBQztRQUV4QixzQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztRQUV0QyxjQUFTLEdBQUcsYUFBYSxDQUFDO1FBRUosY0FBUyxHQUFHLG9DQUFvQyxDQUFDO0lBTXBFLENBQUM7SUFFSixhQUFhO1FBQ1QsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNyQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDLENBQUMsQ0FBZ0IsQ0FBQztRQUN4SCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQWdCLENBQUM7UUFFbEcsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUNkLElBQUksSUFBSSxFQUFFLENBQUM7Z0JBQ1AsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLElBQUksQ0FBQztnQkFDM0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsS0FBSyxDQUFDO2dCQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUMsVUFBVSxJQUFJLENBQUM7WUFDM0MsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ0osUUFBUSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBQ3BDLENBQUM7SUFDTCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzlDLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7aUJBQ3pELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO2lCQUNsQyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNaLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN6QixDQUFDLENBQUMsQ0FBQztRQUNYLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFxQixFQUFFLEtBQWE7UUFDeEMsT0FBTyxLQUFLLENBQUMsSUFBSSxJQUFJLEtBQUssQ0FBQztJQUMvQixDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDekIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNqQyxDQUFDOzhHQXJEUSwwQkFBMEIsa0JBZXZCLGlCQUFpQjtrR0FmcEIsMEJBQTBCLG9JQ3BCdkMsbytCQTRCQSw0Q0RWYyxJQUFJLDZGQUFFLEtBQUs7OzJGQUVaLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDSSxxQkFBcUIsY0FFbkIsSUFBSSxXQUNQLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQzs7MEJBaUJqQixNQUFNOzJCQUFDLGlCQUFpQjt1RkFIUCxTQUFTO3NCQUE5QixXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSG9zdEJpbmRpbmcsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcywgT25EZXN0cm95LCBOZ1pvbmUsIEluamVjdCwgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgR2FudHREYXRlUG9pbnQgfSBmcm9tICcuLi8uLi8uLi9jbGFzcy9kYXRlLXBvaW50JztcbmltcG9ydCB7IFN1YmplY3QsIG1lcmdlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IGlzTnVtYmVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvaGVscGVycyc7XG5cbmltcG9ydCB7IEdBTlRUX1VQUEVSX1RPS0VOLCBHYW50dFVwcGVyIH0gZnJvbSAnLi4vLi4vLi4vZ2FudHQtdXBwZXInO1xuaW1wb3J0IHsgR2FudHRWaWV3VHlwZSB9IGZyb20gJy4vLi4vLi4vLi4vY2xhc3Mvdmlldy10eXBlJztcbmltcG9ydCB7IHRvZGF5Qm9yZGVyUmFkaXVzIH0gZnJvbSAnLi4vLi4vLi4vZ2FudHQuc3R5bGVzJztcbmltcG9ydCB7IE5nSWYsIE5nRm9yIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuY29uc3QgbWFpbkhlaWdodCA9IDUwMDA7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZ2FudHQtY2FsZW5kYXItZ3JpZCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhbGVuZGFyLWdyaWQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW05nSWYsIE5nRm9yXVxufSlcbmV4cG9ydCBjbGFzcyBHYW50dENhbGVuZGFyR3JpZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBnZXQgdmlldygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZ2FudHRVcHBlci52aWV3O1xuICAgIH1cbiAgICBwcml2YXRlIHVuc3Vic2NyaWJlJCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgICBtYWluSGVpZ2h0ID0gbWFpbkhlaWdodDtcblxuICAgIHRvZGF5Qm9yZGVyUmFkaXVzID0gdG9kYXlCb3JkZXJSYWRpdXM7XG5cbiAgICB2aWV3VHlwZXMgPSBHYW50dFZpZXdUeXBlO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpIGNsYXNzTmFtZSA9IGBnYW50dC1jYWxlbmRhciBnYW50dC1jYWxlbmRhci1ncmlkYDtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KEdBTlRUX1VQUEVSX1RPS0VOKSBwdWJsaWMgZ2FudHRVcHBlcjogR2FudHRVcHBlcixcbiAgICAgICAgcHJpdmF0ZSBuZ1pvbmU6IE5nWm9uZSxcbiAgICAgICAgcHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PlxuICAgICkge31cblxuICAgIHNldFRvZGF5UG9pbnQoKSB7XG4gICAgICAgIGNvbnN0IHggPSB0aGlzLnZpZXcuZ2V0VG9kYXlYUG9pbnQoKTtcbiAgICAgICAgY29uc3QgdG9kYXlFbGUgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5nZXRFbGVtZW50c0J5Q2xhc3NOYW1lKCdnYW50dC1jYWxlbmRhci10b2RheS1vdmVybGF5JylbMF0gYXMgSFRNTEVsZW1lbnQ7XG4gICAgICAgIGNvbnN0IGxpbmUgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5nZXRFbGVtZW50c0J5Q2xhc3NOYW1lKCd0b2RheS1saW5lJylbMF0gYXMgSFRNTEVsZW1lbnQ7XG5cbiAgICAgICAgaWYgKGlzTnVtYmVyKHgpKSB7XG4gICAgICAgICAgICBpZiAobGluZSkge1xuICAgICAgICAgICAgICAgIGxpbmUuc3R5bGUubGVmdCA9IGAke3h9cHhgO1xuICAgICAgICAgICAgICAgIGxpbmUuc3R5bGUudG9wID0gYDBweGA7XG4gICAgICAgICAgICAgICAgbGluZS5zdHlsZS5ib3R0b20gPSBgJHstbWFpbkhlaWdodH1weGA7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0b2RheUVsZS5zdHlsZS5kaXNwbGF5ID0gJ25vbmUnO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMubmdab25lLm9uU3RhYmxlLnBpcGUodGFrZSgxKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIG1lcmdlKHRoaXMuZ2FudHRVcHBlci52aWV3Q2hhbmdlLCB0aGlzLmdhbnR0VXBwZXIudmlldy5zdGFydCQpXG4gICAgICAgICAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMudW5zdWJzY3JpYmUkKSlcbiAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5zZXRUb2RheVBvaW50KCk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHRyYWNrQnkocG9pbnQ6IEdhbnR0RGF0ZVBvaW50LCBpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiBwb2ludC50ZXh0IHx8IGluZGV4O1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCkge1xuICAgICAgICB0aGlzLnVuc3Vic2NyaWJlJC5uZXh0KCk7XG4gICAgICAgIHRoaXMudW5zdWJzY3JpYmUkLmNvbXBsZXRlKCk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImdhbnR0LWNhbGVuZGFyLXRvZGF5LW92ZXJsYXlcIiBbc3R5bGUud2lkdGgucHhdPVwidmlldy53aWR0aFwiPlxuICA8c3BhbiBjbGFzcz1cInRvZGF5LWxpbmVcIiAqbmdJZj1cImdhbnR0VXBwZXIuc2hvd1RvZGF5TGluZVwiPiA8L3NwYW4+XG48L2Rpdj5cblxuPHN2ZyBjbGFzcz1cImdhbnR0LWNhbGVuZGFyLWdyaWQtbWFpblwiIFthdHRyLndpZHRoXT1cInZpZXcud2lkdGhcIiBbYXR0ci5oZWlnaHRdPVwiZ2FudHRVcHBlci5zdHlsZXMuaGVhZGVySGVpZ2h0IC0gMVwiPlxuICA8Zz5cbiAgICA8ZyAqbmdJZj1cInZpZXcuc2hvd1RpbWVsaW5lXCI+XG4gICAgICA8bGluZVxuICAgICAgICAqbmdGb3I9XCJsZXQgcG9pbnQgb2Ygdmlldy5zZWNvbmRhcnlEYXRlUG9pbnRzOyBsZXQgaSA9IGluZGV4OyB0cmFja0J5OiB0cmFja0J5XCJcbiAgICAgICAgW2F0dHIueDFdPVwiKGkgKyAxKSAqIHZpZXcuY2VsbFdpZHRoXCJcbiAgICAgICAgW2F0dHIueDJdPVwiKGkgKyAxKSAqIHZpZXcuY2VsbFdpZHRoXCJcbiAgICAgICAgW2F0dHIueTFdPVwiMFwiXG4gICAgICAgIFthdHRyLnkyXT1cIm1haW5IZWlnaHRcIlxuICAgICAgICBjbGFzcz1cInNlY29uZGFyeS1saW5lXCJcbiAgICAgID48L2xpbmU+XG4gICAgPC9nPlxuICAgIDxnPlxuICAgICAgPGxpbmVcbiAgICAgICAgKm5nRm9yPVwibGV0IHBvaW50IG9mIHZpZXcucHJpbWFyeURhdGVQb2ludHM7IGxldCBpID0gaW5kZXg7IHRyYWNrQnk6IHRyYWNrQnlcIlxuICAgICAgICBbYXR0ci54MV09XCIoaSArIDEpICogdmlldy5wcmltYXJ5V2lkdGhcIlxuICAgICAgICBbYXR0ci54Ml09XCIoaSArIDEpICogdmlldy5wcmltYXJ5V2lkdGhcIlxuICAgICAgICBbYXR0ci55MV09XCIwXCJcbiAgICAgICAgW2F0dHIueTJdPVwibWFpbkhlaWdodFwiXG4gICAgICAgIGNsYXNzPVwicHJpbWFyeS1saW5lXCJcbiAgICAgID48L2xpbmU+XG4gICAgPC9nPlxuICA8L2c+XG48L3N2Zz5cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Component, HostBinding, Inject } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { todayHeight, todayWidth } from '../../../gantt.styles';
|
|
3
3
|
import { GANTT_UPPER_TOKEN } from '../../../gantt-upper';
|
|
4
4
|
import { GanttViewType } from '../../../class';
|
|
5
5
|
import { take, takeUntil } from 'rxjs/operators';
|
|
@@ -13,16 +13,19 @@ export class GanttCalendarHeaderComponent {
|
|
|
13
13
|
get view() {
|
|
14
14
|
return this.ganttUpper.view;
|
|
15
15
|
}
|
|
16
|
+
get height() {
|
|
17
|
+
return this.ganttUpper.styles.headerHeight + 'px';
|
|
18
|
+
}
|
|
16
19
|
constructor(ganttUpper, ngZone, elementRef) {
|
|
17
20
|
this.ganttUpper = ganttUpper;
|
|
18
21
|
this.ngZone = ngZone;
|
|
19
22
|
this.elementRef = elementRef;
|
|
20
23
|
this.unsubscribe$ = new Subject();
|
|
21
|
-
this.headerHeight = headerHeight;
|
|
22
24
|
this.viewTypes = GanttViewType;
|
|
23
25
|
this.className = `gantt-calendar gantt-calendar-header`;
|
|
24
26
|
}
|
|
25
27
|
ngOnInit() {
|
|
28
|
+
// 头部日期定位
|
|
26
29
|
this.ngZone.onStable.pipe(take(1)).subscribe(() => {
|
|
27
30
|
merge(this.ganttUpper.viewChange, this.ganttUpper.view.start$)
|
|
28
31
|
.pipe(takeUntil(this.unsubscribe$))
|
|
@@ -40,7 +43,7 @@ export class GanttCalendarHeaderComponent {
|
|
|
40
43
|
if (isNumber(x)) {
|
|
41
44
|
if (rect) {
|
|
42
45
|
rect.style.left = `${x - todayWidth / 2}px`;
|
|
43
|
-
rect.style.top = `${headerHeight - todayHeight}px`;
|
|
46
|
+
rect.style.top = `${this.ganttUpper.styles.headerHeight - todayHeight}px`;
|
|
44
47
|
rect.innerHTML = today.toString();
|
|
45
48
|
}
|
|
46
49
|
}
|
|
@@ -51,17 +54,20 @@ export class GanttCalendarHeaderComponent {
|
|
|
51
54
|
trackBy(point, index) {
|
|
52
55
|
return point.text || index;
|
|
53
56
|
}
|
|
54
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
55
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
57
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttCalendarHeaderComponent, deps: [{ token: GANTT_UPPER_TOKEN }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttCalendarHeaderComponent, isStandalone: true, selector: "gantt-calendar-header", host: { properties: { "class": "this.className", "style.height": "this.height" } }, ngImport: i0, template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-rect\" [hidden]=\"ganttUpper.viewType !== viewTypes.day\"> </span>\n</div>\n<svg [attr.width]=\"view.width\" [attr.height]=\"ganttUpper.styles.headerHeight\">\n <g>\n <text\n class=\"primary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n *ngFor=\"let point of view.primaryDatePoints; trackBy: trackBy\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n <ng-container *ngFor=\"let point of view.secondaryDatePoints; trackBy: trackBy\">\n <text\n class=\"secondary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n </ng-container>\n\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"ganttUpper.styles.headerHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n\n <g>\n <line\n [attr.x1]=\"0\"\n [attr.x2]=\"view.width\"\n [attr.y1]=\"ganttUpper.styles.headerHeight\"\n [attr.y2]=\"ganttUpper.styles.headerHeight\"\n class=\"header-line\"\n ></line>\n </g>\n </g>\n</svg>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
56
59
|
}
|
|
57
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttCalendarHeaderComponent, decorators: [{
|
|
58
61
|
type: Component,
|
|
59
|
-
args: [{ selector: 'gantt-calendar-header', standalone: true, imports: [NgFor, NgStyle], template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-rect\" [hidden]=\"ganttUpper.viewType !== viewTypes.day\"> </span>\n</div>\n<svg [attr.width]=\"view.width\" [attr.height]=\"headerHeight\">\n <g>\n <text\n class=\"primary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n *ngFor=\"let point of view.primaryDatePoints; trackBy: trackBy\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n <ng-container *ngFor=\"let point of view.secondaryDatePoints; trackBy: trackBy\">\n <text\n class=\"secondary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n </ng-container>\n\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"headerHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n\n <g>\n <line
|
|
62
|
+
args: [{ selector: 'gantt-calendar-header', standalone: true, imports: [NgFor, NgStyle], template: "<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n <span class=\"today-rect\" [hidden]=\"ganttUpper.viewType !== viewTypes.day\"> </span>\n</div>\n<svg [attr.width]=\"view.width\" [attr.height]=\"ganttUpper.styles.headerHeight\">\n <g>\n <text\n class=\"primary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n *ngFor=\"let point of view.primaryDatePoints; trackBy: trackBy\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n <ng-container *ngFor=\"let point of view.secondaryDatePoints; trackBy: trackBy\">\n <text\n class=\"secondary-text\"\n [ngStyle]=\"point.style\"\n [class.today]=\"point.additions?.isToday\"\n [class.weekend]=\"point.additions?.isWeekend\"\n [attr.x]=\"point.x\"\n [attr.y]=\"point.y\"\n >\n {{ point.text }}\n </text>\n </ng-container>\n\n <g>\n <line\n *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n [attr.x1]=\"(i + 1) * view.primaryWidth\"\n [attr.x2]=\"(i + 1) * view.primaryWidth\"\n [attr.y1]=\"0\"\n [attr.y2]=\"ganttUpper.styles.headerHeight\"\n class=\"primary-line\"\n ></line>\n </g>\n\n <g>\n <line\n [attr.x1]=\"0\"\n [attr.x2]=\"view.width\"\n [attr.y1]=\"ganttUpper.styles.headerHeight\"\n [attr.y2]=\"ganttUpper.styles.headerHeight\"\n class=\"header-line\"\n ></line>\n </g>\n </g>\n</svg>\n" }]
|
|
60
63
|
}], ctorParameters: () => [{ type: i1.GanttUpper, decorators: [{
|
|
61
64
|
type: Inject,
|
|
62
65
|
args: [GANTT_UPPER_TOKEN]
|
|
63
66
|
}] }, { type: i0.NgZone }, { type: i0.ElementRef }], propDecorators: { className: [{
|
|
64
67
|
type: HostBinding,
|
|
65
68
|
args: ['class']
|
|
69
|
+
}], height: [{
|
|
70
|
+
type: HostBinding,
|
|
71
|
+
args: ['style.height']
|
|
66
72
|
}] } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-header.component.js","sourceRoot":"","sources":["../../../../../../packages/gantt/src/components/calendar/header/calendar-header.component.ts","../../../../../../packages/gantt/src/components/calendar/header/calendar-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostBinding, Inject, NgZone, ElementRef } from '@angular/core';\nimport { GanttDatePoint } from '../../../class/date-point';\nimport { todayHeight, todayWidth } from '../../../gantt.styles';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../../gantt-upper';\nimport { GanttViewType } from '../../../class';\nimport { take, takeUntil } from 'rxjs/operators';\nimport { Subject, merge } from 'rxjs';\nimport { GanttDate } from '../../../utils/date';\nimport { isNumber } from '../../../utils/helpers';\nimport { NgFor, NgStyle } from '@angular/common';\n\n@Component({\n    selector: 'gantt-calendar-header',\n    templateUrl: './calendar-header.component.html',\n    standalone: true,\n    imports: [NgFor, NgStyle]\n})\nexport class GanttCalendarHeaderComponent implements OnInit {\n    get view() {\n        return this.ganttUpper.view;\n    }\n\n    private unsubscribe$ = new Subject();\n\n    viewTypes = GanttViewType;\n\n    @HostBinding('class') className = `gantt-calendar gantt-calendar-header`;\n\n    @HostBinding('style.height')\n    get height() {\n        return this.ganttUpper.styles.headerHeight + 'px';\n    }\n\n    constructor(\n        @Inject(GANTT_UPPER_TOKEN) public ganttUpper: GanttUpper,\n        private ngZone: NgZone,\n        private elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    ngOnInit() {\n        // 头部日期定位\n        this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n            merge(this.ganttUpper.viewChange, this.ganttUpper.view.start$)\n                .pipe(takeUntil(this.unsubscribe$))\n                .subscribe(() => {\n                    if (this.ganttUpper.viewType === GanttViewType.day) this.setTodayPoint();\n                });\n        });\n    }\n\n    setTodayPoint() {\n        const x = this.view.getTodayXPoint();\n        const today = new GanttDate().getDate();\n        const todayEle = this.elementRef.nativeElement.getElementsByClassName('gantt-calendar-today-overlay')[0] as HTMLElement;\n        const rect = this.elementRef.nativeElement.getElementsByClassName('today-rect')[0] as HTMLElement;\n\n        if (isNumber(x)) {\n            if (rect) {\n                rect.style.left = `${x - todayWidth / 2}px`;\n                rect.style.top = `${this.ganttUpper.styles.headerHeight - todayHeight}px`;\n                rect.innerHTML = today.toString();\n            }\n        } else {\n            todayEle.style.display = 'none';\n        }\n    }\n\n    trackBy(point: GanttDatePoint, index: number) {\n        return point.text || index;\n    }\n}\n","<div class=\"gantt-calendar-today-overlay\" [style.width.px]=\"view.width\">\n  <span class=\"today-rect\" [hidden]=\"ganttUpper.viewType !== viewTypes.day\"> </span>\n</div>\n<svg [attr.width]=\"view.width\" [attr.height]=\"ganttUpper.styles.headerHeight\">\n  <g>\n    <text\n      class=\"primary-text\"\n      [ngStyle]=\"point.style\"\n      [class.today]=\"point.additions?.isToday\"\n      [class.weekend]=\"point.additions?.isWeekend\"\n      *ngFor=\"let point of view.primaryDatePoints; trackBy: trackBy\"\n      [attr.x]=\"point.x\"\n      [attr.y]=\"point.y\"\n    >\n      {{ point.text }}\n    </text>\n    <ng-container *ngFor=\"let point of view.secondaryDatePoints; trackBy: trackBy\">\n      <text\n        class=\"secondary-text\"\n        [ngStyle]=\"point.style\"\n        [class.today]=\"point.additions?.isToday\"\n        [class.weekend]=\"point.additions?.isWeekend\"\n        [attr.x]=\"point.x\"\n        [attr.y]=\"point.y\"\n      >\n        {{ point.text }}\n      </text>\n    </ng-container>\n\n    <g>\n      <line\n        *ngFor=\"let point of view.primaryDatePoints; let i = index; trackBy: trackBy\"\n        [attr.x1]=\"(i + 1) * view.primaryWidth\"\n        [attr.x2]=\"(i + 1) * view.primaryWidth\"\n        [attr.y1]=\"0\"\n        [attr.y2]=\"ganttUpper.styles.headerHeight\"\n        class=\"primary-line\"\n      ></line>\n    </g>\n\n    <g>\n      <line\n        [attr.x1]=\"0\"\n        [attr.x2]=\"view.width\"\n        [attr.y1]=\"ganttUpper.styles.headerHeight\"\n        [attr.y2]=\"ganttUpper.styles.headerHeight\"\n        class=\"header-line\"\n      ></line>\n    </g>\n  </g>\n</svg>\n"]}
|
|
@@ -1,13 +1,21 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { GANTT_UPPER_TOKEN } from '../../gantt-upper';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../gantt-upper";
|
|
3
5
|
export class GanttDragBackdropComponent {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
+
constructor(ganttUpper) {
|
|
7
|
+
this.ganttUpper = ganttUpper;
|
|
8
|
+
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttDragBackdropComponent, deps: [{ token: GANTT_UPPER_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: GanttDragBackdropComponent, isStandalone: true, selector: "gantt-drag-backdrop", host: { classAttribute: "gantt-drag-backdrop" }, ngImport: i0, template: "<div class=\"gantt-drag-mask\" [style.top.px]=\"ganttUpper.styles.headerHeight\">\n <div class=\"date-range\">\n <span class=\"start\"></span>\n <span class=\"end\"></span>\n </div>\n</div>\n" }); }
|
|
6
11
|
}
|
|
7
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: GanttDragBackdropComponent, decorators: [{
|
|
8
13
|
type: Component,
|
|
9
14
|
args: [{ selector: 'gantt-drag-backdrop', host: {
|
|
10
15
|
class: 'gantt-drag-backdrop'
|
|
11
|
-
}, standalone: true, template: "<div class=\"gantt-drag-mask\">\n <div class=\"date-range\">\n <span class=\"start\"></span>\n <span class=\"end\"></span>\n </div>\n</div>\n" }]
|
|
12
|
-
}]
|
|
13
|
-
|
|
16
|
+
}, standalone: true, template: "<div class=\"gantt-drag-mask\" [style.top.px]=\"ganttUpper.styles.headerHeight\">\n <div class=\"date-range\">\n <span class=\"start\"></span>\n <span class=\"end\"></span>\n </div>\n</div>\n" }]
|
|
17
|
+
}], ctorParameters: () => [{ type: i1.GanttUpper, decorators: [{
|
|
18
|
+
type: Inject,
|
|
19
|
+
args: [GANTT_UPPER_TOKEN]
|
|
20
|
+
}] }] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1iYWNrZHJvcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9nYW50dC9zcmMvY29tcG9uZW50cy9kcmFnLWJhY2tkcm9wL2RyYWctYmFja2Ryb3AuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ2FudHQvc3JjL2NvbXBvbmVudHMvZHJhZy1iYWNrZHJvcC9kcmFnLWJhY2tkcm9wLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxpQkFBaUIsRUFBYyxNQUFNLG1CQUFtQixDQUFDOzs7QUFTbEUsTUFBTSxPQUFPLDBCQUEwQjtJQUNuQyxZQUE4QyxVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO0lBQUcsQ0FBQzs4R0FEL0QsMEJBQTBCLGtCQUNmLGlCQUFpQjtrR0FENUIsMEJBQTBCLGdJQ1Z2Qyx5TUFNQTs7MkZESWEsMEJBQTBCO2tCQVJ0QyxTQUFTOytCQUNJLHFCQUFxQixRQUV6Qjt3QkFDRixLQUFLLEVBQUUscUJBQXFCO3FCQUMvQixjQUNXLElBQUk7OzBCQUdILE1BQU07MkJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEdBTlRUX1VQUEVSX1RPS0VOLCBHYW50dFVwcGVyIH0gZnJvbSAnLi4vLi4vZ2FudHQtdXBwZXInO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdnYW50dC1kcmFnLWJhY2tkcm9wJyxcbiAgICB0ZW1wbGF0ZVVybDogYC4vZHJhZy1iYWNrZHJvcC5jb21wb25lbnQuaHRtbGAsXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ2dhbnR0LWRyYWctYmFja2Ryb3AnXG4gICAgfSxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIEdhbnR0RHJhZ0JhY2tkcm9wQ29tcG9uZW50IHtcbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KEdBTlRUX1VQUEVSX1RPS0VOKSBwdWJsaWMgZ2FudHRVcHBlcjogR2FudHRVcHBlcikge31cbn1cbiIsIjxkaXYgY2xhc3M9XCJnYW50dC1kcmFnLW1hc2tcIiBbc3R5bGUudG9wLnB4XT1cImdhbnR0VXBwZXIuc3R5bGVzLmhlYWRlckhlaWdodFwiPlxuICA8ZGl2IGNsYXNzPVwiZGF0ZS1yYW5nZVwiPlxuICAgIDxzcGFuIGNsYXNzPVwic3RhcnRcIj48L3NwYW4+XG4gICAgPHNwYW4gY2xhc3M9XCJlbmRcIj48L3NwYW4+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|