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
JavaScript
/**
* 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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"}