Implement undo/redo for whiteboard #195
parent
c18f6eafdc
commit
ec4b95687c
|
@ -87,7 +87,7 @@
|
|||
#cp-app-whiteboard-delete {
|
||||
min-width: 40px;
|
||||
}
|
||||
.cp-whiteboard-type {
|
||||
.cp-whiteboard-type, .cp-whiteboard-history {
|
||||
button {
|
||||
min-width: 40px;
|
||||
text-align: center;
|
||||
|
|
|
@ -53,6 +53,9 @@ define([
|
|||
var $type = $('.cp-whiteboard-type');
|
||||
var $brush = $('.cp-whiteboard-type .brush');
|
||||
var $move = $('.cp-whiteboard-type .move');
|
||||
var $history = $('.cp-whiteboard-history');
|
||||
var $undo = $('.cp-whiteboard-history .undo');
|
||||
var $redo = $('.cp-whiteboard-history .redo');
|
||||
var $deleteButton = $('#cp-app-whiteboard-delete');
|
||||
|
||||
var metadataMgr = framework._.cpNfInner.metadataMgr;
|
||||
|
@ -137,6 +140,27 @@ define([
|
|||
$deleteButton.prop('disabled', '');
|
||||
});
|
||||
|
||||
$undo.click(function () {
|
||||
if (typeof(APP.canvas.undo) !== "function") { return; }
|
||||
APP.canvas.undo();
|
||||
APP.onLocal();
|
||||
});
|
||||
$redo.click(function () {
|
||||
if (typeof(APP.canvas.undo) !== "function") { return; }
|
||||
APP.canvas.redo();
|
||||
APP.onLocal();
|
||||
});
|
||||
$('body').on('keydown', function (e) {
|
||||
if (e.which === 90 && e.ctrlKey) {
|
||||
$undo.click();
|
||||
return;
|
||||
}
|
||||
if (e.which === 89 && e.ctrlKey) {
|
||||
$redo.click();
|
||||
return;
|
||||
}
|
||||
});
|
||||
|
||||
var deleteSelection = function () {
|
||||
if (APP.draw) { return; }
|
||||
if (canvas.getActiveObject()) {
|
||||
|
@ -436,7 +460,15 @@ define([
|
|||
};
|
||||
});
|
||||
|
||||
var cleanHistory = function () {
|
||||
if (Array.isArray(canvas.historyUndo)) {
|
||||
canvas.historyUndo = canvas.historyUndo.slice(-100);
|
||||
canvas.historyRedo = canvas.historyRedo.slice(-100);
|
||||
}
|
||||
};
|
||||
|
||||
framework.onContentUpdate(function (newContent, waitFor) {
|
||||
cleanHistory();
|
||||
var content = newContent.content;
|
||||
canvas.loadFromJSON(content, waitFor(function () {
|
||||
canvas.renderAll();
|
||||
|
@ -445,6 +477,7 @@ define([
|
|||
});
|
||||
|
||||
framework.setContentGetter(function () {
|
||||
cleanHistory();
|
||||
var content = canvas.toDatalessJSON();
|
||||
return {
|
||||
content: content
|
||||
|
@ -475,6 +508,8 @@ define([
|
|||
};
|
||||
|
||||
|
||||
Messages.undo = "Undo"; // XXX
|
||||
Messages.redo = "Redo"; // XXX
|
||||
var initialContent = function () {
|
||||
return [
|
||||
h('div#cp-toolbar.cp-toolbar-container'),
|
||||
|
@ -494,6 +529,10 @@ define([
|
|||
h('button.btn.brush.fa.fa-paint-brush.btn-primary', {title: Messages.canvas_brush}),
|
||||
h('button.btn.move.fa.fa-arrows', {title: Messages.canvas_select}),
|
||||
]),
|
||||
h('div.cp-whiteboard-history', [
|
||||
h('button.btn.undo.fa.fa-undo', {title: Messages.undo}),
|
||||
h('button.btn.redo.fa.fa-repeat', {title: Messages.redo}),
|
||||
]),
|
||||
h('button.btn.fa.fa-trash#cp-app-whiteboard-delete', {
|
||||
disabled: 'disabled',
|
||||
title: Messages.canvas_delete
|
||||
|
@ -560,6 +599,7 @@ define([
|
|||
$('body').append($div.html());
|
||||
}));
|
||||
}).nThen(function (waitFor) {
|
||||
require(['/lib/fabric-history.min.js'], waitFor());
|
||||
|
||||
// Framework initialization
|
||||
Framework.create({
|
||||
|
|
Loading…
Reference in New Issue