@worktile/gantt 16.0.1 → 16.1.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.
@@ -100,14 +100,29 @@ export class GanttView {
100
100
  }
101
101
  // 根据X坐标获取对应时间
102
102
  getDateByXPoint(x) {
103
- const indexOfSecondaryDate = Math.max(Math.floor(x / this.getCellWidth()), 0);
104
- const matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];
105
- const dayWidth = this.getDayOccupancyWidth(matchDate?.start);
103
+ let indexOfSecondaryDate;
104
+ let matchDate;
105
+ let dayWidth;
106
+ let day;
107
+ if (x >= 0) {
108
+ indexOfSecondaryDate = Math.floor(x / this.getCellWidth());
109
+ matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];
110
+ dayWidth = this.getDayOccupancyWidth(matchDate?.start);
111
+ }
112
+ else {
113
+ const datePointTemp = this.secondaryDatePoints[0];
114
+ dayWidth = this.getDayOccupancyWidth(datePointTemp?.start);
115
+ day = Math.floor(x / dayWidth);
116
+ return datePointTemp?.start.addDays(day);
117
+ }
106
118
  if (dayWidth === this.getCellWidth()) {
107
119
  return matchDate?.start;
108
120
  }
109
121
  else {
110
- const day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;
122
+ day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;
123
+ if (indexOfSecondaryDate > this.secondaryDatePoints.length - 1) {
124
+ day += (indexOfSecondaryDate - (this.secondaryDatePoints.length - 1)) * 30;
125
+ }
111
126
  if (this.getCellWidth() / dayWidth === 7) {
112
127
  return matchDate?.start.addDays(day);
113
128
  }
@@ -120,4 +135,4 @@ export class GanttView {
120
135
  return this.getDateIntervalWidth(start, end.addSeconds(1));
121
136
  }
122
137
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"","sources":["../../../../packages/gantt/src/views/view.ts"],"names":[],"mappings":"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","sourcesContent":["import { GanttDate, differenceInDays, GanttDateUtil } from '../utils/date';\nimport { GanttDatePoint } from '../class/date-point';\nimport { BehaviorSubject } from 'rxjs';\nimport { defaultConfig, GanttDateFormat } from '../gantt.config';\nimport { GanttViewType } from '../class';\n\nexport const primaryDatePointTop = 18;\n\nexport const secondaryDatePointTop = 36;\n\nexport interface GanttViewDate {\n    date: GanttDate;\n    isCustom?: boolean;\n}\n\nexport interface GanttViewOptions {\n    start?: GanttDate;\n    end?: GanttDate;\n    min?: GanttDate;\n    max?: GanttDate;\n    cellWidth?: number;\n    addAmount?: number;\n    addUnit?: GanttDateUtil;\n    dateFormat?: GanttDateFormat;\n    // fill days when start or end is null\n    fillDays?: number;\n    // custom key and value\n    [key: string]: any;\n}\n\nconst viewOptions: GanttViewOptions = {\n    min: new GanttDate().addYears(-1).startOfYear(),\n    max: new GanttDate().addYears(1).endOfYear(),\n    dateFormat: defaultConfig.dateFormat\n};\n\nexport abstract class GanttView {\n    viewType: GanttViewType;\n\n    start$: BehaviorSubject<GanttDate>;\n\n    end$: BehaviorSubject<GanttDate>;\n\n    get start() {\n        return this.start$.getValue();\n    }\n\n    get end() {\n        return this.end$.getValue();\n    }\n\n    primaryDatePoints: GanttDatePoint[];\n\n    secondaryDatePoints: GanttDatePoint[];\n\n    width: number;\n\n    cellWidth: number;\n\n    primaryWidth: number;\n\n    showTimeline = true;\n\n    showWeekBackdrop: boolean;\n\n    options: GanttViewOptions;\n\n    constructor(start: GanttViewDate, end: GanttViewDate, options: GanttViewOptions) {\n        this.options = Object.assign({}, viewOptions, options);\n        const startDate = start.isCustom\n            ? this.startOf(start.date)\n            : this.startOf(start.date.value < this.options.start.value ? start.date : this.options.start);\n        const endDate = end.isCustom\n            ? this.endOf(end.date)\n            : this.endOf(end.date.value > this.options.end.value ? end.date : this.options.end);\n        this.start$ = new BehaviorSubject<GanttDate>(startDate);\n        this.end$ = new BehaviorSubject<GanttDate>(endDate);\n        this.initialize();\n    }\n\n    abstract startOf(date: GanttDate): GanttDate;\n\n    abstract endOf(date: GanttDate): GanttDate;\n\n    // 获取一级时间网格合并后的宽度\n    abstract getPrimaryWidth(): number;\n\n    // 获取当前视图下每一天占用的宽度\n    abstract getDayOccupancyWidth(date: GanttDate): number;\n\n    // 获取一级时间点（坐标，显示名称）\n    abstract getPrimaryDatePoints(): GanttDatePoint[];\n\n    // 获取二级时间点（坐标，显示名称）\n    abstract getSecondaryDatePoints(): GanttDatePoint[];\n\n    protected getDateIntervalWidth(start: GanttDate, end: GanttDate) {\n        let result = 0;\n        const days = differenceInDays(end.value, start.value);\n        for (let i = 0; i < Math.abs(days); i++) {\n            result += this.getDayOccupancyWidth(start.addDays(i));\n        }\n        result = days >= 0 ? result : -result;\n        return Number(result.toFixed(3));\n    }\n\n    protected initialize() {\n        this.primaryDatePoints = this.getPrimaryDatePoints();\n        this.secondaryDatePoints = this.getSecondaryDatePoints();\n        this.width = this.getWidth();\n        this.cellWidth = this.getCellWidth();\n        this.primaryWidth = this.getPrimaryWidth();\n    }\n\n    addStartDate() {\n        const start = this.startOf(this.start.add(this.options.addAmount * -1, this.options.addUnit));\n        if (start.value >= this.options.min.value) {\n            const origin = this.start;\n            this.start$.next(start);\n            this.initialize();\n            return { start: this.start, end: origin };\n        }\n        return null;\n    }\n\n    addEndDate() {\n        const end = this.endOf(this.end.add(this.options.addAmount, this.options.addUnit));\n        if (end.value <= this.options.max.value) {\n            const origin = this.end;\n            this.end$.next(end);\n            this.initialize();\n            return { start: origin, end: this.end };\n        }\n        return null;\n    }\n\n    updateDate(start: GanttDate, end: GanttDate) {\n        start = this.startOf(start);\n        end = this.endOf(end);\n        if (start.value < this.start.value) {\n            this.start$.next(start);\n        }\n        if (end.value > this.end.value) {\n            this.end$.next(end);\n        }\n        this.initialize();\n    }\n\n    // 获取View的宽度\n    getWidth() {\n        return this.getCellWidth() * this.secondaryDatePoints.length;\n    }\n\n    // 获取单个网格的宽度\n    getCellWidth() {\n        return this.options.cellWidth;\n    }\n\n    // 获取当前时间的X坐标\n    getTodayXPoint(): number {\n        const toady = new GanttDate().startOfDay();\n        if (toady.value > this.start.value && toady.value < this.end.value) {\n            const x = this.getXPointByDate(toady) + this.getDayOccupancyWidth(toady) / 2;\n            return x;\n        } else {\n            return null;\n        }\n    }\n\n    // 获取指定时间的X坐标\n    getXPointByDate(date: GanttDate) {\n        return this.getDateIntervalWidth(this.start, date);\n    }\n\n    // 根据X坐标获取对应时间\n    getDateByXPoint(x: number) {\n        const indexOfSecondaryDate = Math.max(Math.floor(x / this.getCellWidth()), 0);\n        const matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];\n        const dayWidth = this.getDayOccupancyWidth(matchDate?.start);\n        if (dayWidth === this.getCellWidth()) {\n            return matchDate?.start;\n        } else {\n            const day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;\n            if (this.getCellWidth() / dayWidth === 7) {\n                return matchDate?.start.addDays(day);\n            }\n            return matchDate?.start.setDate(day);\n        }\n    }\n\n    // 获取指定时间范围的宽度\n    getDateRangeWidth(start: GanttDate, end: GanttDate) {\n        // addSeconds(1) 是因为计算相差天会以一个整天来计算 end时间一般是59分59秒不是一个整天，所以需要加1\n        return this.getDateIntervalWidth(start, end.addSeconds(1));\n    }\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view.js","sourceRoot":"","sources":["../../../../packages/gantt/src/views/view.ts"],"names":[],"mappings":"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","sourcesContent":["import { GanttDate, differenceInDays, GanttDateUtil } from '../utils/date';\nimport { GanttDatePoint } from '../class/date-point';\nimport { BehaviorSubject } from 'rxjs';\nimport { defaultConfig, GanttDateFormat } from '../gantt.config';\nimport { GanttViewType } from '../class';\n\nexport const primaryDatePointTop = 18;\n\nexport const secondaryDatePointTop = 36;\n\nexport interface GanttViewDate {\n    date: GanttDate;\n    isCustom?: boolean;\n}\n\nexport interface GanttViewOptions {\n    start?: GanttDate;\n    end?: GanttDate;\n    min?: GanttDate;\n    max?: GanttDate;\n    cellWidth?: number;\n    addAmount?: number;\n    addUnit?: GanttDateUtil;\n    dateFormat?: GanttDateFormat;\n    // fill days when start or end is null\n    fillDays?: number;\n    // custom key and value\n    [key: string]: any;\n}\n\nconst viewOptions: GanttViewOptions = {\n    min: new GanttDate().addYears(-1).startOfYear(),\n    max: new GanttDate().addYears(1).endOfYear(),\n    dateFormat: defaultConfig.dateFormat\n};\n\nexport abstract class GanttView {\n    viewType: GanttViewType;\n\n    start$: BehaviorSubject<GanttDate>;\n\n    end$: BehaviorSubject<GanttDate>;\n\n    get start() {\n        return this.start$.getValue();\n    }\n\n    get end() {\n        return this.end$.getValue();\n    }\n\n    primaryDatePoints: GanttDatePoint[];\n\n    secondaryDatePoints: GanttDatePoint[];\n\n    width: number;\n\n    cellWidth: number;\n\n    primaryWidth: number;\n\n    showTimeline = true;\n\n    showWeekBackdrop: boolean;\n\n    options: GanttViewOptions;\n\n    constructor(start: GanttViewDate, end: GanttViewDate, options: GanttViewOptions) {\n        this.options = Object.assign({}, viewOptions, options);\n        const startDate = start.isCustom\n            ? this.startOf(start.date)\n            : this.startOf(start.date.value < this.options.start.value ? start.date : this.options.start);\n        const endDate = end.isCustom\n            ? this.endOf(end.date)\n            : this.endOf(end.date.value > this.options.end.value ? end.date : this.options.end);\n        this.start$ = new BehaviorSubject<GanttDate>(startDate);\n        this.end$ = new BehaviorSubject<GanttDate>(endDate);\n        this.initialize();\n    }\n\n    abstract startOf(date: GanttDate): GanttDate;\n\n    abstract endOf(date: GanttDate): GanttDate;\n\n    // 获取一级时间网格合并后的宽度\n    abstract getPrimaryWidth(): number;\n\n    // 获取当前视图下每一天占用的宽度\n    abstract getDayOccupancyWidth(date: GanttDate): number;\n\n    // 获取一级时间点（坐标，显示名称）\n    abstract getPrimaryDatePoints(): GanttDatePoint[];\n\n    // 获取二级时间点（坐标，显示名称）\n    abstract getSecondaryDatePoints(): GanttDatePoint[];\n\n    protected getDateIntervalWidth(start: GanttDate, end: GanttDate) {\n        let result = 0;\n        const days = differenceInDays(end.value, start.value);\n        for (let i = 0; i < Math.abs(days); i++) {\n            result += this.getDayOccupancyWidth(start.addDays(i));\n        }\n        result = days >= 0 ? result : -result;\n        return Number(result.toFixed(3));\n    }\n\n    protected initialize() {\n        this.primaryDatePoints = this.getPrimaryDatePoints();\n        this.secondaryDatePoints = this.getSecondaryDatePoints();\n        this.width = this.getWidth();\n        this.cellWidth = this.getCellWidth();\n        this.primaryWidth = this.getPrimaryWidth();\n    }\n\n    addStartDate() {\n        const start = this.startOf(this.start.add(this.options.addAmount * -1, this.options.addUnit));\n        if (start.value >= this.options.min.value) {\n            const origin = this.start;\n            this.start$.next(start);\n            this.initialize();\n            return { start: this.start, end: origin };\n        }\n        return null;\n    }\n\n    addEndDate() {\n        const end = this.endOf(this.end.add(this.options.addAmount, this.options.addUnit));\n        if (end.value <= this.options.max.value) {\n            const origin = this.end;\n            this.end$.next(end);\n            this.initialize();\n            return { start: origin, end: this.end };\n        }\n        return null;\n    }\n\n    updateDate(start: GanttDate, end: GanttDate) {\n        start = this.startOf(start);\n        end = this.endOf(end);\n        if (start.value < this.start.value) {\n            this.start$.next(start);\n        }\n        if (end.value > this.end.value) {\n            this.end$.next(end);\n        }\n        this.initialize();\n    }\n\n    // 获取View的宽度\n    getWidth() {\n        return this.getCellWidth() * this.secondaryDatePoints.length;\n    }\n\n    // 获取单个网格的宽度\n    getCellWidth() {\n        return this.options.cellWidth;\n    }\n\n    // 获取当前时间的X坐标\n    getTodayXPoint(): number {\n        const toady = new GanttDate().startOfDay();\n        if (toady.value > this.start.value && toady.value < this.end.value) {\n            const x = this.getXPointByDate(toady) + this.getDayOccupancyWidth(toady) / 2;\n            return x;\n        } else {\n            return null;\n        }\n    }\n\n    // 获取指定时间的X坐标\n    getXPointByDate(date: GanttDate) {\n        return this.getDateIntervalWidth(this.start, date);\n    }\n\n    // 根据X坐标获取对应时间\n    getDateByXPoint(x: number): GanttDate {\n        let indexOfSecondaryDate: number;\n        let matchDate: GanttDatePoint;\n        let dayWidth: number;\n        let day: number;\n        if (x >= 0) {\n            indexOfSecondaryDate = Math.floor(x / this.getCellWidth());\n            matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];\n            dayWidth = this.getDayOccupancyWidth(matchDate?.start);\n        } else {\n            const datePointTemp = this.secondaryDatePoints[0];\n            dayWidth = this.getDayOccupancyWidth(datePointTemp?.start);\n            day = Math.floor(x / dayWidth);\n            return datePointTemp?.start.addDays(day);\n        }\n        if (dayWidth === this.getCellWidth()) {\n            return matchDate?.start;\n        } else {\n            day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;\n            if (indexOfSecondaryDate > this.secondaryDatePoints.length - 1) {\n                day += (indexOfSecondaryDate - (this.secondaryDatePoints.length - 1)) * 30;\n            }\n            if (this.getCellWidth() / dayWidth === 7) {\n                return matchDate?.start.addDays(day);\n            }\n            return matchDate?.start.setDate(day);\n        }\n    }\n\n    // 获取指定时间范围的宽度\n    getDateRangeWidth(start: GanttDate, end: GanttDate) {\n        // addSeconds(1) 是因为计算相差天会以一个整天来计算 end时间一般是59分59秒不是一个整天，所以需要加1\n        return this.getDateIntervalWidth(start, end.addSeconds(1));\n    }\n}\n"]}
@@ -491,14 +491,29 @@ class GanttView {
491
491
  }
492
492
  // 根据X坐标获取对应时间
493
493
  getDateByXPoint(x) {
494
- const indexOfSecondaryDate = Math.max(Math.floor(x / this.getCellWidth()), 0);
495
- const matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];
496
- const dayWidth = this.getDayOccupancyWidth(matchDate?.start);
494
+ let indexOfSecondaryDate;
495
+ let matchDate;
496
+ let dayWidth;
497
+ let day;
498
+ if (x >= 0) {
499
+ indexOfSecondaryDate = Math.floor(x / this.getCellWidth());
500
+ matchDate = this.secondaryDatePoints[Math.min(this.secondaryDatePoints.length - 1, indexOfSecondaryDate)];
501
+ dayWidth = this.getDayOccupancyWidth(matchDate?.start);
502
+ }
503
+ else {
504
+ const datePointTemp = this.secondaryDatePoints[0];
505
+ dayWidth = this.getDayOccupancyWidth(datePointTemp?.start);
506
+ day = Math.floor(x / dayWidth);
507
+ return datePointTemp?.start.addDays(day);
508
+ }
497
509
  if (dayWidth === this.getCellWidth()) {
498
510
  return matchDate?.start;
499
511
  }
500
512
  else {
501
- const day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;
513
+ day = Math.floor((x % this.getCellWidth()) / dayWidth) + 1;
514
+ if (indexOfSecondaryDate > this.secondaryDatePoints.length - 1) {
515
+ day += (indexOfSecondaryDate - (this.secondaryDatePoints.length - 1)) * 30;
516
+ }
502
517
  if (this.getCellWidth() / dayWidth === 7) {
503
518
  return matchDate?.start.addDays(day);
504
519
  }
@@ -905,6 +920,7 @@ class GanttUpper {
905
920
  this.viewType = GanttViewType.month;
906
921
  this.showTodayLine = true;
907
922
  this.showToolbar = false;
923
+ this.restrictToBounds = true;
908
924
  this.toolbarOptions = {
909
925
  viewTypes: [GanttViewType.day, GanttViewType.month, GanttViewType.year]
910
926
  };
@@ -1160,7 +1176,7 @@ class GanttUpper {
1160
1176
  this.changeView(this.viewType);
1161
1177
  }
1162
1178
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: GanttUpper, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: GANTT_GLOBAL_CONFIG }], target: i0.ɵɵFactoryTarget.Directive }); }
1163
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: GanttUpper, inputs: { originItems: ["items", "originItems"], originGroups: ["groups", "originGroups"], originBaselineItems: ["baselineItems", "originBaselineItems"], viewType: "viewType", start: "start", end: "end", showTodayLine: "showTodayLine", draggable: "draggable", styles: "styles", showToolbar: "showToolbar", toolbarOptions: "toolbarOptions", viewOptions: "viewOptions", linkOptions: "linkOptions", disabledLoadOnScroll: "disabledLoadOnScroll", selectable: "selectable", multiple: "multiple" }, outputs: { loadOnScroll: "loadOnScroll", dragStarted: "dragStarted", dragMoved: "dragMoved", dragEnded: "dragEnded", barClick: "barClick", viewChange: "viewChange", expandChange: "expandChange" }, host: { properties: { "class.gantt": "this.ganttClass" } }, queries: [{ propertyName: "barTemplate", first: true, predicate: ["bar"], descendants: true, static: true }, { propertyName: "rangeTemplate", first: true, predicate: ["range"], descendants: true, static: true }, { propertyName: "itemTemplate", first: true, predicate: ["item"], descendants: true, static: true }, { propertyName: "baselineTemplate", first: true, predicate: ["baseline"], descendants: true, static: true }, { propertyName: "groupTemplate", first: true, predicate: ["group"], descendants: true, static: true }, { propertyName: "groupHeaderTemplate", first: true, predicate: ["groupHeader"], descendants: true, static: true }, { propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0 }); }
1179
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: GanttUpper, inputs: { originItems: ["items", "originItems"], originGroups: ["groups", "originGroups"], originBaselineItems: ["baselineItems", "originBaselineItems"], viewType: "viewType", start: "start", end: "end", showTodayLine: "showTodayLine", draggable: "draggable", styles: "styles", showToolbar: "showToolbar", restrictToBounds: "restrictToBounds", toolbarOptions: "toolbarOptions", viewOptions: "viewOptions", linkOptions: "linkOptions", disabledLoadOnScroll: "disabledLoadOnScroll", selectable: "selectable", multiple: "multiple" }, outputs: { loadOnScroll: "loadOnScroll", dragStarted: "dragStarted", dragMoved: "dragMoved", dragEnded: "dragEnded", barClick: "barClick", viewChange: "viewChange", expandChange: "expandChange" }, host: { properties: { "class.gantt": "this.ganttClass" } }, queries: [{ propertyName: "barTemplate", first: true, predicate: ["bar"], descendants: true, static: true }, { propertyName: "rangeTemplate", first: true, predicate: ["range"], descendants: true, static: true }, { propertyName: "itemTemplate", first: true, predicate: ["item"], descendants: true, static: true }, { propertyName: "baselineTemplate", first: true, predicate: ["baseline"], descendants: true, static: true }, { propertyName: "groupTemplate", first: true, predicate: ["group"], descendants: true, static: true }, { propertyName: "groupHeaderTemplate", first: true, predicate: ["groupHeader"], descendants: true, static: true }, { propertyName: "toolbarTemplate", first: true, predicate: ["toolbar"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0 }); }
1164
1180
  }
