@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/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.1.1",
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",