Fabric.js history implementation
npm i git+https://github.com/maxigator/fabric-history.git
import 'fabric-history';
<script src="https://raw.githubusercontent.com/maxigator/fabric-history/master/src/index.min.js"></script>
Following commands will undo and redo the canvas.
canvas.undo();
canvas.redo();
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Fabric with history</title>
</head>
<body>
<canvas style="border:1px solid black;" width="800" height="400"></canvas>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/6.0.0-beta5/fabric.min.js"></script>
<script src="https://raw.githubusercontent.com/maxigator/fabric-history/master/src/index.min.js"></script>
<script>
const canvas = new fabric.Canvas(document.querySelector('canvas'), {
isDrawingMode: true
})
document.addEventListener('keyup', async ({ keyCode, ctrlKey } = event) => {
// Check Ctrl key is pressed.
if (!ctrlKey) {
return
}
// Check pressed button is Z - Ctrl+Z.
if (keyCode === 90) {
await canvas.undo()
}
// Check pressed button is Y - Ctrl+Y.
if (keyCode === 89) {
await canvas.redo()
}
})
</script>
</body>
</html>
You can find an advanced example on demo folder.
- history:append
- Fired when a history appended to stack
- history:undo
- Fired when an undo process is happening
- history:redo
- Fired when a redo process is happening
- history:clear
- Fired when whole history cleared
canvas.undo().then(()=>{
console.log('post undo');
});
canvas.redo().then(()=>{
console.log('post redo');
});
- undo
- redo
- clearHistory