**useMultiTrack.ts:** - Removed localStorage persistence (tracks, effects, automation) - Now relies entirely on IndexedDB via project management system - Simpler state management without dual persistence **AudioEditor.tsx:** - Store last project ID in localStorage when saving - Auto-load last project on page mount - Only runs once per session with hasAutoLoaded flag - Falls back to empty state if project can't be loaded **Benefits:** - No more conflicts between localStorage and IndexedDB - Effects and automation properly persisted - Seamless experience - reload page and your project is ready - Single source of truth (IndexedDB) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
70 lines
1.9 KiB
TypeScript
70 lines
1.9 KiB
TypeScript
import { useState, useCallback } from 'react';
|
|
import type { Track } from '@/types/track';
|
|
import { createTrack, createTrackFromBuffer } from '@/lib/audio/track-utils';
|
|
|
|
export function useMultiTrack() {
|
|
// Note: localStorage persistence disabled in favor of IndexedDB project management
|
|
const [tracks, setTracks] = useState<Track[]>([]);
|
|
|
|
const addTrack = useCallback((name?: string) => {
|
|
const track = createTrack(name);
|
|
setTracks((prev) => [...prev, track]);
|
|
return track;
|
|
}, []);
|
|
|
|
const addTrackFromBuffer = useCallback((buffer: AudioBuffer, name?: string) => {
|
|
const track = createTrackFromBuffer(buffer, name);
|
|
setTracks((prev) => [...prev, track]);
|
|
return track;
|
|
}, []);
|
|
|
|
const removeTrack = useCallback((trackId: string) => {
|
|
setTracks((prev) => prev.filter((t) => t.id !== trackId));
|
|
}, []);
|
|
|
|
const updateTrack = useCallback((trackId: string, updates: Partial<Track>) => {
|
|
setTracks((prev) =>
|
|
prev.map((track) =>
|
|
track.id === trackId ? { ...track, ...updates } : track
|
|
)
|
|
);
|
|
}, []);
|
|
|
|
const clearTracks = useCallback(() => {
|
|
setTracks([]);
|
|
}, []);
|
|
|
|
const reorderTracks = useCallback((fromIndex: number, toIndex: number) => {
|
|
setTracks((prev) => {
|
|
const newTracks = [...prev];
|
|
const [movedTrack] = newTracks.splice(fromIndex, 1);
|
|
newTracks.splice(toIndex, 0, movedTrack);
|
|
return newTracks;
|
|
});
|
|
}, []);
|
|
|
|
const setTrackBuffer = useCallback((trackId: string, buffer: AudioBuffer) => {
|
|
setTracks((prev) =>
|
|
prev.map((track) =>
|
|
track.id === trackId ? { ...track, audioBuffer: buffer } : track
|
|
)
|
|
);
|
|
}, []);
|
|
|
|
const loadTracks = useCallback((tracksToLoad: Track[]) => {
|
|
setTracks(tracksToLoad);
|
|
}, []);
|
|
|
|
return {
|
|
tracks,
|
|
addTrack,
|
|
addTrackFromBuffer,
|
|
removeTrack,
|
|
updateTrack,
|
|
clearTracks,
|
|
reorderTracks,
|
|
setTrackBuffer,
|
|
loadTracks,
|
|
};
|
|
}
|