@worktile/gantt 18.0.3 → 18.0.4
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.
|
@@ -54,7 +54,7 @@ export class NgxGanttBarComponent extends GanttItemUpper {
|
|
|
54
54
|
// using `zone-patch-rxjs` because it'll trigger a change detection when it unsubscribes.
|
|
55
55
|
this.ngZone.runOutsideAngular(() => {
|
|
56
56
|
onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
|
|
57
|
-
this.drag.
|
|
57
|
+
this.drag.initialize(this.elementRef, this.item, this.ganttUpper);
|
|
58
58
|
});
|
|
59
59
|
});
|
|
60
60
|
this.setContentBackground();
|
|
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
129
129
|
type: ViewChildren,
|
|
130
130
|
args: ['handle']
|
|
131
131
|
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/bar/bar.component.ts","../../../../../packages/gantt/src/components/bar/bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    HostBinding,\n    ElementRef,\n    OnChanges,\n    OnDestroy,\n    Inject,\n    ViewChild,\n    Output,\n    EventEmitter,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    NgZone,\n    SimpleChanges\n} from '@angular/core';\nimport { from, fromEvent, merge, Observable } from 'rxjs';\nimport { startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { GanttBarDrag } from './bar-drag';\nimport { hexToRgb } from '../../utils/helpers';\nimport { GanttDragContainer } from '../../gantt-drag-container';\nimport { barBackground } from '../../gantt.styles';\nimport { GanttBarClickEvent } from '../../class';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../gantt-upper';\nimport { GanttItemUpper } from '../../gantt-item-upper';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\n\nfunction linearGradient(sideOrCorner: string, color: string, stop: string) {\n    return `linear-gradient(${sideOrCorner},${color} 0%,${stop} 40%)`;\n}\n\n@Component({\n    selector: 'ngx-gantt-bar,gantt-bar',\n    templateUrl: './bar.component.html',\n    providers: [GanttBarDrag],\n    standalone: true,\n    imports: [NgIf, NgTemplateOutlet]\n})\nexport class NgxGanttBarComponent extends GanttItemUpper implements OnInit, AfterViewInit, OnChanges, OnDestroy {\n    @Output() barClick = new EventEmitter<GanttBarClickEvent>();\n\n    @ViewChild('content') contentElementRef: ElementRef<HTMLDivElement>;\n\n    @HostBinding('class.gantt-bar') ganttItemClass = true;\n\n    @ViewChildren('handle') handles: QueryList<ElementRef<HTMLElement>>;\n\n    constructor(\n        private dragContainer: GanttDragContainer,\n        private drag: GanttBarDrag,\n        elementRef: ElementRef<HTMLDivElement>,\n        @Inject(GANTT_UPPER_TOKEN) public override ganttUpper: GanttUpper,\n        private ngZone: NgZone\n    ) {\n        super(elementRef, ganttUpper);\n    }\n\n    override ngOnInit() {\n        super.ngOnInit();\n        this.dragContainer.dragStarted.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.elementRef.nativeElement.style.pointerEvents = 'none';\n        });\n        this.dragContainer.dragEnded.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.elementRef.nativeElement.style.pointerEvents = '';\n            this.setContentBackground();\n        });\n    }\n\n    override ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        if (!this.firstChange) {\n            this.drag.updateItem(this.item);\n\n            if (\n                changes.item.currentValue.refs?.width !== changes.item.previousValue.refs?.width ||\n                changes.item.currentValue.color !== changes.item.previousValue.color ||\n                changes.item.currentValue.start?.value !== changes.item.previousValue.start?.value ||\n                changes.item.currentValue.end?.value !== changes.item.previousValue.end?.value\n            ) {\n                this.setContentBackground();\n            }\n        }\n    }\n\n    ngAfterViewInit() {\n        // Note: the zone may be nooped through `BootstrapOptions` when bootstrapping the root module. This means\n        // the `onStable` will never emit any value.\n        const onStable$ = this.ngZone.isStable ? from(Promise.resolve()) : this.ngZone.onStable.pipe(take(1));\n        // Normally this isn't in the zone, but it can cause performance regressions for apps\n        // using `zone-patch-rxjs` because it'll trigger a change detection when it unsubscribes.\n        this.ngZone.runOutsideAngular(() => {\n            onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n                this.drag.createDrags(this.elementRef, this.item, this.ganttUpper);\n            });\n        });\n\n        this.setContentBackground();\n\n        this.handles.changes\n            .pipe(\n                startWith(this.handles),\n                switchMap(\n                    () =>\n                        // Note: we need to explicitly subscribe outside of the Angular zone since `addEventListener`\n                        // is called when the `fromEvent` is subscribed.\n                        new Observable<Event>((subscriber) =>\n                            this.ngZone.runOutsideAngular(() =>\n                                merge(...this.handles.toArray().map((handle) => fromEvent(handle.nativeElement, 'mousedown'))).subscribe(\n                                    subscriber\n                                )\n                            )\n                        )\n                ),\n                takeUntil(this.unsubscribe$)\n            )\n            .subscribe((event) => {\n                event.stopPropagation();\n            });\n    }\n\n    onBarClick(event: Event) {\n        this.barClick.emit({ event, item: this.item.origin });\n    }\n\n    private setContentBackground() {\n        if (this.item.refs?.width) {\n            const contentElement = this.contentElementRef.nativeElement;\n            const color = this.item.color || barBackground;\n            const style: Partial<CSSStyleDeclaration> = this.item.barStyle || {};\n            const barElement = this.elementRef.nativeElement;\n\n            if (this.item.origin.start && this.item.origin.end) {\n                style.background = color;\n                style.borderRadius = '';\n            }\n            if (this.item.origin.start && !this.item.origin.end) {\n                style.background = linearGradient('to left', hexToRgb(color, 0.55), hexToRgb(color, 1));\n\n                const borderRadius = '4px 12.5px 12.5px 4px';\n                style.borderRadius = borderRadius;\n                barElement.style.borderRadius = borderRadius;\n            }\n            if (!this.item.origin.start && this.item.origin.end) {\n                style.background = linearGradient('to right', hexToRgb(color, 0.55), hexToRgb(color, 1));\n\n                const borderRadius = '12.5px 4px 4px 12.5px';\n                style.borderRadius = borderRadius;\n                barElement.style.borderRadius = borderRadius;\n            }\n            if (this.item.progress >= 0) {\n                const contentProgressElement = contentElement.querySelector('.gantt-bar-content-progress') as HTMLDivElement;\n                style.background = hexToRgb(color, 0.3);\n                style.borderRadius = '';\n                contentProgressElement.style.background = color;\n            }\n\n            for (const key in style) {\n                if (style.hasOwnProperty(key)) {\n                    contentElement.style[key] = style[key];\n                }\n            }\n        }\n    }\n\n    stopPropagation(event: Event) {\n        event.stopPropagation();\n    }\n}\n","<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"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"","sources":["../../../../../packages/gantt/src/components/bar/bar.component.ts","../../../../../packages/gantt/src/components/bar/bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,WAAW,EAIX,MAAM,EACN,SAAS,EACT,MAAM,EACN,YAAY,EAEZ,YAAY,EAIf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAE/C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAEnD,OAAO,EAAE,iBAAiB,EAAc,MAAM,mBAAmB,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;;;;;AAEzD,SAAS,cAAc,CAAC,YAAoB,EAAE,KAAa,EAAE,IAAY;IACrE,OAAO,mBAAmB,YAAY,IAAI,KAAK,OAAO,IAAI,OAAO,CAAC;AACtE,CAAC;AASD,MAAM,OAAO,oBAAqB,SAAQ,cAAc;IASpD,YACY,aAAiC,EACjC,IAAkB,EAC1B,UAAsC,EACK,UAAsB,EACzD,MAAc;QAEtB,KAAK,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QANtB,kBAAa,GAAb,aAAa,CAAoB;QACjC,SAAI,GAAJ,IAAI,CAAc;QAEiB,eAAU,GAAV,UAAU,CAAY;QACzD,WAAM,GAAN,MAAM,CAAQ;QAbhB,aAAQ,GAAG,IAAI,YAAY,EAAsB,CAAC;QAI5B,mBAAc,GAAG,IAAI,CAAC;IAYtD,CAAC;IAEQ,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7E,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,aAAa,GAAG,MAAM,CAAC;QAC/D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3E,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,aAAa,GAAG,EAAE,CAAC;YACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;IACP,CAAC;IAEQ,WAAW,CAAC,OAAsB;QACvC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAEhC,IACI,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK;gBAChF,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK;gBACpE,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK;gBAClF,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,KAAK,EAChF,CAAC;gBACC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAChC,CAAC;QACL,CAAC;IACL,CAAC;IAED,eAAe;QACX,yGAAyG;QACzG,4CAA4C;QAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACtG,qFAAqF;QACrF,yFAAyF;QACzF,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACxD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACtE,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,OAAO;aACf,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,SAAS,CACL,GAAG,EAAE;QACD,6FAA6F;QAC7F,gDAAgD;QAChD,IAAI,UAAU,CAAQ,CAAC,UAAU,EAAE,EAAE,CACjC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAC/B,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS,CACpG,UAAU,CACb,CACJ,CACJ,CACR,EACD,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC/B;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,KAAK,CAAC,eAAe,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,UAAU,CAAC,KAAY;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC1D,CAAC;IAEO,oBAAoB;QACxB,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC;YACxB,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;YAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,aAAa,CAAC;YAC/C,MAAM,KAAK,GAAiC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;YACrE,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YAEjD,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;gBACjD,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC;gBACzB,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC;YAC5B,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;gBAClD,KAAK,CAAC,UAAU,GAAG,cAAc,CAAC,SAAS,EAAE,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;gBAExF,MAAM,YAAY,GAAG,uBAAuB,CAAC;gBAC7C,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;gBAClC,UAAU,CAAC,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;YACjD,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;gBAClD,KAAK,CAAC,UAAU,GAAG,cAAc,CAAC,UAAU,EAAE,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;gBAEzF,MAAM,YAAY,GAAG,uBAAuB,CAAC;gBAC7C,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;gBAClC,UAAU,CAAC,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;YACjD,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE,CAAC;gBAC1B,MAAM,sBAAsB,GAAG,cAAc,CAAC,aAAa,CAAC,6BAA6B,CAAmB,CAAC;gBAC7G,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;gBACxC,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC;gBACxB,sBAAsB,CAAC,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC;YACpD,CAAC;YAED,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;gBACtB,IAAI,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;oBAC5B,cAAc,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;gBAC3C,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;IAED,eAAe,CAAC,KAAY;QACxB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;8GAhIQ,oBAAoB,0GAajB,iBAAiB;kGAbpB,oBAAoB,6KAJlB,CAAC,YAAY,CAAC,2PCnC7B,g2BAiBA,4CDoBc,IAAI,6FAAE,gBAAgB;;2FAEvB,oBAAoB;kBAPhC,SAAS;+BACI,yBAAyB,aAExB,CAAC,YAAY,CAAC,cACb,IAAI,WACP,CAAC,IAAI,EAAE,gBAAgB,CAAC;;0BAe5B,MAAM;2BAAC,iBAAiB;8DAZnB,QAAQ;sBAAjB,MAAM;gBAEe,iBAAiB;sBAAtC,SAAS;uBAAC,SAAS;gBAEY,cAAc;sBAA7C,WAAW;uBAAC,iBAAiB;gBAEN,OAAO;sBAA9B,YAAY;uBAAC,QAAQ","sourcesContent":["import {\n    Component,\n    OnInit,\n    HostBinding,\n    ElementRef,\n    OnChanges,\n    OnDestroy,\n    Inject,\n    ViewChild,\n    Output,\n    EventEmitter,\n    AfterViewInit,\n    ViewChildren,\n    QueryList,\n    NgZone,\n    SimpleChanges\n} from '@angular/core';\nimport { from, fromEvent, merge, Observable } from 'rxjs';\nimport { startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { GanttBarDrag } from './bar-drag';\nimport { hexToRgb } from '../../utils/helpers';\nimport { GanttDragContainer } from '../../gantt-drag-container';\nimport { barBackground } from '../../gantt.styles';\nimport { GanttBarClickEvent } from '../../class';\nimport { GANTT_UPPER_TOKEN, GanttUpper } from '../../gantt-upper';\nimport { GanttItemUpper } from '../../gantt-item-upper';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\n\nfunction linearGradient(sideOrCorner: string, color: string, stop: string) {\n    return `linear-gradient(${sideOrCorner},${color} 0%,${stop} 40%)`;\n}\n\n@Component({\n    selector: 'ngx-gantt-bar,gantt-bar',\n    templateUrl: './bar.component.html',\n    providers: [GanttBarDrag],\n    standalone: true,\n    imports: [NgIf, NgTemplateOutlet]\n})\nexport class NgxGanttBarComponent extends GanttItemUpper implements OnInit, AfterViewInit, OnChanges, OnDestroy {\n    @Output() barClick = new EventEmitter<GanttBarClickEvent>();\n\n    @ViewChild('content') contentElementRef: ElementRef<HTMLDivElement>;\n\n    @HostBinding('class.gantt-bar') ganttItemClass = true;\n\n    @ViewChildren('handle') handles: QueryList<ElementRef<HTMLElement>>;\n\n    constructor(\n        private dragContainer: GanttDragContainer,\n        private drag: GanttBarDrag,\n        elementRef: ElementRef<HTMLDivElement>,\n        @Inject(GANTT_UPPER_TOKEN) public override ganttUpper: GanttUpper,\n        private ngZone: NgZone\n    ) {\n        super(elementRef, ganttUpper);\n    }\n\n    override ngOnInit() {\n        super.ngOnInit();\n        this.dragContainer.dragStarted.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.elementRef.nativeElement.style.pointerEvents = 'none';\n        });\n        this.dragContainer.dragEnded.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n            this.elementRef.nativeElement.style.pointerEvents = '';\n            this.setContentBackground();\n        });\n    }\n\n    override ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        if (!this.firstChange) {\n            this.drag.updateItem(this.item);\n\n            if (\n                changes.item.currentValue.refs?.width !== changes.item.previousValue.refs?.width ||\n                changes.item.currentValue.color !== changes.item.previousValue.color ||\n                changes.item.currentValue.start?.value !== changes.item.previousValue.start?.value ||\n                changes.item.currentValue.end?.value !== changes.item.previousValue.end?.value\n            ) {\n                this.setContentBackground();\n            }\n        }\n    }\n\n    ngAfterViewInit() {\n        // Note: the zone may be nooped through `BootstrapOptions` when bootstrapping the root module. This means\n        // the `onStable` will never emit any value.\n        const onStable$ = this.ngZone.isStable ? from(Promise.resolve()) : this.ngZone.onStable.pipe(take(1));\n        // Normally this isn't in the zone, but it can cause performance regressions for apps\n        // using `zone-patch-rxjs` because it'll trigger a change detection when it unsubscribes.\n        this.ngZone.runOutsideAngular(() => {\n            onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n                this.drag.initialize(this.elementRef, this.item, this.ganttUpper);\n            });\n        });\n\n        this.setContentBackground();\n\n        this.handles.changes\n            .pipe(\n                startWith(this.handles),\n                switchMap(\n                    () =>\n                        // Note: we need to explicitly subscribe outside of the Angular zone since `addEventListener`\n                        // is called when the `fromEvent` is subscribed.\n                        new Observable<Event>((subscriber) =>\n                            this.ngZone.runOutsideAngular(() =>\n                                merge(...this.handles.toArray().map((handle) => fromEvent(handle.nativeElement, 'mousedown'))).subscribe(\n                                    subscriber\n                                )\n                            )\n                        )\n                ),\n                takeUntil(this.unsubscribe$)\n            )\n            .subscribe((event) => {\n                event.stopPropagation();\n            });\n    }\n\n    onBarClick(event: Event) {\n        this.barClick.emit({ event, item: this.item.origin });\n    }\n\n    private setContentBackground() {\n        if (this.item.refs?.width) {\n            const contentElement = this.contentElementRef.nativeElement;\n            const color = this.item.color || barBackground;\n            const style: Partial<CSSStyleDeclaration> = this.item.barStyle || {};\n            const barElement = this.elementRef.nativeElement;\n\n            if (this.item.origin.start && this.item.origin.end) {\n                style.background = color;\n                style.borderRadius = '';\n            }\n            if (this.item.origin.start && !this.item.origin.end) {\n                style.background = linearGradient('to left', hexToRgb(color, 0.55), hexToRgb(color, 1));\n\n                const borderRadius = '4px 12.5px 12.5px 4px';\n                style.borderRadius = borderRadius;\n                barElement.style.borderRadius = borderRadius;\n            }\n            if (!this.item.origin.start && this.item.origin.end) {\n                style.background = linearGradient('to right', hexToRgb(color, 0.55), hexToRgb(color, 1));\n\n                const borderRadius = '12.5px 4px 4px 12.5px';\n                style.borderRadius = borderRadius;\n                barElement.style.borderRadius = borderRadius;\n            }\n            if (this.item.progress >= 0) {\n                const contentProgressElement = contentElement.querySelector('.gantt-bar-content-progress') as HTMLDivElement;\n                style.background = hexToRgb(color, 0.3);\n                style.borderRadius = '';\n                contentProgressElement.style.background = color;\n            }\n\n            for (const key in style) {\n                if (style.hasOwnProperty(key)) {\n                    contentElement.style[key] = style[key];\n                }\n            }\n        }\n    }\n\n    stopPropagation(event: Event) {\n        event.stopPropagation();\n    }\n}\n","<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"]}
|
|
@@ -4,7 +4,7 @@ import * as i1$1 from '@angular/cdk/scrolling';
|
|
|
4
4
|
import { CdkScrollable, CdkVirtualScrollViewport, CdkFixedSizeVirtualScroll, CdkVirtualForOf, ScrollingModule } from '@angular/cdk/scrolling';
|
|
5
5
|
import { isPlatformServer, NgIf, NgTemplateOutlet, NgFor, NgStyle, NgClass, DOCUMENT, CommonModule } from '@angular/common';
|
|
6
6
|
import * as i0 from '@angular/core';
|
|
7
|
-
import { InjectionToken, EventEmitter, Directive, Inject, Input, Output, ContentChild, HostBinding, Injectable, PLATFORM_ID, Component, ViewChild, ViewChildren, Pipe, ElementRef, Optional, HostListener, forwardRef, ChangeDetectionStrategy, ContentChildren, NgModule } from '@angular/core';
|
|
7
|
+
import { InjectionToken, EventEmitter, Directive, Inject, Input, Output, ContentChild, HostBinding, Injectable, PLATFORM_ID, signal, effect, Component, ViewChild, ViewChildren, Pipe, ElementRef, Optional, HostListener, forwardRef, ChangeDetectionStrategy, ContentChildren, NgModule } from '@angular/core';
|
|
8
8
|
import { fromUnixTime, getWeek, getDaysInMonth, differenceInCalendarDays, setDate, addSeconds, addMinutes, addHours, addDays, addWeeks, addMonths, addQuarters, addYears, startOfMinute, startOfHour, startOfDay, startOfWeek, startOfMonth, startOfQuarter, startOfYear, endOfMinute, endOfHour, endOfDay, endOfWeek, endOfMonth, endOfQuarter, endOfYear, getUnixTime, format, isWeekend, isToday, differenceInHours, differenceInMinutes, differenceInDays, differenceInCalendarQuarters, eachMonthOfInterval, eachYearOfInterval, eachWeekOfInterval, eachDayOfInterval, differenceInCalendarYears, eachHourOfInterval, setDefaultOptions } from 'date-fns';
|
|
9
9
|
export { addDays, addHours, addMinutes, addMonths, addQuarters, addSeconds, addWeeks, addYears, differenceInCalendarDays, differenceInCalendarQuarters, differenceInDays, differenceInMinutes, eachDayOfInterval, eachHourOfInterval, eachMonthOfInterval, eachWeekOfInterval, endOfDay, endOfHour, endOfMinute, endOfMonth, endOfQuarter, endOfWeek, endOfYear, format, fromUnixTime, getDaysInMonth, getUnixTime, getWeek, isToday, isWeekend, setDate, startOfDay, startOfHour, startOfMinute, startOfMonth, startOfQuarter, startOfWeek, startOfYear } from 'date-fns';
|
|
10
10
|
import { BehaviorSubject, Subject, from, fromEvent, merge, Observable, EMPTY, interval, animationFrameScheduler, takeUntil as takeUntil$1, startWith as startWith$1, auditTime as auditTime$1, filter } from 'rxjs';
|
|
@@ -1686,10 +1686,10 @@ function createSvgElement(qualifiedName, className) {
|
|
|
1686
1686
|
}
|
|
1687
1687
|
class GanttBarDrag {
|
|
1688
1688
|
get dragDisabled() {
|
|
1689
|
-
return !this.item.draggable || !this.ganttUpper.draggable;
|
|
1689
|
+
return !this.item().draggable || !this.ganttUpper.draggable;
|
|
1690
1690
|
}
|
|
1691
1691
|
get linkDragDisabled() {
|
|
1692
|
-
return !this.item.linkable || !this.ganttUpper.linkable;
|
|
1692
|
+
return !this.item().linkable || !this.ganttUpper.linkable;
|
|
1693
1693
|
}
|
|
1694
1694
|
get barHandleDragMoveAndScrollDistance() {
|
|
1695
1695
|
return this.barHandleDragMoveDistance + this.dragScrollDistance;
|
|
@@ -1702,7 +1702,9 @@ class GanttBarDrag {
|
|
|
1702
1702
|
this.dom = dom;
|
|
1703
1703
|
this.dragContainer = dragContainer;
|
|
1704
1704
|
this._ngZone = _ngZone;
|
|
1705
|
-
this.
|
|
1705
|
+
this.item = signal(null);
|
|
1706
|
+
this.linkDragRefs = [];
|
|
1707
|
+
this.barHandleDragRefs = [];
|
|
1706
1708
|
this.destroy$ = new Subject();
|
|
1707
1709
|
/** Used to signal to the current auto-scroll sequence when to stop. */
|
|
1708
1710
|
this.stopScrollTimers$ = new Subject();
|
|
@@ -1733,6 +1735,12 @@ class GanttBarDrag {
|
|
|
1733
1735
|
}
|
|
1734
1736
|
});
|
|
1735
1737
|
};
|
|
1738
|
+
effect(() => {
|
|
1739
|
+
const item = this.item();
|
|
1740
|
+
if (item) {
|
|
1741
|
+
this.createDrags();
|
|
1742
|
+
}
|
|
1743
|
+
});
|
|
1736
1744
|
}
|
|
1737
1745
|
createDragRef(element) {
|
|
1738
1746
|
const dragRef = this.dragDrop.createDrag(element);
|
|
@@ -1742,40 +1750,46 @@ class GanttBarDrag {
|
|
|
1742
1750
|
return fromEvent(this.dom.mainContainer, 'scroll', passiveListenerOptions).pipe(takeUntil(dragRef.ended));
|
|
1743
1751
|
}
|
|
1744
1752
|
createMouseEvents() {
|
|
1745
|
-
|
|
1746
|
-
this.
|
|
1747
|
-
|
|
1748
|
-
|
|
1749
|
-
|
|
1750
|
-
|
|
1751
|
-
.
|
|
1752
|
-
|
|
1753
|
-
|
|
1754
|
-
|
|
1755
|
-
this.
|
|
1756
|
-
|
|
1757
|
-
|
|
1758
|
-
|
|
1753
|
+
if (!this.hasMonitorMouseEvent && (!this.dragDisabled || !this.linkDragDisabled)) {
|
|
1754
|
+
this.hasMonitorMouseEvent = true;
|
|
1755
|
+
const dropClass = this.ganttUpper.config.linkOptions?.dependencyTypes?.length === 1 &&
|
|
1756
|
+
this.ganttUpper.config.linkOptions?.dependencyTypes[0] === GanttLinkType.fs
|
|
1757
|
+
? singleDropActiveClass
|
|
1758
|
+
: dropActiveClass;
|
|
1759
|
+
fromEvent(this.barElement, 'mouseenter', passiveListenerOptions)
|
|
1760
|
+
.pipe(takeUntil(this.destroy$))
|
|
1761
|
+
.subscribe(() => {
|
|
1762
|
+
if (this.dragContainer.linkDraggingId && this.dragContainer.linkDraggingId !== this.item().id) {
|
|
1763
|
+
if (!this.linkDragDisabled) {
|
|
1764
|
+
this.barElement.classList.add(dropClass);
|
|
1765
|
+
this.dragContainer.emitLinkDragEntered({
|
|
1766
|
+
item: this.item(),
|
|
1767
|
+
element: this.barElement
|
|
1768
|
+
});
|
|
1769
|
+
}
|
|
1759
1770
|
}
|
|
1760
|
-
|
|
1761
|
-
|
|
1762
|
-
|
|
1763
|
-
|
|
1764
|
-
|
|
1765
|
-
|
|
1766
|
-
|
|
1767
|
-
|
|
1768
|
-
|
|
1769
|
-
this.
|
|
1770
|
-
|
|
1771
|
-
|
|
1772
|
-
|
|
1773
|
-
|
|
1774
|
-
|
|
1775
|
-
|
|
1771
|
+
else {
|
|
1772
|
+
if (!this.dragDisabled || !this.linkDragDisabled) {
|
|
1773
|
+
this.barElement.classList.add(activeClass);
|
|
1774
|
+
}
|
|
1775
|
+
}
|
|
1776
|
+
});
|
|
1777
|
+
fromEvent(this.barElement, 'mouseleave', passiveListenerOptions)
|
|
1778
|
+
.pipe(takeUntil(this.destroy$))
|
|
1779
|
+
.subscribe(() => {
|
|
1780
|
+
if (!this.dragContainer.linkDraggingId) {
|
|
1781
|
+
this.barElement.classList.remove(activeClass);
|
|
1782
|
+
}
|
|
1783
|
+
else {
|
|
1784
|
+
this.dragContainer.emitLinkDragLeaved();
|
|
1785
|
+
}
|
|
1786
|
+
this.barElement.classList.remove(dropClass);
|
|
1787
|
+
});
|
|
1788
|
+
}
|
|
1776
1789
|
}
|
|
1777
1790
|
createBarDrag() {
|
|
1778
1791
|
const dragRef = this.createDragRef(this.barElement);
|
|
1792
|
+
dragRef.disabled = this.dragDisabled;
|
|
1779
1793
|
dragRef.lockAxis = 'x';
|
|
1780
1794
|
dragRef.withBoundaryElement(this.dom.mainItems);
|
|
1781
1795
|
dragRef.started.subscribe(() => {
|
|
@@ -1789,7 +1803,7 @@ class GanttBarDrag {
|
|
|
1789
1803
|
this.barDragMove();
|
|
1790
1804
|
}
|
|
1791
1805
|
});
|
|
1792
|
-
this.dragContainer.dragStarted.emit({ item: this.item.origin });
|
|
1806
|
+
this.dragContainer.dragStarted.emit({ item: this.item().origin });
|
|
1793
1807
|
});
|
|
1794
1808
|
dragRef.moved.subscribe((event) => {
|
|
1795
1809
|
this.startScrollingIfNecessary(event.pointerPosition.x, event.pointerPosition.y);
|
|
@@ -1806,14 +1820,13 @@ class GanttBarDrag {
|
|
|
1806
1820
|
this.dragScrolling = false;
|
|
1807
1821
|
this.dragScrollDistance = 0;
|
|
1808
1822
|
this.barDragMoveDistance = 0;
|
|
1809
|
-
this.item.updateRefs({
|
|
1810
|
-
width: this.ganttUpper.view.getDateRangeWidth(this.item.start, this.item.end),
|
|
1811
|
-
x: this.ganttUpper.view.getXPointByDate(this.item.start),
|
|
1823
|
+
this.item().updateRefs({
|
|
1824
|
+
width: this.ganttUpper.view.getDateRangeWidth(this.item().start, this.item().end),
|
|
1825
|
+
x: this.ganttUpper.view.getXPointByDate(this.item().start),
|
|
1812
1826
|
y: (this.ganttUpper.styles.lineHeight - this.ganttUpper.styles.barHeight) / 2 - 1
|
|
1813
1827
|
});
|
|
1814
|
-
this.dragContainer.dragEnded.emit({ item: this.item.origin });
|
|
1828
|
+
this.dragContainer.dragEnded.emit({ item: this.item().origin });
|
|
1815
1829
|
});
|
|
1816
|
-
this.barDragRef = dragRef;
|
|
1817
1830
|
return dragRef;
|
|
1818
1831
|
}
|
|
1819
1832
|
createBarHandleDrags() {
|
|
@@ -1822,6 +1835,7 @@ class GanttBarDrag {
|
|
|
1822
1835
|
handles.forEach((handle, index) => {
|
|
1823
1836
|
const isBefore = index === 0;
|
|
1824
1837
|
const dragRef = this.createDragRef(handle);
|
|
1838
|
+
dragRef.disabled = this.dragDisabled;
|
|
1825
1839
|
dragRef.lockAxis = 'x';
|
|
1826
1840
|
dragRef.withBoundaryElement(this.dom.mainItems);
|
|
1827
1841
|
dragRef.started.subscribe(() => {
|
|
@@ -1844,7 +1858,7 @@ class GanttBarDrag {
|
|
|
1844
1858
|
}
|
|
1845
1859
|
}
|
|
1846
1860
|
});
|
|
1847
|
-
this.dragContainer.dragStarted.emit({ item: this.item.origin });
|
|
1861
|
+
this.dragContainer.dragStarted.emit({ item: this.item().origin });
|
|
1848
1862
|
});
|
|
1849
1863
|
dragRef.moved.subscribe((event) => {
|
|
1850
1864
|
if (this.barHandleDragMoveRecordDiffs && this.barHandleDragMoveRecordDiffs > 0) {
|
|
@@ -1868,12 +1882,12 @@ class GanttBarDrag {
|
|
|
1868
1882
|
this.dragScrolling = false;
|
|
1869
1883
|
this.dragScrollDistance = 0;
|
|
1870
1884
|
this.barHandleDragMoveDistance = 0;
|
|
1871
|
-
this.item.updateRefs({
|
|
1872
|
-
width: this.ganttUpper.view.getDateRangeWidth(this.item.start, this.item.end),
|
|
1873
|
-
x: this.ganttUpper.view.getXPointByDate(this.item.start),
|
|
1885
|
+
this.item().updateRefs({
|
|
1886
|
+
width: this.ganttUpper.view.getDateRangeWidth(this.item().start, this.item().end),
|
|
1887
|
+
x: this.ganttUpper.view.getXPointByDate(this.item().start),
|
|
1874
1888
|
y: (this.ganttUpper.styles.lineHeight - this.ganttUpper.styles.barHeight) / 2 - 1
|
|
1875
1889
|
});
|
|
1876
|
-
this.dragContainer.dragEnded.emit({ item: this.item.origin });
|
|
1890
|
+
this.dragContainer.dragEnded.emit({ item: this.item().origin });
|
|
1877
1891
|
});
|
|
1878
1892
|
dragRefs.push(dragRef);
|
|
1879
1893
|
});
|
|
@@ -1885,6 +1899,7 @@ class GanttBarDrag {
|
|
|
1885
1899
|
handles.forEach((handle, index) => {
|
|
1886
1900
|
const isBegin = index === 0;
|
|
1887
1901
|
const dragRef = this.dragDrop.createDrag(handle);
|
|
1902
|
+
dragRef.disabled = this.linkDragDisabled;
|
|
1888
1903
|
dragRef.withBoundaryElement(this.dom.root);
|
|
1889
1904
|
dragRef.beforeStarted.subscribe(() => {
|
|
1890
1905
|
handle.style.pointerEvents = 'none';
|
|
@@ -1894,7 +1909,7 @@ class GanttBarDrag {
|
|
|
1894
1909
|
this.createLinkDraggingLine();
|
|
1895
1910
|
this.dragContainer.emitLinkDragStarted({
|
|
1896
1911
|
element: this.barElement,
|
|
1897
|
-
item: this.item,
|
|
1912
|
+
item: this.item(),
|
|
1898
1913
|
pos: isBegin ? InBarPosition.start : InBarPosition.finish
|
|
1899
1914
|
});
|
|
1900
1915
|
});
|
|
@@ -1969,10 +1984,10 @@ class GanttBarDrag {
|
|
|
1969
1984
|
this.barElement.classList.remove('gantt-bar-draggable-drag');
|
|
1970
1985
|
}
|
|
1971
1986
|
barDragMove() {
|
|
1972
|
-
const currentX = this.item.refs.x + this.barDragMoveDistance + this.dragScrollDistance;
|
|
1987
|
+
const currentX = this.item().refs.x + this.barDragMoveDistance + this.dragScrollDistance;
|
|
1973
1988
|
const currentDate = this.ganttUpper.view.getDateByXPoint(currentX);
|
|
1974
1989
|
const currentStartX = this.ganttUpper.view.getXPointByDate(currentDate);
|
|
1975
|
-
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item.end, this.item.start);
|
|
1990
|
+
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item().end, this.item().start);
|
|
1976
1991
|
let start = currentDate;
|
|
1977
1992
|
let end = currentDate.add(diffs, this.ganttUpper.view?.options?.datePrecisionUnit);
|
|
1978
1993
|
// 日视图特殊逻辑处理
|
|
@@ -1987,59 +2002,59 @@ class GanttBarDrag {
|
|
|
1987
2002
|
const left = currentX - this.barDragMoveDistance;
|
|
1988
2003
|
this.barElement.style.left = left + 'px';
|
|
1989
2004
|
}
|
|
1990
|
-
this.openDragBackdrop(this.barElement, this.ganttUpper.view.getDateByXPoint(currentX), this.ganttUpper.view.getDateByXPoint(currentX + this.item.refs.width));
|
|
2005
|
+
this.openDragBackdrop(this.barElement, this.ganttUpper.view.getDateByXPoint(currentX), this.ganttUpper.view.getDateByXPoint(currentX + this.item().refs.width));
|
|
1991
2006
|
if (!this.isStartOrEndInsideView(start, end)) {
|
|
1992
2007
|
return;
|
|
1993
2008
|
}
|
|
1994
2009
|
this.updateItemDate(start, end);
|
|
1995
|
-
this.dragContainer.dragMoved.emit({ item: this.item.origin });
|
|
2010
|
+
this.dragContainer.dragMoved.emit({ item: this.item().origin });
|
|
1996
2011
|
}
|
|
1997
2012
|
barBeforeHandleDragMove() {
|
|
1998
2013
|
const { x, start, minRangeWidthWidth } = this.startOfBarHandle();
|
|
1999
|
-
const width = this.item.refs.width + this.barHandleDragMoveAndScrollDistance * -1;
|
|
2000
|
-
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item.end, start);
|
|
2014
|
+
const width = this.item().refs.width + this.barHandleDragMoveAndScrollDistance * -1;
|
|
2015
|
+
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(this.item().end, start);
|
|
2001
2016
|
if (width > dragMinWidth && diffs > 0) {
|
|
2002
2017
|
this.barElement.style.width = width + 'px';
|
|
2003
2018
|
this.barElement.style.left = x + 'px';
|
|
2004
|
-
this.openDragBackdrop(this.barElement, start, this.item.end);
|
|
2005
|
-
if (!this.isStartOrEndInsideView(start, this.item.end)) {
|
|
2019
|
+
this.openDragBackdrop(this.barElement, start, this.item().end);
|
|
2020
|
+
if (!this.isStartOrEndInsideView(start, this.item().end)) {
|
|
2006
2021
|
return;
|
|
2007
2022
|
}
|
|
2008
|
-
this.updateItemDate(start, this.item.end);
|
|
2023
|
+
this.updateItemDate(start, this.item().end);
|
|
2009
2024
|
}
|
|
2010
2025
|
else {
|
|
2011
2026
|
if (this.barHandleDragMoveRecordDiffs > 0 && diffs <= 0) {
|
|
2012
2027
|
this.barElement.style.width = minRangeWidthWidth + 'px';
|
|
2013
|
-
const x = this.ganttUpper.view.getXPointByDate(this.item.end);
|
|
2028
|
+
const x = this.ganttUpper.view.getXPointByDate(this.item().end);
|
|
2014
2029
|
this.barElement.style.left = x + 'px';
|
|
2015
2030
|
}
|
|
2016
|
-
this.openDragBackdrop(this.barElement, this.item.end, this.item.end);
|
|
2017
|
-
this.updateItemDate(this.item.end, this.item.end);
|
|
2031
|
+
this.openDragBackdrop(this.barElement, this.item().end, this.item().end);
|
|
2032
|
+
this.updateItemDate(this.item().end, this.item().end);
|
|
2018
2033
|
}
|
|
2019
2034
|
this.barHandleDragMoveRecordDiffs = diffs;
|
|
2020
|
-
this.dragContainer.dragMoved.emit({ item: this.item.origin });
|
|
2035
|
+
this.dragContainer.dragMoved.emit({ item: this.item().origin });
|
|
2021
2036
|
}
|
|
2022
2037
|
barAfterHandleDragMove() {
|
|
2023
2038
|
const { width, end } = this.endOfBarHandle();
|
|
2024
|
-
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(end, this.item.start);
|
|
2039
|
+
const diffs = this.ganttUpper.view.differenceByPrecisionUnit(end, this.item().start);
|
|
2025
2040
|
if (width > dragMinWidth && diffs > 0) {
|
|
2026
2041
|
this.barElement.style.width = width + 'px';
|
|
2027
|
-
this.openDragBackdrop(this.barElement, this.item.start, end);
|
|
2028
|
-
if (!this.isStartOrEndInsideView(this.item.start, end)) {
|
|
2042
|
+
this.openDragBackdrop(this.barElement, this.item().start, end);
|
|
2043
|
+
if (!this.isStartOrEndInsideView(this.item().start, end)) {
|
|
2029
2044
|
return;
|
|
2030
2045
|
}
|
|
2031
|
-
this.updateItemDate(this.item.start, end);
|
|
2046
|
+
this.updateItemDate(this.item().start, end);
|
|
2032
2047
|
}
|
|
2033
2048
|
else {
|
|
2034
2049
|
if (this.barHandleDragMoveRecordDiffs > 0 && diffs <= 0) {
|
|
2035
|
-
const minRangeWidth = this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item.start);
|
|
2050
|
+
const minRangeWidth = this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item().start);
|
|
2036
2051
|
this.barElement.style.width = minRangeWidth + 'px';
|
|
2037
2052
|
}
|
|
2038
|
-
this.openDragBackdrop(this.barElement, this.item.start, this.item.start);
|
|
2039
|
-
this.updateItemDate(this.item.start, this.item.start);
|
|
2053
|
+
this.openDragBackdrop(this.barElement, this.item().start, this.item().start);
|
|
2054
|
+
this.updateItemDate(this.item().start, this.item().start);
|
|
2040
2055
|
}
|
|
2041
2056
|
this.barHandleDragMoveRecordDiffs = diffs;
|
|
2042
|
-
this.dragContainer.dragMoved.emit({ item: this.item.origin });
|
|
2057
|
+
this.dragContainer.dragMoved.emit({ item: this.item().origin });
|
|
2043
2058
|
}
|
|
2044
2059
|
calcLinkLinePositions(target, isBefore) {
|
|
2045
2060
|
const rootRect = this.dom.root.getBoundingClientRect();
|
|
@@ -2096,33 +2111,33 @@ class GanttBarDrag {
|
|
|
2096
2111
|
const xThreshold = clientWidth * DROP_PROXIMITY_THRESHOLD;
|
|
2097
2112
|
if (isBefore) {
|
|
2098
2113
|
const { start, minRangeWidthWidth } = this.startOfBarHandle();
|
|
2099
|
-
const xPointerByEndDate = this.ganttUpper.view.getXPointByDate(this.item.end);
|
|
2100
|
-
isStartGreaterThanEnd = start.value > this.item.end.value;
|
|
2114
|
+
const xPointerByEndDate = this.ganttUpper.view.getXPointByDate(this.item().end);
|
|
2115
|
+
isStartGreaterThanEnd = start.value > this.item().end.value;
|
|
2101
2116
|
isBarAppearsInView = xPointerByEndDate + minRangeWidthWidth + xThreshold <= scrollLeft + clientWidth;
|
|
2102
2117
|
}
|
|
2103
2118
|
else {
|
|
2104
2119
|
const { end } = this.endOfBarHandle();
|
|
2105
|
-
const xPointerByStartDate = this.ganttUpper.view.getXPointByDate(this.item.start);
|
|
2106
|
-
isStartGreaterThanEnd = end.value < this.item.start.value;
|
|
2120
|
+
const xPointerByStartDate = this.ganttUpper.view.getXPointByDate(this.item().start);
|
|
2121
|
+
isStartGreaterThanEnd = end.value < this.item().start.value;
|
|
2107
2122
|
isBarAppearsInView = scrollLeft + xThreshold <= xPointerByStartDate;
|
|
2108
2123
|
}
|
|
2109
2124
|
return isStartGreaterThanEnd && isBarAppearsInView ? true : false;
|
|
2110
2125
|
}
|
|
2111
2126
|
// Some data information about dragging start until it is equal to or greater than end
|
|
2112
2127
|
startOfBarHandle() {
|
|
2113
|
-
const x = this.item.refs.x + this.barHandleDragMoveAndScrollDistance;
|
|
2128
|
+
const x = this.item().refs.x + this.barHandleDragMoveAndScrollDistance;
|
|
2114
2129
|
return {
|
|
2115
2130
|
x,
|
|
2116
2131
|
start: this.ganttUpper.view.getDateByXPoint(x),
|
|
2117
|
-
minRangeWidthWidth: this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item.end)
|
|
2132
|
+
minRangeWidthWidth: this.ganttUpper.view.getMinRangeWidthByPrecisionUnit(this.item().end)
|
|
2118
2133
|
};
|
|
2119
2134
|
}
|
|
2120
2135
|
// Some data information about dragging end of bar handle
|
|
2121
2136
|
endOfBarHandle() {
|
|
2122
|
-
const width = this.item.refs.width + this.barHandleDragMoveAndScrollDistance;
|
|
2137
|
+
const width = this.item().refs.width + this.barHandleDragMoveAndScrollDistance;
|
|
2123
2138
|
return {
|
|
2124
2139
|
width,
|
|
2125
|
-
end: this.ganttUpper.view.getDateByXPoint(this.item.refs.x + width)
|
|
2140
|
+
end: this.ganttUpper.view.getDateByXPoint(this.item().refs.x + width)
|
|
2126
2141
|
};
|
|
2127
2142
|
}
|
|
2128
2143
|
stopScrolling() {
|
|
@@ -2141,34 +2156,55 @@ class GanttBarDrag {
|
|
|
2141
2156
|
}
|
|
2142
2157
|
}
|
|
2143
2158
|
updateItemDate(start, end) {
|
|
2144
|
-
this.item.updateDate(this.ganttUpper.view.startOfPrecision(start), this.ganttUpper.view.endOfPrecision(end));
|
|
2159
|
+
this.item().updateDate(this.ganttUpper.view.startOfPrecision(start), this.ganttUpper.view.endOfPrecision(end));
|
|
2145
2160
|
}
|
|
2146
|
-
|
|
2147
|
-
this.item = item;
|
|
2161
|
+
initialize(elementRef, item, ganttUpper) {
|
|
2148
2162
|
this.barElement = elementRef.nativeElement;
|
|
2149
2163
|
this.ganttUpper = ganttUpper;
|
|
2150
|
-
|
|
2151
|
-
|
|
2164
|
+
this.item.set(item);
|
|
2165
|
+
}
|
|
2166
|
+
createBarDragRef() {
|
|
2167
|
+
if (this.barDragRef) {
|
|
2168
|
+
this.barDragRef.disabled = this.dragDisabled;
|
|
2152
2169
|
}
|
|
2153
|
-
else {
|
|
2154
|
-
this.
|
|
2155
|
-
if (!this.dragDisabled) {
|
|
2156
|
-
const dragRef = this.createBarDrag();
|
|
2157
|
-
const dragHandlesRefs = this.createBarHandleDrags();
|
|
2158
|
-
this.dragRefs.push(dragRef, ...dragHandlesRefs);
|
|
2159
|
-
}
|
|
2160
|
-
if (!this.linkDragDisabled) {
|
|
2161
|
-
const linkDragRefs = this.createLinkHandleDrags();
|
|
2162
|
-
this.dragRefs.push(...linkDragRefs);
|
|
2163
|
-
}
|
|
2170
|
+
else if (!this.dragDisabled) {
|
|
2171
|
+
this.barDragRef = this.createBarDrag();
|
|
2164
2172
|
}
|
|
2165
2173
|
}
|
|
2174
|
+
createBarHandleDragRefs() {
|
|
2175
|
+
if (this.barHandleDragRefs.length > 0) {
|
|
2176
|
+
this.barHandleDragRefs.forEach((dragRef) => {
|
|
2177
|
+
dragRef.disabled = this.dragDisabled;
|
|
2178
|
+
});
|
|
2179
|
+
}
|
|
2180
|
+
else if (!this.dragDisabled) {
|
|
2181
|
+
this.barHandleDragRefs = this.createBarHandleDrags();
|
|
2182
|
+
}
|
|
2183
|
+
}
|
|
2184
|
+
createLinkDragRefs() {
|
|
2185
|
+
if (this.linkDragRefs.length > 0) {
|
|
2186
|
+
this.linkDragRefs.forEach((dragRef) => {
|
|
2187
|
+
dragRef.disabled = this.linkDragDisabled;
|
|
2188
|
+
});
|
|
2189
|
+
}
|
|
2190
|
+
else if (!this.linkDragDisabled) {
|
|
2191
|
+
this.linkDragRefs = this.createLinkHandleDrags();
|
|
2192
|
+
}
|
|
2193
|
+
}
|
|
2194
|
+
createDrags() {
|
|
2195
|
+
this.createMouseEvents();
|
|
2196
|
+
this.createBarDragRef();
|
|
2197
|
+
this.createBarHandleDragRefs();
|
|
2198
|
+
this.createLinkDragRefs();
|
|
2199
|
+
}
|
|
2166
2200
|
updateItem(item) {
|
|
2167
|
-
this.item
|
|
2201
|
+
this.item.set(item);
|
|
2168
2202
|
}
|
|
2169
2203
|
ngOnDestroy() {
|
|
2170
2204
|
this.closeDragBackdrop();
|
|
2171
|
-
this.
|
|
2205
|
+
this.barDragRef?.dispose();
|
|
2206
|
+
this.linkDragRefs?.forEach((dragRef) => dragRef.dispose());
|
|
2207
|
+
this.barHandleDragRefs?.forEach((dragRef) => dragRef.dispose());
|
|
2172
2208
|
this.destroy$.next();
|
|
2173
2209
|
this.destroy$.complete();
|
|
2174
2210
|
this.stopScrolling();
|
|
@@ -2293,7 +2329,7 @@ class NgxGanttBarComponent extends GanttItemUpper {
|
|
|
2293
2329
|
// using `zone-patch-rxjs` because it'll trigger a change detection when it unsubscribes.
|
|
2294
2330
|
this.ngZone.runOutsideAngular(() => {
|
|
2295
2331
|
onStable$.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {
|
|
2296
|
-
this.drag.
|
|
2332
|
+
this.drag.initialize(this.elementRef, this.item, this.ganttUpper);
|
|
2297
2333
|
});
|
|
2298
2334
|
});
|
|
2299
2335
|
this.setContentBackground();
|