@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.
- package/dist/canvas/GridLayer.d.ts +2 -2
- package/dist/canvas/ItemsLayer.d.ts +2 -1
- package/dist/canvas/defaultSummaryRenderer.d.ts +2 -0
- package/dist/canvas-timeline.cjs.js +1 -1
- package/dist/canvas-timeline.cjs.js.map +1 -1
- package/dist/canvas-timeline.es.js +1048 -782
- package/dist/canvas-timeline.es.js.map +1 -1
- package/dist/core/HierarchyEngine.d.ts +31 -0
- package/dist/core/LayoutEngine.d.ts +4 -1
- package/dist/index.d.ts +2 -1
- package/dist/interaction/snapUtils.d.ts +15 -0
- package/dist/types.d.ts +14 -1
- package/package.json +2 -1
|
@@ -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
|
|
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.
|
|
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",
|