@taskctrl/canvas-timeline 0.1.1 → 0.2.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 +1 -1
- package/dist/canvas-timeline.cjs.js +1 -1
- package/dist/canvas-timeline.cjs.js.map +1 -1
- package/dist/canvas-timeline.es.js +816 -734
- package/dist/canvas-timeline.es.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/interaction/snapUtils.d.ts +15 -0
- package/dist/types.d.ts +8 -0
- package/package.json +7 -2
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
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
4
|
export { TodayMarker } from './dom/TodayMarker';
|
|
@@ -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
|
@@ -52,6 +52,13 @@ export interface Dependency {
|
|
|
52
52
|
type?: 'finish-to-start' | 'start-to-start' | 'finish-to-finish';
|
|
53
53
|
color?: string;
|
|
54
54
|
}
|
|
55
|
+
export interface TimeRangeHighlight {
|
|
56
|
+
start: number;
|
|
57
|
+
end: number;
|
|
58
|
+
color: string;
|
|
59
|
+
label?: string;
|
|
60
|
+
opacity?: number;
|
|
61
|
+
}
|
|
55
62
|
export interface TimelineTheme {
|
|
56
63
|
primary: string;
|
|
57
64
|
trainColors: Record<string, string>;
|
|
@@ -121,6 +128,7 @@ export interface CanvasTimelineProps {
|
|
|
121
128
|
rightSidebarWidth?: number;
|
|
122
129
|
rightSidebarGroupRenderer?: (group: Group) => React.ReactNode;
|
|
123
130
|
dependencies?: Dependency[];
|
|
131
|
+
highlights?: TimeRangeHighlight[];
|
|
124
132
|
onItemClick?: (itemId: number, e: PointerEvent) => void;
|
|
125
133
|
onItemDoubleClick?: (itemId: number, e: PointerEvent) => void;
|
|
126
134
|
onItemContextMenu?: (itemId: number, e: PointerEvent) => void;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@taskctrl/canvas-timeline",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "High-performance canvas-based timeline component for React",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "rimraf ./dist && tsc && vite build",
|
|
@@ -8,7 +8,12 @@
|
|
|
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
|
+
"prepublishOnly": "yarn build",
|
|
12
|
+
"release": "yarn release:patch",
|
|
13
|
+
"release:patch": "npm version patch -m \"chore: release v%s\" && git push origin HEAD --follow-tags",
|
|
14
|
+
"release:minor": "npm version minor -m \"chore: release v%s\" && git push origin HEAD --follow-tags",
|
|
15
|
+
"release:major": "npm version major -m \"chore: release v%s\" && git push origin HEAD --follow-tags",
|
|
16
|
+
"release:beta": "npm version prerelease --preid=beta -m \"chore: release v%s\" && git push origin HEAD --follow-tags"
|
|
12
17
|
},
|
|
13
18
|
"main": "./dist/canvas-timeline.cjs.js",
|
|
14
19
|
"module": "./dist/canvas-timeline.es.js",
|