}
this.wrapper.on('keyup', function(e) {
- if(e.which >= 37 && e.which <= 40)
- canvas.setCurrentElement(canvas.getCursor().getPosition().element, {caretTo: false})
+ if(e.which >= 37 && e.which <= 40) {
+ var element = canvas.getCursor().getPosition().element,
+ caretTo = false;
+ if(!element) {
+ // Chrome hack
+ var direction;
+ if(e.which === (KEYS.ARROW_LEFT || KEYS.ARROW_DOWN)) {
+ direction = 'above';
+ caretTo = 'end';
+ } else {
+ direction = 'below';
+ caretTo = 'start';
+ }
+ element = canvas.getDocumentElement(utils.nearestInDocumentOrder('[document-text-element]', direction, window.getSelection().focusNode));
+ }
+ canvas.setCurrentElement(element, {caretTo: caretTo});
+ }
});
this.wrapper.on('keydown', function(e) {
}
});
- this.wrapper.on('click', '[wlxml-tag], [document-text-element]', function(e) {
+ this.wrapper.on('click', '[document-node-element], [document-text-element]', function(e) {
e.stopPropagation();
- canvas.setCurrentElement(canvas.getDocumentElement(e.target), {caretTo: false});
+ canvas.setCurrentElement(canvas.getDocumentElement(e.currentTarget), {caretTo: false});
});
var observer = new MutationObserver(function(mutations) {
observer.observe(this.d[0], config);
- this.wrapper.on('mouseover', '[wlxml-tag], [document-text-element]', function(e) {
- var el = canvas.getDocumentElement(e.target);
+ this.wrapper.on('mouseover', '[document-node-element], [document-text-element]', function(e) {
+ var el = canvas.getDocumentElement(e.currentTarget);
if(!el)
return;
e.stopPropagation();
el = el.parent();
el.toggleLabel(true);
});
- this.wrapper.on('mouseout', '[wlxml-tag], [document-text-element]', function(e) {
- var el = canvas.getDocumentElement(e.target);
+ this.wrapper.on('mouseout', '[document-node-element], [document-text-element]', function(e) {
+ var el = canvas.getDocumentElement(e.currentTarget);
if(!el)
return;
e.stopPropagation();