mirror of
https://bitbucket.org/wisemapping/wisemapping-frontend.git
synced 2024-11-25 15:47:55 +01:00
Clean up code.
This commit is contained in:
parent
cbc4196231
commit
7163a07696
@ -46,162 +46,56 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
private _registerEvents(designer: Designer) {
|
private _registerEvents(designer: Designer) {
|
||||||
// Try with the keyboard ..
|
// Try with the keyboard ..
|
||||||
const model = designer.getModel();
|
const model = designer.getModel();
|
||||||
this.addShortcut(
|
this.addShortcut('backspace', () => { designer.deleteSelectedEntities(); });
|
||||||
['backspace'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.deleteSelectedEntities();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['space'], (event: Event) => {
|
|
||||||
designer.shrinkSelectedBranch();
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['f2'], (event: Event) => {
|
|
||||||
event.stopPropagation();
|
|
||||||
event.preventDefault();
|
|
||||||
const node = model.selectedTopic();
|
|
||||||
if (node) {
|
|
||||||
node.showTextEditor(node.getText());
|
|
||||||
}
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['del'], (event: Event) => {
|
|
||||||
designer.deleteSelectedEntities();
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['enter'], () => {
|
|
||||||
designer.createSiblingForSelectedNode();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['insert'], (event: Event) => {
|
|
||||||
designer.createChildForSelectedNode();
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['tab'], (eventevent: Event) => {
|
|
||||||
designer.createChildForSelectedNode();
|
|
||||||
eventevent.preventDefault();
|
|
||||||
eventevent.stopPropagation();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['meta+enter'], (eventevent: Event) => {
|
|
||||||
eventevent.preventDefault();
|
|
||||||
eventevent.stopPropagation();
|
|
||||||
designer.createChildForSelectedNode();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+z', 'meta+z'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.undo();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+c', 'meta+c'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.copyToClipboard();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+l', 'meta+l'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.addLink();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+k', 'meta+k'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.addNote();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+v', 'meta+v'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.pasteClipboard();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+shift+z', 'meta+shift+z', 'ctrl+y', 'meta+y'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.redo();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+a', 'meta+a'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
designer.selectAll();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+b', 'meta+b'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
designer.changeFontWeight();
|
this.addShortcut('space', () => { designer.shrinkSelectedBranch(); });
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+s', 'meta+s'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
$(document).find('#save').trigger('click');
|
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+i', 'meta+i'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
designer.changeFontStyle();
|
this.addShortcut('del', () => { designer.deleteSelectedEntities(); });
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['ctrl+shift+a', 'meta+shift+a'], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
designer.deselectAll();
|
this.addShortcut('enter', () => { designer.createSiblingForSelectedNode(); });
|
||||||
},
|
|
||||||
);
|
|
||||||
this.addShortcut(
|
|
||||||
['meta+=', 'ctrl+='], (event: Event) => {
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
designer.zoomIn();
|
this.addShortcut('f2', () => {
|
||||||
},
|
const node = model.selectedTopic();
|
||||||
);
|
if (node) {
|
||||||
this.addShortcut(
|
node.showTextEditor(node.getText());
|
||||||
['meta+-', 'ctrl+-'], (event: Event) => {
|
}
|
||||||
event.preventDefault();
|
});
|
||||||
event.stopPropagation();
|
|
||||||
|
this.addShortcut('insert', () => { designer.createChildForSelectedNode(); });
|
||||||
|
|
||||||
|
this.addShortcut('tab', () => { designer.createChildForSelectedNode(); });
|
||||||
|
|
||||||
|
this.addShortcut('meta+enter', () => { designer.createChildForSelectedNode(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+z', 'meta+z'], () => { designer.undo(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+c', 'meta+c'], () => { designer.copyToClipboard(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+l', 'meta+l'], () => { designer.addLink(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+k', 'meta+k'], () => { designer.addNote(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+v', 'meta+v'], () => { designer.pasteClipboard(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+shift+z', 'meta+shift+z'], () => { designer.redo(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+a', 'meta+a'], () => { designer.selectAll(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+b', 'meta+b'], () => { designer.changeFontWeight(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+s', 'meta+s'], () => { $(document).find('#save').trigger('click'); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+i', 'meta+i'], () => { designer.changeFontStyle(); });
|
||||||
|
|
||||||
|
this.addShortcut(['ctrl+shift+a', 'meta+shift+a'], () => { designer.deselectAll(); });
|
||||||
|
|
||||||
|
this.addShortcut(['meta+=', 'ctrl+='], () => { designer.zoomIn(); });
|
||||||
|
|
||||||
|
this.addShortcut(['meta+-', 'ctrl+-'], () => { designer.zoomOut(); });
|
||||||
|
|
||||||
designer.zoomOut();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
const me = this;
|
const me = this;
|
||||||
this.addShortcut(
|
this.addShortcut(
|
||||||
'right', (event: Event) => {
|
'right', () => {
|
||||||
const node = model.selectedTopic();
|
const node = model.selectedTopic();
|
||||||
if (node) {
|
if (node) {
|
||||||
if (node.isCentralTopic()) {
|
if (node.isCentralTopic()) {
|
||||||
@ -215,12 +109,11 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
const centralTopic = model.getCentralTopic();
|
const centralTopic = model.getCentralTopic();
|
||||||
me._goToNode(designer, centralTopic);
|
me._goToNode(designer, centralTopic);
|
||||||
}
|
}
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
this.addShortcut(
|
this.addShortcut(
|
||||||
'left', (event: Event) => {
|
'left', () => {
|
||||||
const node = model.selectedTopic();
|
const node = model.selectedTopic();
|
||||||
if (node) {
|
if (node) {
|
||||||
if (node.isCentralTopic()) {
|
if (node.isCentralTopic()) {
|
||||||
@ -234,12 +127,11 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
const centralTopic = model.getCentralTopic();
|
const centralTopic = model.getCentralTopic();
|
||||||
me._goToNode(designer, centralTopic);
|
me._goToNode(designer, centralTopic);
|
||||||
}
|
}
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
this.addShortcut(
|
this.addShortcut(
|
||||||
'up', (event: Event) => {
|
'up', () => {
|
||||||
const node = model.selectedTopic();
|
const node = model.selectedTopic();
|
||||||
if (node) {
|
if (node) {
|
||||||
if (!node.isCentralTopic()) {
|
if (!node.isCentralTopic()) {
|
||||||
@ -249,12 +141,10 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
const centralTopic = model.getCentralTopic();
|
const centralTopic = model.getCentralTopic();
|
||||||
me._goToNode(designer, centralTopic);
|
me._goToNode(designer, centralTopic);
|
||||||
}
|
}
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
this.addShortcut(
|
this.addShortcut(
|
||||||
'down', (event: Event) => {
|
'down', () => {
|
||||||
const node = model.selectedTopic();
|
const node = model.selectedTopic();
|
||||||
if (node) {
|
if (node) {
|
||||||
if (!node.isCentralTopic()) {
|
if (!node.isCentralTopic()) {
|
||||||
@ -264,8 +154,6 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
const centralTopic = model.getCentralTopic();
|
const centralTopic = model.getCentralTopic();
|
||||||
me._goToNode(designer, centralTopic);
|
me._goToNode(designer, centralTopic);
|
||||||
}
|
}
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
const excludes = ['Escape', 'F1', 'F3', 'F4', 'F5', 'F6', 'F7', 'F8', 'F9', 'F10', 'F11', 'F12'];
|
const excludes = ['Escape', 'F1', 'F3', 'F4', 'F5', 'F6', 'F7', 'F8', 'F9', 'F10', 'F11', 'F12'];
|
||||||
@ -279,7 +167,7 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||||
if (['Enter', 'Capslock'].indexOf(event.code) === -1) {
|
if (['Enter', 'CapsLock'].includes(event.code)) {
|
||||||
const nodes = designer.getModel().filterSelectedTopics();
|
const nodes = designer.getModel().filterSelectedTopics();
|
||||||
if (nodes.length > 0) {
|
if (nodes.length > 0) {
|
||||||
// If a modifier is press, the key selected must be ignored.
|
// If a modifier is press, the key selected must be ignored.
|
||||||
@ -287,7 +175,6 @@ class DesignerKeyboard extends Keyboard {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
nodes[0].showTextEditor('');
|
nodes[0].showTextEditor('');
|
||||||
event.stopPropagation();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -18,10 +18,17 @@
|
|||||||
import $ from 'jquery';
|
import $ from 'jquery';
|
||||||
|
|
||||||
class Keyboard {
|
class Keyboard {
|
||||||
addShortcut(shortcuts: string[] | string, callback) {
|
addShortcut(shortcuts: string[] | string, callback, stopPropagation?: true) {
|
||||||
const shortcutsArray = Array.isArray(shortcuts) ? shortcuts : [shortcuts];
|
const shortcutsArray = Array.isArray(shortcuts) ? shortcuts : [shortcuts];
|
||||||
shortcutsArray.forEach((shortcut) => {
|
shortcutsArray.forEach((shortcut) => {
|
||||||
$(document).bind('keydown', shortcut, callback);
|
$(document).bind('keydown', shortcut,
|
||||||
|
(e) => {
|
||||||
|
if (stopPropagation) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
callback(e);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -61,12 +61,11 @@ class MultilineTextEditor extends Events {
|
|||||||
private _registerEvents(containerElem: JQuery) {
|
private _registerEvents(containerElem: JQuery) {
|
||||||
const textareaElem = this._getTextareaElem();
|
const textareaElem = this._getTextareaElem();
|
||||||
textareaElem.on('keydown', (event) => {
|
textareaElem.on('keydown', (event) => {
|
||||||
const j: any = $;
|
switch (event.code) {
|
||||||
switch (j.hotkeys.specialKeys[event.keyCode]) {
|
case 'Escape':
|
||||||
case 'esc':
|
|
||||||
this.close(false);
|
this.close(false);
|
||||||
break;
|
break;
|
||||||
case 'enter': {
|
case 'Enter': {
|
||||||
if (event.metaKey || event.ctrlKey) {
|
if (event.metaKey || event.ctrlKey) {
|
||||||
// Add return ...
|
// Add return ...
|
||||||
const text = this._getTextAreaText();
|
const text = this._getTextAreaText();
|
||||||
|
Loading…
Reference in New Issue
Block a user