@taskctrl/canvas-timeline 0.1.2 → 0.3.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.
@@ -0,0 +1,31 @@
1
+ interface HierarchyItem {
2
+ id: number;
3
+ start_time: number;
4
+ end_time: number;
5
+ parentId?: number;
6
+ }
7
+ export declare class HierarchyEngine {
8
+ private parentToChildren;
9
+ private childToParent;
10
+ private itemMap;
11
+ private depthCache;
12
+ rebuild(items: HierarchyItem[]): void;
13
+ isParent(itemId: number): boolean;
14
+ getParent(itemId: number): number | undefined;
15
+ getChildren(itemId: number): number[];
16
+ getDescendants(itemId: number): number[];
17
+ getEffectiveSpan(itemId: number): {
18
+ start: number;
19
+ end: number;
20
+ };
21
+ getNestingDepth(itemId: number): number;
22
+ getMoveDelta(itemId: number, newStart: number): {
23
+ itemId: number;
24
+ newStart: number;
25
+ }[];
26
+ getResizeConstraint(itemId: number, edge: 'left' | 'right'): {
27
+ min: number;
28
+ max: number;
29
+ };
30
+ }
31
+ export {};
@@ -1,4 +1,5 @@
1
1
  import type { Item } from '../types';
2
+ import type { HierarchyEngine } from './HierarchyEngine';
2
3
  export interface ItemLayout {
3
4
  stackLevel: number;
4
5
  itemHeight: number;
@@ -9,7 +10,9 @@ export declare class LayoutEngine {
9
10
  private layoutCache;
10
11
  private groupMaxStack;
11
12
  constructor(lineHeight: number, itemHeightRatio: number);
12
- computeLayout(items: Item[], stackItems: boolean): Map<number, ItemLayout>;
13
+ computeLayout(items: Item[], stackItems: boolean, hierarchy?: HierarchyEngine): Map<number, ItemLayout>;
14
+ private computeFlatLayout;
15
+ private computeHierarchyLayout;
13
16
  getLayout(itemId: number): ItemLayout | undefined;
14
17
  getGroupHeight(groupId: string | number): number;
15
18
  }
package/dist/index.d.ts CHANGED
@@ -1,6 +1,7 @@
1
- export type { Group, Item, ItemBounds, ItemState, DrawHelpers, CanvasItemRenderer, CanvasGroupItemRenderer, DayStyle, RowStyle, Dependency, TimelineTheme, MarkerConfig, CanvasTimelineProps, CanvasTimelineRef, CaptureOptions, } from './types';
1
+ export type { Group, Item, ItemBounds, ItemState, DrawHelpers, CanvasItemRenderer, CanvasGroupItemRenderer, DayStyle, RowStyle, Dependency, TimeRangeHighlight, TimelineTheme, MarkerConfig, CanvasTimelineProps, CanvasTimelineRef, CaptureOptions, } from './types';
2
2
  export { DEFAULT_THEME } from './types';
3
3
  export { CanvasTimeline } from './CanvasTimeline';
4
+ export { HierarchyEngine } from './core/HierarchyEngine';
4
5
  export { TodayMarker } from './dom/TodayMarker';
5
6
  export { CustomMarker } from './dom/CustomMarker';
6
7
  export { TimelineHeaders } from './dom/TimelineHeaders';
@@ -0,0 +1,15 @@
1
+ interface SnapItem {
2
+ id: number;
3
+ start_time: number;
4
+ end_time: number;
5
+ }
6
+ /**
7
+ * Collect start and end X positions from all items except the dragged item.
8
+ */
9
+ export declare function collectItemEdges(items: SnapItem[], excludeItemId: number, timeToX: (time: number) => number): number[];
10
+ /**
11
+ * Find the best snap target from a list of edge X positions.
12
+ * Returns the snapped X position if an edge is within threshold, or null to fall back to time-grid snap.
13
+ */
14
+ export declare function findSnapTarget(currentX: number, edgeXPositions: number[], thresholdPx: number, _pixelsPerMs: number, _dragSnap: number): number | null;
15
+ export {};
package/dist/types.d.ts CHANGED
@@ -12,6 +12,7 @@ export interface Item {
12
12
  group: number | string;
13
13
  start_time: number;
14
14
  end_time: number;
15
+ parentId?: number;
15
16
  type?: string;
16
17
  [key: string]: unknown;
17
18
  }
@@ -52,6 +53,13 @@ export interface Dependency {
52
53
  type?: 'finish-to-start' | 'start-to-start' | 'finish-to-finish';
53
54
  color?: string;
54
55
  }
56
+ export interface TimeRangeHighlight {
57
+ start: number;
58
+ end: number;
59
+ color: string;
60
+ label?: string;
61
+ opacity?: number;
62
+ }
55
63
  export interface TimelineTheme {
56
64
  primary: string;
57
65
  trainColors: Record<string, string>;
@@ -117,14 +125,19 @@ export interface CanvasTimelineProps {
117
125
  showCursorLine?: boolean;
118
126
  itemRenderer: CanvasItemRenderer;
119
127
  groupRenderer?: CanvasGroupItemRenderer;
128
+ summaryRenderer?: CanvasItemRenderer;
120
129
  sidebarGroupRenderer: (group: Group) => React.ReactNode;
121
130
  rightSidebarWidth?: number;
122
131
  rightSidebarGroupRenderer?: (group: Group) => React.ReactNode;
123
132
  dependencies?: Dependency[];
133
+ highlights?: TimeRangeHighlight[];
124
134
  onItemClick?: (itemId: number, e: PointerEvent) => void;
125
135
  onItemDoubleClick?: (itemId: number, e: PointerEvent) => void;
126
136
  onItemContextMenu?: (itemId: number, e: PointerEvent) => void;
127
- onItemMove?: (itemId: number, newStartTime: number, newGroupId: string | number) => void;
137
+ onItemMove?: (itemId: number, newStartTime: number, newGroupId: string | number, childMoves?: {
138
+ itemId: number;
139
+ newStart: number;
140
+ }[]) => void;
128
141
  onItemResize?: (itemId: number, newTime: number, edge: 'left' | 'right') => void;
129
142
  /** Validate and optionally constrain move/resize. Return the (possibly modified) time. */
130
143
  moveResizeValidator?: (action: 'move' | 'resize', itemId: number, time: number, edge?: 'left' | 'right') => number;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@taskctrl/canvas-timeline",
3
- "version": "0.1.2",
3
+ "version": "0.3.0",
4
4
  "description": "High-performance canvas-based timeline component for React",
5
5
  "scripts": {
6
6
  "build": "rimraf ./dist && tsc && vite build",
@@ -8,6 +8,7 @@
8
8
  "test:watch": "vitest",
9
9
  "test:coverage": "vitest run --coverage",
10
10
  "lint": "eslint --ext .ts --ext .tsx ./src",
11
+ "prepublishOnly": "yarn build",
11
12
  "release": "yarn release:patch",
12
13
  "release:patch": "npm version patch -m \"chore: release v%s\" && git push origin HEAD --follow-tags",
13
14
  "release:minor": "npm version minor -m \"chore: release v%s\" && git push origin HEAD --follow-tags",