@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.
- package/LICENSE +201 -0
- package/README.md +51 -0
- package/dist/Editor.d.ts +3 -0
- package/dist/Editor.d.ts.map +1 -0
- package/dist/Editor.js +73 -0
- package/dist/Editor.js.map +1 -0
- package/dist/ExportDialog.d.ts +12 -0
- package/dist/ExportDialog.d.ts.map +1 -0
- package/dist/ExportDialog.js +30 -0
- package/dist/ExportDialog.js.map +1 -0
- package/dist/MotionPathOverlay.d.ts +5 -0
- package/dist/MotionPathOverlay.d.ts.map +1 -0
- package/dist/MotionPathOverlay.js +156 -0
- package/dist/MotionPathOverlay.js.map +1 -0
- package/dist/PerfHud.d.ts +2 -0
- package/dist/PerfHud.d.ts.map +1 -0
- package/dist/PerfHud.js +85 -0
- package/dist/PerfHud.js.map +1 -0
- package/dist/Stage.d.ts +2 -0
- package/dist/Stage.d.ts.map +1 -0
- package/dist/Stage.js +406 -0
- package/dist/Stage.js.map +1 -0
- package/dist/StageOverlay.d.ts +7 -0
- package/dist/StageOverlay.d.ts.map +1 -0
- package/dist/StageOverlay.js +508 -0
- package/dist/StageOverlay.js.map +1 -0
- package/dist/commands.d.ts +18 -0
- package/dist/commands.d.ts.map +1 -0
- package/dist/commands.js +103 -0
- package/dist/commands.js.map +1 -0
- package/dist/configuration.d.ts +9 -0
- package/dist/configuration.d.ts.map +1 -0
- package/dist/configuration.js +21 -0
- package/dist/configuration.js.map +1 -0
- package/dist/controls/AnimationsStack.d.ts +8 -0
- package/dist/controls/AnimationsStack.d.ts.map +1 -0
- package/dist/controls/AnimationsStack.js +188 -0
- package/dist/controls/AnimationsStack.js.map +1 -0
- package/dist/controls/CameraControl.d.ts +19 -0
- package/dist/controls/CameraControl.d.ts.map +1 -0
- package/dist/controls/CameraControl.js +47 -0
- package/dist/controls/CameraControl.js.map +1 -0
- package/dist/controls/CaptionLengthControl.d.ts +5 -0
- package/dist/controls/CaptionLengthControl.d.ts.map +1 -0
- package/dist/controls/CaptionLengthControl.js +11 -0
- package/dist/controls/CaptionLengthControl.js.map +1 -0
- package/dist/controls/CaptionTranscribe.d.ts +2 -0
- package/dist/controls/CaptionTranscribe.d.ts.map +1 -0
- package/dist/controls/CaptionTranscribe.js +95 -0
- package/dist/controls/CaptionTranscribe.js.map +1 -0
- package/dist/controls/ColorPicker.d.ts +17 -0
- package/dist/controls/ColorPicker.d.ts.map +1 -0
- package/dist/controls/ColorPicker.js +354 -0
- package/dist/controls/ColorPicker.js.map +1 -0
- package/dist/controls/ControlRenderer.d.ts +20 -0
- package/dist/controls/ControlRenderer.d.ts.map +1 -0
- package/dist/controls/ControlRenderer.js +106 -0
- package/dist/controls/ControlRenderer.js.map +1 -0
- package/dist/controls/CropControl.d.ts +2 -0
- package/dist/controls/CropControl.d.ts.map +1 -0
- package/dist/controls/CropControl.js +177 -0
- package/dist/controls/CropControl.js.map +1 -0
- package/dist/controls/EffectsStack.d.ts +8 -0
- package/dist/controls/EffectsStack.d.ts.map +1 -0
- package/dist/controls/EffectsStack.js +89 -0
- package/dist/controls/EffectsStack.js.map +1 -0
- package/dist/controls/GradeControl.d.ts +2 -0
- package/dist/controls/GradeControl.d.ts.map +1 -0
- package/dist/controls/GradeControl.js +120 -0
- package/dist/controls/GradeControl.js.map +1 -0
- package/dist/controls/KeyframeDiamond.d.ts +11 -0
- package/dist/controls/KeyframeDiamond.d.ts.map +1 -0
- package/dist/controls/KeyframeDiamond.js +87 -0
- package/dist/controls/KeyframeDiamond.js.map +1 -0
- package/dist/controls/LightingControls.d.ts +24 -0
- package/dist/controls/LightingControls.d.ts.map +1 -0
- package/dist/controls/LightingControls.js +108 -0
- package/dist/controls/LightingControls.js.map +1 -0
- package/dist/controls/ShapePresetControl.d.ts +4 -0
- package/dist/controls/ShapePresetControl.d.ts.map +1 -0
- package/dist/controls/ShapePresetControl.js +30 -0
- package/dist/controls/ShapePresetControl.js.map +1 -0
- package/dist/controls/ValueField.d.ts +10 -0
- package/dist/controls/ValueField.d.ts.map +1 -0
- package/dist/controls/ValueField.js +158 -0
- package/dist/controls/ValueField.js.map +1 -0
- package/dist/controls/VolumeControl.d.ts +10 -0
- package/dist/controls/VolumeControl.d.ts.map +1 -0
- package/dist/controls/VolumeControl.js +75 -0
- package/dist/controls/VolumeControl.js.map +1 -0
- package/dist/controls/compound.d.ts +46 -0
- package/dist/controls/compound.d.ts.map +1 -0
- package/dist/controls/compound.js +160 -0
- package/dist/controls/compound.js.map +1 -0
- package/dist/controls/layout.d.ts +38 -0
- package/dist/controls/layout.d.ts.map +1 -0
- package/dist/controls/layout.js +162 -0
- package/dist/controls/layout.js.map +1 -0
- package/dist/controls/primitives.d.ts +83 -0
- package/dist/controls/primitives.d.ts.map +1 -0
- package/dist/controls/primitives.js +194 -0
- package/dist/controls/primitives.js.map +1 -0
- package/dist/controls/transcribe.worker.d.ts +2 -0
- package/dist/controls/transcribe.worker.d.ts.map +1 -0
- package/dist/controls/transcribe.worker.js +22 -0
- package/dist/controls/transcribe.worker.js.map +1 -0
- package/dist/frame/AddElementBar.d.ts +2 -0
- package/dist/frame/AddElementBar.d.ts.map +1 -0
- package/dist/frame/AddElementBar.js +103 -0
- package/dist/frame/AddElementBar.js.map +1 -0
- package/dist/frame/Breadcrumbs.d.ts +2 -0
- package/dist/frame/Breadcrumbs.d.ts.map +1 -0
- package/dist/frame/Breadcrumbs.js +32 -0
- package/dist/frame/Breadcrumbs.js.map +1 -0
- package/dist/frame/GroupFlash.d.ts +2 -0
- package/dist/frame/GroupFlash.d.ts.map +1 -0
- package/dist/frame/GroupFlash.js +65 -0
- package/dist/frame/GroupFlash.js.map +1 -0
- package/dist/frame/Resizable.d.ts +12 -0
- package/dist/frame/Resizable.d.ts.map +1 -0
- package/dist/frame/Resizable.js +37 -0
- package/dist/frame/Resizable.js.map +1 -0
- package/dist/frame/Section.d.ts +23 -0
- package/dist/frame/Section.d.ts.map +1 -0
- package/dist/frame/Section.js +23 -0
- package/dist/frame/Section.js.map +1 -0
- package/dist/frame/ZoomControl.d.ts +9 -0
- package/dist/frame/ZoomControl.d.ts.map +1 -0
- package/dist/frame/ZoomControl.js +15 -0
- package/dist/frame/ZoomControl.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +13 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/camera-gizmo.d.ts +15 -0
- package/dist/lib/camera-gizmo.d.ts.map +1 -0
- package/dist/lib/camera-gizmo.js +57 -0
- package/dist/lib/camera-gizmo.js.map +1 -0
- package/dist/lib/camera-tool.d.ts +43 -0
- package/dist/lib/camera-tool.d.ts.map +1 -0
- package/dist/lib/camera-tool.js +80 -0
- package/dist/lib/camera-tool.js.map +1 -0
- package/dist/lib/caption-segments.d.ts +17 -0
- package/dist/lib/caption-segments.d.ts.map +1 -0
- package/dist/lib/caption-segments.js +50 -0
- package/dist/lib/caption-segments.js.map +1 -0
- package/dist/lib/group.d.ts +12 -0
- package/dist/lib/group.d.ts.map +1 -0
- package/dist/lib/group.js +61 -0
- package/dist/lib/group.js.map +1 -0
- package/dist/lib/keyframes.d.ts +29 -0
- package/dist/lib/keyframes.d.ts.map +1 -0
- package/dist/lib/keyframes.js +92 -0
- package/dist/lib/keyframes.js.map +1 -0
- package/dist/lib/sfx-preview.d.ts +18 -0
- package/dist/lib/sfx-preview.d.ts.map +1 -0
- package/dist/lib/sfx-preview.js +74 -0
- package/dist/lib/sfx-preview.js.map +1 -0
- package/dist/lib/shape-presets.d.ts +35 -0
- package/dist/lib/shape-presets.d.ts.map +1 -0
- package/dist/lib/shape-presets.js +81 -0
- package/dist/lib/shape-presets.js.map +1 -0
- package/dist/lib/ungroup.d.ts +12 -0
- package/dist/lib/ungroup.d.ts.map +1 -0
- package/dist/lib/ungroup.js +40 -0
- package/dist/lib/ungroup.js.map +1 -0
- package/dist/lib/utils.d.ts +3 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +9 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/panels/AssetsPanel.d.ts +2 -0
- package/dist/panels/AssetsPanel.d.ts.map +1 -0
- package/dist/panels/AssetsPanel.js +108 -0
- package/dist/panels/AssetsPanel.js.map +1 -0
- package/dist/panels/InspectorPanel.d.ts +2 -0
- package/dist/panels/InspectorPanel.d.ts.map +1 -0
- package/dist/panels/InspectorPanel.js +286 -0
- package/dist/panels/InspectorPanel.js.map +1 -0
- package/dist/panels/InterpolationPanel.d.ts +2 -0
- package/dist/panels/InterpolationPanel.d.ts.map +1 -0
- package/dist/panels/InterpolationPanel.js +226 -0
- package/dist/panels/InterpolationPanel.js.map +1 -0
- package/dist/panels/LayersTree.d.ts +4 -0
- package/dist/panels/LayersTree.d.ts.map +1 -0
- package/dist/panels/LayersTree.js +137 -0
- package/dist/panels/LayersTree.js.map +1 -0
- package/dist/panels/LeftRail.d.ts +6 -0
- package/dist/panels/LeftRail.d.ts.map +1 -0
- package/dist/panels/LeftRail.js +35 -0
- package/dist/panels/LeftRail.js.map +1 -0
- package/dist/panels/SourcePanel.d.ts +2 -0
- package/dist/panels/SourcePanel.d.ts.map +1 -0
- package/dist/panels/SourcePanel.js +470 -0
- package/dist/panels/SourcePanel.js.map +1 -0
- package/dist/panels/TimelinePanel.d.ts +11 -0
- package/dist/panels/TimelinePanel.d.ts.map +1 -0
- package/dist/panels/TimelinePanel.js +98 -0
- package/dist/panels/TimelinePanel.js.map +1 -0
- package/dist/panels/assets/SfxBrowser.d.ts +2 -0
- package/dist/panels/assets/SfxBrowser.d.ts.map +1 -0
- package/dist/panels/assets/SfxBrowser.js +49 -0
- package/dist/panels/assets/SfxBrowser.js.map +1 -0
- package/dist/panels/assets/use-assets.d.ts +11 -0
- package/dist/panels/assets/use-assets.d.ts.map +1 -0
- package/dist/panels/assets/use-assets.js +84 -0
- package/dist/panels/assets/use-assets.js.map +1 -0
- package/dist/panels/assets/use-sfx.d.ts +6 -0
- package/dist/panels/assets/use-sfx.d.ts.map +1 -0
- package/dist/panels/assets/use-sfx.js +47 -0
- package/dist/panels/assets/use-sfx.js.map +1 -0
- package/dist/panels/timeline/CanvasTimeline.d.ts +7 -0
- package/dist/panels/timeline/CanvasTimeline.d.ts.map +1 -0
- package/dist/panels/timeline/CanvasTimeline.js +1536 -0
- package/dist/panels/timeline/CanvasTimeline.js.map +1 -0
- package/dist/panels/timeline/Clip.d.ts +37 -0
- package/dist/panels/timeline/Clip.d.ts.map +1 -0
- package/dist/panels/timeline/Clip.js +176 -0
- package/dist/panels/timeline/Clip.js.map +1 -0
- package/dist/panels/timeline/CurveEditor.d.ts +2 -0
- package/dist/panels/timeline/CurveEditor.d.ts.map +1 -0
- package/dist/panels/timeline/CurveEditor.js +233 -0
- package/dist/panels/timeline/CurveEditor.js.map +1 -0
- package/dist/panels/timeline/MixerRail.d.ts +7 -0
- package/dist/panels/timeline/MixerRail.d.ts.map +1 -0
- package/dist/panels/timeline/MixerRail.js +295 -0
- package/dist/panels/timeline/MixerRail.js.map +1 -0
- package/dist/panels/timeline/Waveform.d.ts +11 -0
- package/dist/panels/timeline/Waveform.d.ts.map +1 -0
- package/dist/panels/timeline/Waveform.js +63 -0
- package/dist/panels/timeline/Waveform.js.map +1 -0
- package/dist/panels/timeline/clip-style.d.ts +10 -0
- package/dist/panels/timeline/clip-style.d.ts.map +1 -0
- package/dist/panels/timeline/clip-style.js +20 -0
- package/dist/panels/timeline/clip-style.js.map +1 -0
- package/dist/panels/timeline/filmstrip.d.ts +7 -0
- package/dist/panels/timeline/filmstrip.d.ts.map +1 -0
- package/dist/panels/timeline/filmstrip.js +135 -0
- package/dist/panels/timeline/filmstrip.js.map +1 -0
- package/dist/panels/timeline/timeline-layout.d.ts +65 -0
- package/dist/panels/timeline/timeline-layout.d.ts.map +1 -0
- package/dist/panels/timeline/timeline-layout.js +118 -0
- package/dist/panels/timeline/timeline-layout.js.map +1 -0
- package/dist/types.d.ts +68 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/package.json +56 -0
- 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 @@
|
|
|
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"}
|