@clipkit/editor 1.0.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.
Files changed (248) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +51 -0
  3. package/dist/Editor.d.ts +3 -0
  4. package/dist/Editor.d.ts.map +1 -0
  5. package/dist/Editor.js +73 -0
  6. package/dist/Editor.js.map +1 -0
  7. package/dist/ExportDialog.d.ts +12 -0
  8. package/dist/ExportDialog.d.ts.map +1 -0
  9. package/dist/ExportDialog.js +30 -0
  10. package/dist/ExportDialog.js.map +1 -0
  11. package/dist/MotionPathOverlay.d.ts +5 -0
  12. package/dist/MotionPathOverlay.d.ts.map +1 -0
  13. package/dist/MotionPathOverlay.js +156 -0
  14. package/dist/MotionPathOverlay.js.map +1 -0
  15. package/dist/PerfHud.d.ts +2 -0
  16. package/dist/PerfHud.d.ts.map +1 -0
  17. package/dist/PerfHud.js +85 -0
  18. package/dist/PerfHud.js.map +1 -0
  19. package/dist/Stage.d.ts +2 -0
  20. package/dist/Stage.d.ts.map +1 -0
  21. package/dist/Stage.js +406 -0
  22. package/dist/Stage.js.map +1 -0
  23. package/dist/StageOverlay.d.ts +7 -0
  24. package/dist/StageOverlay.d.ts.map +1 -0
  25. package/dist/StageOverlay.js +508 -0
  26. package/dist/StageOverlay.js.map +1 -0
  27. package/dist/commands.d.ts +18 -0
  28. package/dist/commands.d.ts.map +1 -0
  29. package/dist/commands.js +103 -0
  30. package/dist/commands.js.map +1 -0
  31. package/dist/configuration.d.ts +9 -0
  32. package/dist/configuration.d.ts.map +1 -0
  33. package/dist/configuration.js +21 -0
  34. package/dist/configuration.js.map +1 -0
  35. package/dist/controls/AnimationsStack.d.ts +8 -0
  36. package/dist/controls/AnimationsStack.d.ts.map +1 -0
  37. package/dist/controls/AnimationsStack.js +188 -0
  38. package/dist/controls/AnimationsStack.js.map +1 -0
  39. package/dist/controls/CameraControl.d.ts +19 -0
  40. package/dist/controls/CameraControl.d.ts.map +1 -0
  41. package/dist/controls/CameraControl.js +47 -0
  42. package/dist/controls/CameraControl.js.map +1 -0
  43. package/dist/controls/CaptionLengthControl.d.ts +5 -0
  44. package/dist/controls/CaptionLengthControl.d.ts.map +1 -0
  45. package/dist/controls/CaptionLengthControl.js +11 -0
  46. package/dist/controls/CaptionLengthControl.js.map +1 -0
  47. package/dist/controls/CaptionTranscribe.d.ts +2 -0
  48. package/dist/controls/CaptionTranscribe.d.ts.map +1 -0
  49. package/dist/controls/CaptionTranscribe.js +95 -0
  50. package/dist/controls/CaptionTranscribe.js.map +1 -0
  51. package/dist/controls/ColorPicker.d.ts +17 -0
  52. package/dist/controls/ColorPicker.d.ts.map +1 -0
  53. package/dist/controls/ColorPicker.js +354 -0
  54. package/dist/controls/ColorPicker.js.map +1 -0
  55. package/dist/controls/ControlRenderer.d.ts +20 -0
  56. package/dist/controls/ControlRenderer.d.ts.map +1 -0
  57. package/dist/controls/ControlRenderer.js +106 -0
  58. package/dist/controls/ControlRenderer.js.map +1 -0
  59. package/dist/controls/CropControl.d.ts +2 -0
  60. package/dist/controls/CropControl.d.ts.map +1 -0
  61. package/dist/controls/CropControl.js +177 -0
  62. package/dist/controls/CropControl.js.map +1 -0
  63. package/dist/controls/EffectsStack.d.ts +8 -0
  64. package/dist/controls/EffectsStack.d.ts.map +1 -0
  65. package/dist/controls/EffectsStack.js +89 -0
  66. package/dist/controls/EffectsStack.js.map +1 -0
  67. package/dist/controls/GradeControl.d.ts +2 -0
  68. package/dist/controls/GradeControl.d.ts.map +1 -0
  69. package/dist/controls/GradeControl.js +120 -0
  70. package/dist/controls/GradeControl.js.map +1 -0
  71. package/dist/controls/KeyframeDiamond.d.ts +11 -0
  72. package/dist/controls/KeyframeDiamond.d.ts.map +1 -0
  73. package/dist/controls/KeyframeDiamond.js +87 -0
  74. package/dist/controls/KeyframeDiamond.js.map +1 -0
  75. package/dist/controls/LightingControls.d.ts +24 -0
  76. package/dist/controls/LightingControls.d.ts.map +1 -0
  77. package/dist/controls/LightingControls.js +108 -0
  78. package/dist/controls/LightingControls.js.map +1 -0
  79. package/dist/controls/ShapePresetControl.d.ts +4 -0
  80. package/dist/controls/ShapePresetControl.d.ts.map +1 -0
  81. package/dist/controls/ShapePresetControl.js +30 -0
  82. package/dist/controls/ShapePresetControl.js.map +1 -0
  83. package/dist/controls/ValueField.d.ts +10 -0
  84. package/dist/controls/ValueField.d.ts.map +1 -0
  85. package/dist/controls/ValueField.js +158 -0
  86. package/dist/controls/ValueField.js.map +1 -0
  87. package/dist/controls/VolumeControl.d.ts +10 -0
  88. package/dist/controls/VolumeControl.d.ts.map +1 -0
  89. package/dist/controls/VolumeControl.js +75 -0
  90. package/dist/controls/VolumeControl.js.map +1 -0
  91. package/dist/controls/compound.d.ts +46 -0
  92. package/dist/controls/compound.d.ts.map +1 -0
  93. package/dist/controls/compound.js +160 -0
  94. package/dist/controls/compound.js.map +1 -0
  95. package/dist/controls/layout.d.ts +38 -0
  96. package/dist/controls/layout.d.ts.map +1 -0
  97. package/dist/controls/layout.js +162 -0
  98. package/dist/controls/layout.js.map +1 -0
  99. package/dist/controls/primitives.d.ts +83 -0
  100. package/dist/controls/primitives.d.ts.map +1 -0
  101. package/dist/controls/primitives.js +194 -0
  102. package/dist/controls/primitives.js.map +1 -0
  103. package/dist/controls/transcribe.worker.d.ts +2 -0
  104. package/dist/controls/transcribe.worker.d.ts.map +1 -0
  105. package/dist/controls/transcribe.worker.js +22 -0
  106. package/dist/controls/transcribe.worker.js.map +1 -0
  107. package/dist/frame/AddElementBar.d.ts +2 -0
  108. package/dist/frame/AddElementBar.d.ts.map +1 -0
  109. package/dist/frame/AddElementBar.js +103 -0
  110. package/dist/frame/AddElementBar.js.map +1 -0
  111. package/dist/frame/Breadcrumbs.d.ts +2 -0
  112. package/dist/frame/Breadcrumbs.d.ts.map +1 -0
  113. package/dist/frame/Breadcrumbs.js +32 -0
  114. package/dist/frame/Breadcrumbs.js.map +1 -0
  115. package/dist/frame/GroupFlash.d.ts +2 -0
  116. package/dist/frame/GroupFlash.d.ts.map +1 -0
  117. package/dist/frame/GroupFlash.js +65 -0
  118. package/dist/frame/GroupFlash.js.map +1 -0
  119. package/dist/frame/Resizable.d.ts +12 -0
  120. package/dist/frame/Resizable.d.ts.map +1 -0
  121. package/dist/frame/Resizable.js +37 -0
  122. package/dist/frame/Resizable.js.map +1 -0
  123. package/dist/frame/Section.d.ts +23 -0
  124. package/dist/frame/Section.d.ts.map +1 -0
  125. package/dist/frame/Section.js +23 -0
  126. package/dist/frame/Section.js.map +1 -0
  127. package/dist/frame/ZoomControl.d.ts +9 -0
  128. package/dist/frame/ZoomControl.d.ts.map +1 -0
  129. package/dist/frame/ZoomControl.js +15 -0
  130. package/dist/frame/ZoomControl.js.map +1 -0
  131. package/dist/index.d.ts +9 -0
  132. package/dist/index.d.ts.map +1 -0
  133. package/dist/index.js +13 -0
  134. package/dist/index.js.map +1 -0
  135. package/dist/lib/camera-gizmo.d.ts +15 -0
  136. package/dist/lib/camera-gizmo.d.ts.map +1 -0
  137. package/dist/lib/camera-gizmo.js +57 -0
  138. package/dist/lib/camera-gizmo.js.map +1 -0
  139. package/dist/lib/camera-tool.d.ts +43 -0
  140. package/dist/lib/camera-tool.d.ts.map +1 -0
  141. package/dist/lib/camera-tool.js +80 -0
  142. package/dist/lib/camera-tool.js.map +1 -0
  143. package/dist/lib/caption-segments.d.ts +17 -0
  144. package/dist/lib/caption-segments.d.ts.map +1 -0
  145. package/dist/lib/caption-segments.js +50 -0
  146. package/dist/lib/caption-segments.js.map +1 -0
  147. package/dist/lib/group.d.ts +12 -0
  148. package/dist/lib/group.d.ts.map +1 -0
  149. package/dist/lib/group.js +61 -0
  150. package/dist/lib/group.js.map +1 -0
  151. package/dist/lib/keyframes.d.ts +29 -0
  152. package/dist/lib/keyframes.d.ts.map +1 -0
  153. package/dist/lib/keyframes.js +92 -0
  154. package/dist/lib/keyframes.js.map +1 -0
  155. package/dist/lib/sfx-preview.d.ts +18 -0
  156. package/dist/lib/sfx-preview.d.ts.map +1 -0
  157. package/dist/lib/sfx-preview.js +74 -0
  158. package/dist/lib/sfx-preview.js.map +1 -0
  159. package/dist/lib/shape-presets.d.ts +35 -0
  160. package/dist/lib/shape-presets.d.ts.map +1 -0
  161. package/dist/lib/shape-presets.js +81 -0
  162. package/dist/lib/shape-presets.js.map +1 -0
  163. package/dist/lib/ungroup.d.ts +12 -0
  164. package/dist/lib/ungroup.d.ts.map +1 -0
  165. package/dist/lib/ungroup.js +40 -0
  166. package/dist/lib/ungroup.js.map +1 -0
  167. package/dist/lib/utils.d.ts +3 -0
  168. package/dist/lib/utils.d.ts.map +1 -0
  169. package/dist/lib/utils.js +9 -0
  170. package/dist/lib/utils.js.map +1 -0
  171. package/dist/panels/AssetsPanel.d.ts +2 -0
  172. package/dist/panels/AssetsPanel.d.ts.map +1 -0
  173. package/dist/panels/AssetsPanel.js +108 -0
  174. package/dist/panels/AssetsPanel.js.map +1 -0
  175. package/dist/panels/InspectorPanel.d.ts +2 -0
  176. package/dist/panels/InspectorPanel.d.ts.map +1 -0
  177. package/dist/panels/InspectorPanel.js +286 -0
  178. package/dist/panels/InspectorPanel.js.map +1 -0
  179. package/dist/panels/InterpolationPanel.d.ts +2 -0
  180. package/dist/panels/InterpolationPanel.d.ts.map +1 -0
  181. package/dist/panels/InterpolationPanel.js +226 -0
  182. package/dist/panels/InterpolationPanel.js.map +1 -0
  183. package/dist/panels/LayersTree.d.ts +4 -0
  184. package/dist/panels/LayersTree.d.ts.map +1 -0
  185. package/dist/panels/LayersTree.js +137 -0
  186. package/dist/panels/LayersTree.js.map +1 -0
  187. package/dist/panels/LeftRail.d.ts +6 -0
  188. package/dist/panels/LeftRail.d.ts.map +1 -0
  189. package/dist/panels/LeftRail.js +35 -0
  190. package/dist/panels/LeftRail.js.map +1 -0
  191. package/dist/panels/SourcePanel.d.ts +2 -0
  192. package/dist/panels/SourcePanel.d.ts.map +1 -0
  193. package/dist/panels/SourcePanel.js +470 -0
  194. package/dist/panels/SourcePanel.js.map +1 -0
  195. package/dist/panels/TimelinePanel.d.ts +11 -0
  196. package/dist/panels/TimelinePanel.d.ts.map +1 -0
  197. package/dist/panels/TimelinePanel.js +98 -0
  198. package/dist/panels/TimelinePanel.js.map +1 -0
  199. package/dist/panels/assets/SfxBrowser.d.ts +2 -0
  200. package/dist/panels/assets/SfxBrowser.d.ts.map +1 -0
  201. package/dist/panels/assets/SfxBrowser.js +49 -0
  202. package/dist/panels/assets/SfxBrowser.js.map +1 -0
  203. package/dist/panels/assets/use-assets.d.ts +11 -0
  204. package/dist/panels/assets/use-assets.d.ts.map +1 -0
  205. package/dist/panels/assets/use-assets.js +84 -0
  206. package/dist/panels/assets/use-assets.js.map +1 -0
  207. package/dist/panels/assets/use-sfx.d.ts +6 -0
  208. package/dist/panels/assets/use-sfx.d.ts.map +1 -0
  209. package/dist/panels/assets/use-sfx.js +47 -0
  210. package/dist/panels/assets/use-sfx.js.map +1 -0
  211. package/dist/panels/timeline/CanvasTimeline.d.ts +7 -0
  212. package/dist/panels/timeline/CanvasTimeline.d.ts.map +1 -0
  213. package/dist/panels/timeline/CanvasTimeline.js +1536 -0
  214. package/dist/panels/timeline/CanvasTimeline.js.map +1 -0
  215. package/dist/panels/timeline/Clip.d.ts +37 -0
  216. package/dist/panels/timeline/Clip.d.ts.map +1 -0
  217. package/dist/panels/timeline/Clip.js +176 -0
  218. package/dist/panels/timeline/Clip.js.map +1 -0
  219. package/dist/panels/timeline/CurveEditor.d.ts +2 -0
  220. package/dist/panels/timeline/CurveEditor.d.ts.map +1 -0
  221. package/dist/panels/timeline/CurveEditor.js +233 -0
  222. package/dist/panels/timeline/CurveEditor.js.map +1 -0
  223. package/dist/panels/timeline/MixerRail.d.ts +7 -0
  224. package/dist/panels/timeline/MixerRail.d.ts.map +1 -0
  225. package/dist/panels/timeline/MixerRail.js +295 -0
  226. package/dist/panels/timeline/MixerRail.js.map +1 -0
  227. package/dist/panels/timeline/Waveform.d.ts +11 -0
  228. package/dist/panels/timeline/Waveform.d.ts.map +1 -0
  229. package/dist/panels/timeline/Waveform.js +63 -0
  230. package/dist/panels/timeline/Waveform.js.map +1 -0
  231. package/dist/panels/timeline/clip-style.d.ts +10 -0
  232. package/dist/panels/timeline/clip-style.d.ts.map +1 -0
  233. package/dist/panels/timeline/clip-style.js +20 -0
  234. package/dist/panels/timeline/clip-style.js.map +1 -0
  235. package/dist/panels/timeline/filmstrip.d.ts +7 -0
  236. package/dist/panels/timeline/filmstrip.d.ts.map +1 -0
  237. package/dist/panels/timeline/filmstrip.js +135 -0
  238. package/dist/panels/timeline/filmstrip.js.map +1 -0
  239. package/dist/panels/timeline/timeline-layout.d.ts +65 -0
  240. package/dist/panels/timeline/timeline-layout.d.ts.map +1 -0
  241. package/dist/panels/timeline/timeline-layout.js +118 -0
  242. package/dist/panels/timeline/timeline-layout.js.map +1 -0
  243. package/dist/types.d.ts +68 -0
  244. package/dist/types.d.ts.map +1 -0
  245. package/dist/types.js +3 -0
  246. package/dist/types.js.map +1 -0
  247. package/package.json +56 -0
  248. package/src/styles.css +185 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SfxBrowser.d.ts","sourceRoot":"","sources":["../../../src/panels/assets/SfxBrowser.tsx"],"names":[],"mappings":"AAaA,wBAAgB,UAAU,gCA8GzB"}
