diff --git a/src/core_plugins/console/public/src/input_resize.js b/src/core_plugins/console/public/src/input_resize.js index 7ef2a9b004abb..642a96103b6a3 100644 --- a/src/core_plugins/console/public/src/input_resize.js +++ b/src/core_plugins/console/public/src/input_resize.js @@ -24,6 +24,8 @@ export default function (input, output) { $resizer.addClass('active'); var startWidth = $left.width(); var startX = event.pageX; + input.resize.topRow = input.renderer.layerConfig.firstRow; + output.resize.topRow = output.renderer.layerConfig.firstRow; function onMove(event) { setEditorWidth(startWidth + event.pageX - startX) diff --git a/src/core_plugins/console/public/src/smart_resize.js b/src/core_plugins/console/public/src/smart_resize.js index 0e52ce06080e5..611db5f4df00a 100644 --- a/src/core_plugins/console/public/src/smart_resize.js +++ b/src/core_plugins/console/public/src/smart_resize.js @@ -1,6 +1,16 @@ -import { throttle } from 'lodash'; +import { get, throttle } from 'lodash'; export default function (editor) { const resize = editor.resize; - return throttle(() => resize.call(editor), 35) + const throttledResize = throttle(() => { + + resize.call(editor); + + // Keep current top line in view when resizing to avoid losing user context + let userRow = get(throttledResize, 'topRow', 0); + if (userRow !== 0) { + editor.renderer.scrollToLine(userRow, false, false, () => {}); + } + }, 35); + return throttledResize; }