@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.createDrags(this.elementRef, this.item, this.ganttUpper);
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":"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,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACvE,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.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":"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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.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.dragRefs = [];
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
- const dropClass = this.ganttUpper.config.linkOptions?.dependencyTypes?.length === 1 &&
1746
- this.ganttUpper.config.linkOptions?.dependencyTypes[0] === GanttLinkType.fs
1747
- ? singleDropActiveClass
1748
- : dropActiveClass;
1749
- fromEvent(this.barElement, 'mouseenter', passiveListenerOptions)
1750
- .pipe(takeUntil(this.destroy$))
1751
- .subscribe(() => {
1752
- if (this.dragContainer.linkDraggingId && this.dragContainer.linkDraggingId !== this.item.id) {
1753
- if (this.item.linkable) {
1754
- this.barElement.classList.add(dropClass);
1755
- this.dragContainer.emitLinkDragEntered({
1756
- item: this.item,
1757
- element: this.barElement
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
- else {
1762
- this.barElement.classList.add(activeClass);
1763
- }
1764
- });
1765
- fromEvent(this.barElement, 'mouseleave', passiveListenerOptions)
1766
- .pipe(takeUntil(this.destroy$))
1767
- .subscribe(() => {
1768
- if (!this.dragContainer.linkDraggingId) {
1769
- this.barElement.classList.remove(activeClass);
1770
- }
1771
- else {
1772
- this.dragContainer.emitLinkDragLeaved();
1773
- }
1774
- this.barElement.classList.remove(dropClass);
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
- createDrags(elementRef, item, ganttUpper) {
2147
- this.item = item;
2161
+ initialize(elementRef, item, ganttUpper) {
2148
2162
  this.barElement = elementRef.nativeElement;
2149
2163
  this.ganttUpper = ganttUpper;
2150
- if (this.dragDisabled && this.linkDragDisabled) {
2151
- return;
2164
+ this.item.set(item);
2165
+ }
2166
+ createBarDragRef() {
2167
+ if (this.barDragRef) {
2168
+ this.barDragRef.disabled = this.dragDisabled;
2152
2169
  }
2153
- else {
2154
- this.createMouseEvents();
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 = item;
2201
+ this.item.set(item);
2168
2202
  }
2169
2203
  ngOnDestroy() {
2170
2204
  this.closeDragBackdrop();
2171
- this.dragRefs.forEach((dragRef) => dragRef.dispose());
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.createDrags(this.elementRef, this.item, this.ganttUpper);
2332
+ this.drag.initialize(this.elementRef, this.item, this.ganttUpper);
2297
2333
  });
2298
2334
  });
2299
2335
  this.setContentBackground();