1165
1181
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: GanttUpper, decorators: [{
1166
1182
  type: Directive
@@ -1190,6 +1206,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
1190
1206
  type: Input
1191
1207
  }], showToolbar: [{
1192
1208
  type: Input
1209
+ }], restrictToBounds: [{
1210
+ type: Input
1193
1211
  }], toolbarOptions: [{
1194
1212
  type: Input
1195
1213
  }], viewOptions: [{
@@ -2717,7 +2735,9 @@ class GanttBarDrag {
2717
2735
  createBarDrag() {
2718
2736
  const dragRef = this.createDragRef(this.barElement);
2719
2737
  dragRef.lockAxis = 'x';
2720
- dragRef.withBoundaryElement(this.dom.mainItems);
2738
+ if (this.ganttUpper.restrictToBounds) {
2739
+ dragRef.withBoundaryElement(this.dom.mainItems);
2740
+ }
2721
2741
  dragRef.started.subscribe(() => {
2722
2742
  this.setDraggingStyles();
2723
2743
  this.containerScrollLeft = this.dom.mainContainer.scrollLeft;
@@ -3070,6 +3090,9 @@ class GanttBarDrag {
3070
3090
  const itemEnd = end.getUnixTime();
3071
3091
  const viewStart = this.ganttUpper.view.start.getUnixTime();
3072
3092
  const viewEnd = this.ganttUpper.view.end.getUnixTime();
3093
+ if (!this.ganttUpper.restrictToBounds) {
3094
+ return true;
3095
+ }
3073
3096
  if (itemStart < viewStart || itemEnd > viewEnd) {
3074
3097
  return false;
3075
3098
  }