@@ -0,0 +1,49 @@
1
+ // SfxBrowser — the "see all" SFX library: search, category filter, preview on
2
+ // click, drop on the timeline. Driven entirely by the @clipkit/sfx catalog
3
+ // (listSfx / sfxCategories / renderSfx). Every entry is synth — click to
4
+ // preview, + to drop it at the playhead.
5
+ 'use client';
6
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
7
+ import { useMemo, useState } from 'react';
8
+ import { Play, Plus } from 'lucide-react';
9
+ import { listSfx, sfxCategories } from '@clipkit/sfx';
10
+ import { cn } from '../../lib/utils.js';
11
+ import { useSfxActions } from './use-sfx.js';
12
+ export function SfxBrowser() {
13
+ const { preview, addToTimeline } = useSfxActions();
14
+ const [query, setQuery] = useState('');
15
+ const [category, setCategory] = useState(null);
16
+ const [playing, setPlaying] = useState(null);
17
+ const categories = useMemo(() => sfxCategories(), []);
18
+ const all = useMemo(() => listSfx(), []);
19
+ const results = useMemo(() => {
20
+ const q = query.trim().toLowerCase();
21
+ return all.filter((e) => {
22
+ if (category && e.category !== category)
23
+ return false;
24
+ if (!q)
25
+ return true;
26
+ return (e.label.toLowerCase().includes(q) ||
27
+ e.name.toLowerCase().includes(q) ||
28
+ e.category.includes(q) ||
29
+ e.tags.some((t) => t.includes(q)));
30
+ });
31
+ }, [all, query, category]);
32
+ const onPreview = (e) => {
33
+ setPlaying(e.name);
34
+ preview(e);
35
+ };
36
+ return (_jsxs("div", { className: "flex flex-col h-full", children: [_jsxs("div", { className: "px-2 py-2 border-b border-border shrink-0", children: [_jsx("input", { value: query, onChange: (ev) => setQuery(ev.target.value), placeholder: "Search sound effects\u2026", className: "w-full h-7 bg-card border border-border rounded px-2 text-[11px] text-foreground placeholder:text-muted-foreground/60 outline-none focus:border-primary/50" }), _jsxs("div", { className: "flex flex-wrap gap-1 mt-2", children: [_jsx(Chip, { active: category === null, onClick: () => setCategory(null), children: "All" }), categories.map((c) => (_jsx(Chip, { active: category === c, onClick: () => setCategory(c), children: c }, c)))] })] }), _jsx("div", { className: "flex-1 min-h-0 overflow-y-auto", children: results.length === 0 ? (_jsx("div", { className: "h-full grid place-items-center", children: _jsx("span", { className: "text-[11px] text-muted-foreground/60", children: "No matches" }) })) : (results.map((e) => (_jsxs("div", { className: cn('group/sfx flex items-center gap-2 h-9 px-2 border-b border-border/30 hover:bg-card cursor-default', playing === e.name && 'bg-primary/10'), onClick: () => onPreview(e), children: [_jsx("button", { type: "button", title: "Preview", className: "w-5 h-5 shrink-0 grid place-items-center rounded text-muted-foreground hover:text-foreground hover:bg-primary/15", onClick: (ev) => {
37
+ ev.stopPropagation();
38
+ onPreview(e);
39
+ }, children: _jsx(Play, { size: 11, fill: "currentColor" }) }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsx("div", { className: "truncate text-[11px] text-foreground/90", children: e.label }), _jsx("div", { className: "truncate text-[9px] text-muted-foreground/70", children: e.category })] }), _jsx("button", { type: "button", title: "Add at playhead", className: "w-5 h-5 shrink-0 grid place-items-center rounded text-muted-foreground/50 opacity-0 group-hover/sfx:opacity-100 hover:text-foreground hover:bg-primary/15 transition", onClick: (ev) => {
40
+ ev.stopPropagation();
41
+ addToTimeline(e);
42
+ }, children: _jsx(Plus, { size: 12 }) })] }, e.name)))) }), _jsxs("div", { className: "flex items-center justify-between h-6 px-2 border-t border-border text-[9px] text-muted-foreground/60 shrink-0", children: [_jsxs("span", { children: [results.length, " sounds"] }), _jsx("span", { children: "click to preview \u00B7 + to add" })] })] }));
43
+ }
44
+ function Chip({ active, onClick, children, }) {
45
+ return (_jsx("button", { type: "button", onClick: onClick, className: cn('h-5 px-1.5 rounded text-[9px] capitalize transition-colors', active
46
+ ? 'bg-primary/20 text-foreground'
47
+ : 'text-muted-foreground hover:text-foreground hover:bg-card'), children: children }));
48
+ }
49
+ //# sourceMappingURL=SfxBrowser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SfxBrowser.js","sourceRoot":"","sources":["../../../src/panels/assets/SfxBrowser.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { type ClipkitAsset } from '@clipkit/editor-core';
2
+ export declare function useAssets(): {
3
+ assets: ClipkitAsset[];
4
+ busy: boolean;
5
+ error: string | null;
6
+ importFiles: (files: FileList | File[]) => Promise<void>;
7
+ remove: (id: string) => Promise<void>;
8
+ addToTimeline: (asset: ClipkitAsset) => string;
9
+ refresh: () => Promise<void>;
10
+ };
11
+ //# sourceMappingURL=use-assets.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-assets.d.ts","sourceRoot":"","sources":["../../../src/panels/assets/use-assets.ts"],"names":[],"mappings":"AAQA,OAAO,EAIL,KAAK,YAAY,EAClB,MAAM,sBAAsB,CAAC;AAQ9B,wBAAgB,SAAS;;;;yBAyBP,QAAQ,GAAG,IAAI,EAAE;iBAkBpB,MAAM;2BAYT,YAAY,KAAG,MAAM;;EA2BhC"}
@@ -0,0 +1,84 @@
1
+ // Media-bin actions for the Assets tab. Reads/writes through the injected
2
+ // AssetStore (local IndexedDB by default), and drops an asset on the timeline
3
+ // as the matching element (image/video/audio) at the playhead.
4
+ 'use client';
5
+ import { useCallback, useEffect, useState } from 'react';
6
+ import { useEditor, useEditorContext, useEditorStore, } from '@clipkit/editor-core';
7
+ function num(v, d) {
8
+ return typeof v === 'number' && Number.isFinite(v) ? v : d;
9
+ }
10
+ let dropCounter = 0;
11
+ export function useAssets() {
12
+ const { assetStore } = useEditorContext();
13
+ const { addElement } = useEditor();
14
+ const playheadTime = useEditorStore((s) => s.playback.time);
15
+ const elements = useEditorStore((s) => s.source.elements);
16
+ const compW = useEditorStore((s) => num(s.source.width, 1920));
17
+ const compH = useEditorStore((s) => num(s.source.height, 1080));
18
+ const [assets, setAssets] = useState([]);
19
+ const [busy, setBusy] = useState(false);
20
+ const [error, setError] = useState(null);
21
+ const refresh = useCallback(async () => {
22
+ try {
23
+ setAssets(await assetStore.list());
24
+ }
25
+ catch (e) {
26
+ setError(e instanceof Error ? e.message : 'Could not load media');
27
+ }
28
+ }, [assetStore]);
29
+ useEffect(() => {
30
+ void refresh();
31
+ }, [refresh]);
32
+ const importFiles = useCallback(async (files) => {
33
+ const list = Array.from(files);
34
+ if (list.length === 0)
35
+ return;
36
+ setBusy(true);
37
+ setError(null);
38
+ try {
39
+ for (const f of list)
40
+ await assetStore.upload(f);
41
+ await refresh();
42
+ }
43
+ catch (e) {
44
+ setError(e instanceof Error ? e.message : 'Upload failed');
45
+ }
46
+ finally {
47
+ setBusy(false);
48
+ }
49
+ }, [assetStore, refresh]);
50
+ const remove = useCallback(async (id) => {
51
+ try {
52
+ await assetStore.remove(id);
53
+ await refresh();
54
+ }
55
+ catch (e) {
56
+ setError(e instanceof Error ? e.message : 'Could not remove');
57
+ }
58
+ }, [assetStore, refresh]);
59
+ const addToTimeline = useCallback((asset) => {
60
+ const id = `${asset.kind}-${(dropCounter++).toString(36)}`;
61
+ const time = Math.max(0, playheadTime);
62
+ // layer is assigned on add — the store places new elements on top (layer 1).
63
+ const base = { id, name: asset.name, time, layer: 1 };
64
+ let el;
65
+ if (asset.kind === 'audio') {
66
+ el = { ...base, type: 'audio', source: asset.url, duration: asset.duration ?? 5, volume: 100 };
67
+ }
68
+ else {
69
+ // image/video: fit intrinsic size inside the composition, keep aspect.
70
+ const iw = num(asset.width, compW), ih = num(asset.height, compH);
71
+ const scale = Math.min(1, compW / iw, compH / ih);
72
+ const width = Math.round(iw * scale), height = Math.round(ih * scale);
73
+ const duration = asset.kind === 'video' ? asset.duration ?? 5 : 3;
74
+ // Centre the asset in the comp explicitly (x/y at the centre with a
75
+ // centre anchor). Without an explicit anchor the runtime now places
76
+ // x/y at the top-left corner, so a bare drop would land off-centre.
77
+ el = { ...base, type: asset.kind, source: asset.url, x: compW / 2, y: compH / 2, x_anchor: '50%', y_anchor: '50%', width, height, duration };
78
+ }
79
+ addElement(el);
80
+ return id;
81
+ }, [addElement, elements, playheadTime, compW, compH]);
82
+ return { assets, busy, error, importFiles, remove, addToTimeline, refresh };
83
+ }
84
+ //# sourceMappingURL=use-assets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-assets.js","sourceRoot":"","sources":["../../../src/panels/assets/use-assets.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { type SfxEntry } from '@clipkit/sfx';
2
+ export declare function useSfxActions(): {
3
+ preview: (entry: SfxEntry) => number;
4
+ addToTimeline: (entry: SfxEntry) => string | null;
5
+ };
6
+ //# sourceMappingURL=use-sfx.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-sfx.d.ts","sourceRoot":"","sources":["../../../src/panels/assets/use-sfx.ts"],"names":[],"mappings":"AAaA,OAAO,EAAa,KAAK,QAAQ,EAAE,MAAM,cAAc,CAAC;AAKxD,wBAAgB,aAAa;qBAMS,QAAQ,KAAG,MAAM;2BAQ3C,QAAQ,KAAG,MAAM,GAAG,IAAI;EAwBnC"}
@@ -0,0 +1,47 @@
1
+ // Shared SFX actions for the Assets tab: render a catalog entry, preview it,
2
+ // and drop it on the timeline as a runtime-native `audio` element.
3
+ //
4
+ // "Drop on the timeline" = render the (finished) SFX → encode a WAV object-URL
5
+ // → addElement({ type:'audio', source:url, … }) at the playhead, on a fresh
6
+ // lane. The runtime mixes it in preview/export like any other audio — no
7
+ // special-casing, no ffmpeg.
8
+ 'use client';
9
+ import { useCallback } from 'react';
10
+ import { useEditor, useEditorStore } from '@clipkit/editor-core';
11
+ import { renderSfx } from '@clipkit/sfx';
12
+ import { playSfx, sfxDuration, sfxToObjectUrl } from '../../lib/sfx-preview.js';
13
+ let dropCounter = 0;
14
+ export function useSfxActions() {
15
+ const { addElement } = useEditor();
16
+ const playheadTime = useEditorStore((s) => s.playback.time);
17
+ const elements = useEditorStore((s) => s.source.elements);
18
+ /** Render + preview a catalog entry. Returns its duration (0 if not playable). */
19
+ const preview = useCallback((entry) => {
20
+ const sfx = renderSfx(entry.name);
21
+ if (!sfx)
22
+ return 0;
23
+ return playSfx(sfx);
24
+ }, []);
25
+ /** Drop a catalog entry on the timeline at the playhead. Returns the new id. */
26
+ const addToTimeline = useCallback((entry) => {
27
+ const sfx = renderSfx(entry.name);
28
+ if (!sfx)
29
+ return null;
30
+ const url = sfxToObjectUrl(sfx);
31
+ const duration = sfxDuration(sfx);
32
+ const id = `sfx-${entry.name}-${(dropCounter++).toString(36)}`;
33
+ addElement({
34
+ type: 'audio',
35
+ id,
36
+ name: entry.label,
37
+ source: url,
38
+ time: Math.max(0, playheadTime),
39
+ duration,
40
+ volume: 100,
41
+ layer: 1,
42
+ });
43
+ return id;
44
+ }, [addElement, elements, playheadTime]);
45
+ return { preview, addToTimeline };
46
+ }
47
+ //# sourceMappingURL=use-sfx.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-sfx.js","sourceRoot":"","sources":["../../../src/panels/assets/use-sfx.ts"],"names":[],"mappings":"AAAA,6EAA6E;AAC7E,mEAAmE;AACnE,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,yEAAyE;AACzE,6BAA6B;AAE7B,YAAY,CAAC;AAEb,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAEpC,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACjE,OAAO,EAAE,SAAS,EAAiB,MAAM,cAAc,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAEhF,IAAI,WAAW,GAAG,CAAC,CAAC;AAEpB,MAAM,UAAU,aAAa;IAC3B,MAAM,EAAE,UAAU,EAAE,GAAG,SAAS,EAAE,CAAC;IACnC,MAAM,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC5D,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAE1D,kFAAkF;IAClF,MAAM,OAAO,GAAG,WAAW,CAAC,CAAC,KAAe,EAAU,EAAE;QACtD,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,GAAG;YAAE,OAAO,CAAC,CAAC;QACnB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC;IACtB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,gFAAgF;IAChF,MAAM,aAAa,GAAG,WAAW,CAC/B,CAAC,KAAe,EAAiB,EAAE;QACjC,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QAEtB,MAAM,GAAG,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC;QAChC,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,EAAE,GAAG,OAAO,KAAK,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;QAE/D,UAAU,CAAC;YACT,IAAI,EAAE,OAAO;YACb,EAAE;YACF,IAAI,EAAE,KAAK,CAAC,KAAK;YACjB,MAAM,EAAE,GAAG;YACX,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC;YAC/B,QAAQ;YACR,MAAM,EAAE,GAAG;YACX,KAAK,EAAE,CAAC;SACE,CAAC,CAAC;QACd,OAAO,EAAE,CAAC;IACZ,CAAC,EACD,CAAC,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,CACrC,CAAC;IAEF,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC;AACpC,CAAC"}
@@ -0,0 +1,7 @@
1
+ export declare function CanvasTimeline({ pxPerSec, scrollRef, onScale, }: {
2
+ pxPerSec: number;
3
+ scrollRef?: React.Ref<HTMLDivElement>;
4
+ /** Set the timeline scale (px/s) — drives ctrl/⌘ + wheel zoom. */
5
+ onScale?: (next: number) => void;
6
+ }): import("react").JSX.Element;
7
+ //# sourceMappingURL=CanvasTimeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CanvasTimeline.d.ts","sourceRoot":"","sources":["../../../src/panels/timeline/CanvasTimeline.tsx"],"names":[],"mappings":"AA2HA,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,OAAO,GACR,EAAE;IACD,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACtC,kEAAkE;IAClE,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CAClC,+BAqxCA"}