mirror of
https://github.com/quine-global/hyper.git
synced 2026-01-16 05:38:41 -09:00
Merge pull request #632 from ppot/selection-expand
Provide text completion on hyphenared text
This commit is contained in:
commit
7fbd8ccaf1
4 changed files with 58 additions and 6 deletions
|
|
@ -145,6 +145,10 @@ export default class Term extends Component {
|
||||||
this.term.onVTKeystroke('\x05');
|
this.term.onVTKeystroke('\x05');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
selectAll () {
|
||||||
|
this.term.selectAll();
|
||||||
|
}
|
||||||
|
|
||||||
getTermDocument () {
|
getTermDocument () {
|
||||||
return this.term.document_;
|
return this.term.document_;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -62,6 +62,7 @@ class HyperTerm extends Component {
|
||||||
keys.bind('command+backspace', bound('deleteLine'));
|
keys.bind('command+backspace', bound('deleteLine'));
|
||||||
keys.bind('command+left', bound('moveToStart'));
|
keys.bind('command+left', bound('moveToStart'));
|
||||||
keys.bind('command+right', bound('moveToEnd'));
|
keys.bind('command+right', bound('moveToEnd'));
|
||||||
|
keys.bind('command+a', bound('selectAll'));
|
||||||
this.keys = keys;
|
this.keys = keys;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
15
lib/hterm.js
15
lib/hterm.js
|
|
@ -1,17 +1,20 @@
|
||||||
import { hterm, lib } from 'hterm-umdjs';
|
import { hterm, lib } from 'hterm-umdjs';
|
||||||
|
const selection = require('./utils/selection');
|
||||||
|
|
||||||
hterm.defaultStorage = new lib.Storage.Memory();
|
hterm.defaultStorage = new lib.Storage.Memory();
|
||||||
|
|
||||||
// clear selection range of current selected term view
|
// Provide selectAll to terminal viewport
|
||||||
// Fix event when terminal text is selected and keyboard action is invoked
|
hterm.Terminal.prototype.selectAll = function () {
|
||||||
hterm.Terminal.prototype.clearSelection = function () {
|
// We need to clear dom range to reset anchorNode
|
||||||
this.document_.getSelection().removeAllRanges();
|
selection.clear(this);
|
||||||
|
selection.all(this);
|
||||||
};
|
};
|
||||||
|
|
||||||
// override double click behavior to copy
|
// override double click behavior to copy
|
||||||
const oldMouse = hterm.Terminal.prototype.onMouse_;
|
const oldMouse = hterm.Terminal.prototype.onMouse_;
|
||||||
hterm.Terminal.prototype.onMouse_ = function (e) {
|
hterm.Terminal.prototype.onMouse_ = function (e) {
|
||||||
if ('dblclick' === e.type) {
|
if ('dblclick' === e.type) {
|
||||||
|
selection.extend(this);
|
||||||
console.log('[hyperterm+hterm] ignore double click');
|
console.log('[hyperterm+hterm] ignore double click');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -94,7 +97,7 @@ hterm.Keyboard.prototype.onKeyDown_ = function (e) {
|
||||||
} else {
|
} else {
|
||||||
// Test for valid keys in order to clear the terminal selection
|
// Test for valid keys in order to clear the terminal selection
|
||||||
if ((!e.ctrlKey || e.code !== 'ControlLeft') && !e.shiftKey && e.code !== 'CapsLock') {
|
if ((!e.ctrlKey || e.code !== 'ControlLeft') && !e.shiftKey && e.code !== 'CapsLock') {
|
||||||
this.terminal.clearSelection();
|
selection.clear(this.terminal);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return oldKeyDown.call(this, e);
|
return oldKeyDown.call(this, e);
|
||||||
|
|
@ -105,7 +108,7 @@ hterm.Keyboard.prototype.onKeyPress_ = function (e) {
|
||||||
if (e.metaKey) {
|
if (e.metaKey) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
this.terminal.clearSelection();
|
selection.clear(this.terminal);
|
||||||
}
|
}
|
||||||
return oldKeyPress.call(this, e);
|
return oldKeyPress.call(this, e);
|
||||||
};
|
};
|
||||||
|
|
|
||||||
44
lib/utils/selection.js
Normal file
44
lib/utils/selection.js
Normal file
|
|
@ -0,0 +1,44 @@
|
||||||
|
// clear selection range of current selected term view
|
||||||
|
// Fix event when terminal text is selected and keyboard action is invoked
|
||||||
|
exports.clear = function (terminal) {
|
||||||
|
terminal.document_.getSelection().removeAllRanges();
|
||||||
|
};
|
||||||
|
|
||||||
|
// Use selection extend upon dblclick
|
||||||
|
exports.extend = function (terminal) {
|
||||||
|
terminal.screen_.expandSelection(terminal.document_.getSelection());
|
||||||
|
};
|
||||||
|
|
||||||
|
// Fix a bug in ScrollPort selectAll behavior
|
||||||
|
// Select all rows in the viewport
|
||||||
|
exports.all = function (terminal) {
|
||||||
|
let scrollPort = terminal.scrollPort_;
|
||||||
|
let firstRow, lastRowIndex, lastRow;
|
||||||
|
|
||||||
|
if (scrollPort.topFold_.nextSibling.rowIndex !== 0) {
|
||||||
|
while (scrollPort.topFold_.previousSibling) {
|
||||||
|
scrollPort.rowNodes_.removeChild(scrollPort.topFold_.previousSibling);
|
||||||
|
}
|
||||||
|
|
||||||
|
firstRow = scrollPort.fetchRowNode_(0);
|
||||||
|
scrollPort.rowNodes_.insertBefore(firstRow, scrollPort.topFold_);
|
||||||
|
scrollPort.syncRowNodesDimensions_();
|
||||||
|
} else {
|
||||||
|
firstRow = scrollPort.topFold_.nextSibling;
|
||||||
|
}
|
||||||
|
|
||||||
|
lastRowIndex = scrollPort.rowProvider_.getRowCount() - 1;
|
||||||
|
|
||||||
|
if (scrollPort.bottomFold_.previousSibling.rowIndex !== lastRowIndex) {
|
||||||
|
while (scrollPort.bottomFold_.nextSibling) {
|
||||||
|
scrollPort.rowNodes_.removeChild(scrollPort.bottomFold_.nextSibling);
|
||||||
|
}
|
||||||
|
|
||||||
|
lastRow = scrollPort.fetchRowNode_(lastRowIndex);
|
||||||
|
scrollPort.rowNodes_.appendChild(lastRow);
|
||||||
|
} else {
|
||||||
|
lastRow = scrollPort.bottomFold_.previousSibling.rowIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
scrollPort.selection.sync();
|
||||||
|
};
|
||||||
Loading…
Reference in a new issue