UNPKG

resig.js

Version:

Universal reactive signal library with complete platform features: signals, animations, CRDTs, scheduling, DOM integration. Works identically across React, SolidJS, Svelte, Vue, and Qwik.

377 lines 30.7 kB
/** * Undo/Redo System * Uses Memento<State> with coalgebraic time-travel patterns */ import { signal, computed } from '../core/signal'; // Coalgebraic time-travel manager export class UndoRedoManager { constructor(initialState, config = {}) { this.config = config; this.lastCommand = null; this.mergeTimer = null; this.history = signal([this.createMemento(initialState, 'initial')]); this.future = signal([]); this.currentIndex = signal(0); this.currentState = signal(initialState); this.commands = signal([]); this.setupAutoMerge(); this.loadPersistedHistory(); } // Create memento snapshot (coalgebraic unfold) createMemento(state, id, metadata) { return { state: this.deepClone(state), timestamp: Date.now(), id, metadata, }; } // Deep clone state for immutability deepClone(obj) { if (obj === null || typeof obj !== 'object') return obj; if (obj instanceof Date) return new Date(obj.getTime()); if (obj instanceof Array) return obj.map((item) => this.deepClone(item)); if (typeof obj === 'object') { const cloned = {}; Object.keys(obj).forEach((key) => { cloned[key] = this.deepClone(obj[key]); }); return cloned; } return obj; } // Setup automatic command merging setupAutoMerge() { if (!this.config.autoMerge) return; const mergeTimeout = this.config.mergeTimeout || 1000; this.commands.subscribe((commands) => { if (commands.length === 0) return; // const _lastCommand = commands[commands.length - 1]; // Unused for now if (this.mergeTimer) { clearTimeout(this.mergeTimer); } this.mergeTimer = window.setTimeout(() => { this.lastCommand = null; }, mergeTimeout); }); } // Load persisted history loadPersistedHistory() { if (!this.config.persistKey) return; try { const saved = localStorage.getItem(this.config.persistKey); if (saved) { const data = JSON.parse(saved); this.history._set(data.history || []); this.currentIndex._set(data.currentIndex || 0); const currentMemento = this.history.value()[this.currentIndex.value()]; if (currentMemento) { this.currentState._set(currentMemento.state); } } } catch (error) { console.warn('Failed to load persisted undo/redo history:', error); } } // Persist history persistHistory() { if (!this.config.persistKey) return; try { const data = { history: this.history.value(), currentIndex: this.currentIndex.value(), }; localStorage.setItem(this.config.persistKey, JSON.stringify(data)); } catch (error) { console.warn('Failed to persist undo/redo history:', error); } } // Compress history by removing intermediate states compressHistory() { if (!this.config.compressHistory) return; const maxSize = this.config.maxHistorySize || 50; const history = this.history.value(); if (history.length <= maxSize) return; // Keep first, last, and evenly distributed intermediate states const compressed = []; const step = Math.floor(history.length / maxSize); for (let i = 0; i < history.length; i += step) { compressed.push(history[i]); } // Always keep the last state if (compressed[compressed.length - 1] !== history[history.length - 1]) { compressed.push(history[history.length - 1]); } this.history._set(compressed); this.currentIndex._set(Math.min(this.currentIndex.value(), compressed.length - 1)); } // Execute command with coalgebraic time-travel execute(command) { const currentState = this.currentState.value(); // Try to merge with last command if auto-merge is enabled if (this.config.autoMerge && this.lastCommand) { if (command.canMerge?.(this.lastCommand)) { const mergedCommand = command.merge(this.lastCommand); this.executeInternal(mergedCommand, currentState); return; } } this.executeInternal(command, currentState); this.lastCommand = command; } // Internal command execution executeInternal(command, currentState) { try { const newState = command.execute(currentState); const memento = this.createMemento(newState, command.id, { commandName: command.name, commandId: command.id, }); // Clear future history (branching timeline) this.future._set([]); // Add to history const history = this.history.value(); const newHistory = [ ...history.slice(0, this.currentIndex.value() + 1), memento, ]; // Limit history size const maxSize = this.config.maxHistorySize || 50; if (newHistory.length > maxSize) { newHistory.splice(0, newHistory.length - maxSize); } this.history._set(newHistory); this.currentIndex._set(newHistory.length - 1); this.currentState._set(newState); // Add command to command history this.commands._set([...this.commands.value(), command]); // Compress history if needed this.compressHistory(); // Persist changes this.persistHistory(); } catch (error) { console.error('Failed to execute command:', error); } } // Undo operation (coalgebraic time-travel backward) undo() { const currentIdx = this.currentIndex.value(); const history = this.history.value(); if (currentIdx <= 0) return false; const previousMemento = history[currentIdx - 1]; const currentMemento = history[currentIdx]; // Move current state to future this.future._set([currentMemento, ...this.future.value()]); // Update current state this.currentIndex._set(currentIdx - 1); this.currentState._set(previousMemento.state); this.persistHistory(); return true; } // Redo operation (coalgebraic time-travel forward) redo() { const future = this.future.value(); if (future.length === 0) return false; const nextMemento = future[0]; const remainingFuture = future.slice(1); // Move state from future to history this.future._set(remainingFuture); this.currentIndex._set(this.currentIndex.value() + 1); this.currentState._set(nextMemento.state); this.persistHistory(); return true; } // Jump to specific point in history (coalgebraic time-travel to index) jumpTo(index) { const history = this.history.value(); if (index < 0 || index >= history.length) return false; const currentIdx = this.currentIndex.value(); const targetMemento = history[index]; if (index < currentIdx) { // Moving backward - add states to future const statesToFuture = history.slice(index + 1, currentIdx + 1).reverse(); this.future._set([...statesToFuture, ...this.future.value()]); } else if (index > currentIdx) { // Moving forward - remove states from future const statesToRemove = index - currentIdx; this.future._set(this.future.value().slice(statesToRemove)); } this.currentIndex._set(index); this.currentState._set(targetMemento.state); this.persistHistory(); return true; } // Create snapshot manually createSnapshot(id) { const currentState = this.currentState.value(); const memento = this.createMemento(currentState, id || `snapshot-${Date.now()}`, { type: 'manual-snapshot' }); const history = this.history.value(); const newHistory = [ ...history.slice(0, this.currentIndex.value() + 1), memento, ]; this.history._set(newHistory); this.currentIndex._set(newHistory.length - 1); this.future._set([]); this.persistHistory(); } // Get time-travel state getTimeTravel() { return computed(() => ({ currentIndex: this.currentIndex.value(), history: this.history.value(), future: this.future.value(), canUndo: this.currentIndex.value() > 0, canRedo: this.future.value().length > 0, totalStates: this.history.value().length + this.future.value().length, })); } // Get current state signal getCurrentState() { return this.currentState; } // Get history signal getHistory() { return this.history; } // Get commands signal getCommands() { return this.commands; } // Clear all history clearHistory() { const currentState = this.currentState.value(); const initialMemento = this.createMemento(currentState, 'reset'); this.history._set([initialMemento]); this.future._set([]); this.currentIndex._set(0); this.commands._set([]); this.persistHistory(); } // Get state at specific index getStateAt(index) { const history = this.history.value(); return history[index]?.state || null; } // Check if can undo/redo canUndo() { return this.currentIndex.value() > 0; } canRedo() { return this.future.value().length > 0; } // Cleanup destroy() { if (this.mergeTimer) { clearTimeout(this.mergeTimer); } } } // Factory function for creating undo/redo manager export const createUndoRedoManager = (initialState, config) => { return new UndoRedoManager(initialState, config); }; // Command builders export const createCommand = (id, name, execute, undo, options) => ({ id, name, timestamp: Date.now(), execute, undo, canMerge: options?.canMerge, merge: options?.merge, }); // Mergeable command for text editing export const createTextCommand = (id, type, position, text, previousText) => ({ id, name: `text-${type}`, timestamp: Date.now(), execute: (state) => { switch (type) { case 'insert': return state.slice(0, position) + text + state.slice(position); case 'delete': return state.slice(0, position) + state.slice(position + text.length); case 'replace': return (state.slice(0, position) + text + state.slice(position + (previousText?.length || 0))); default: return state; } }, undo: (state) => { switch (type) { case 'insert': return state.slice(0, position) + state.slice(position + text.length); case 'delete': return state.slice(0, position) + text + state.slice(position); case 'replace': return (state.slice(0, position) + (previousText || '') + state.slice(position + text.length)); default: return state; } }, canMerge: (other) => { return (other.name.startsWith('text-') && Math.abs(other.timestamp - Date.now()) < 1000); }, merge: (other) => { // Simplified merge logic - in production, implement proper text merging return createTextCommand(`${id}-${other.id}`, type, position, text, previousText); }, }); // Array manipulation commands export const createArrayCommand = (type, ...args) => ({ id: `array-${type}-${Date.now()}`, name: `array-${type}`, timestamp: Date.now(), execute: (state) => { const newState = [...state]; newState[type](...args); return newState; }, undo: (state) => { const newState = [...state]; // Implement reverse operations switch (type) { case 'push': newState.pop(); break; case 'pop': newState.push(args[0]); break; case 'shift': newState.unshift(args[0]); break; case 'unshift': newState.shift(); break; case 'splice': // Reverse splice operation const [start, deleteCount, ...items] = args; newState.splice(start, items.length, ...new Array(deleteCount)); break; } return newState; }, }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"undo-redo.js","sourceRoot":"","sources":["../../../src/extensions/undo-redo.ts"],"names":[],"mappings":"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"}