Better scroll handling when toggling editing.
It will now retain the scroll position relative to the full document height when entering and leaving editing mode. This places the viewport closer to the contents you were watching. This is likely less disorienting
This commit is contained in:
parent
619ba14b3f
commit
17c23da9bf
1 changed files with 18 additions and 7 deletions
|
@ -82,10 +82,11 @@ function openEditor() {
|
||||||
|
|
||||||
textarea.style.height = rendered.clientHeight + "px";
|
textarea.style.height = rendered.clientHeight + "px";
|
||||||
|
|
||||||
|
retainScrollRatio(() => {
|
||||||
container.classList.add('edit');
|
container.classList.add('edit');
|
||||||
updateFormEnabledState();
|
|
||||||
|
|
||||||
autosizeTextarea(textarea, shadow);
|
autosizeTextarea(textarea, shadow);
|
||||||
|
});
|
||||||
|
updateFormEnabledState();
|
||||||
|
|
||||||
textarea.setSelectionRange(textarea.value.length, textarea.value.length);
|
textarea.setSelectionRange(textarea.value.length, textarea.value.length);
|
||||||
textarea.focus();
|
textarea.focus();
|
||||||
|
@ -112,6 +113,18 @@ function openEditor() {
|
||||||
// TODO: edit-link in footer?
|
// TODO: edit-link in footer?
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function retainScrollRatio(innerFunction) {
|
||||||
|
const scrollElement = document.body.parentElement;
|
||||||
|
const savedScrollRatio = scrollElement.scrollTop / (scrollElement.scrollHeight - scrollElement.clientHeight);
|
||||||
|
innerFunction();
|
||||||
|
scrollElement.scrollTop = (scrollElement.scrollHeight - scrollElement.clientHeight) * savedScrollRatio;
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeEditor() {
|
||||||
|
retainScrollRatio(() => container.classList.remove('edit'));
|
||||||
|
document.activeElement && document.activeElement.blur();
|
||||||
|
}
|
||||||
|
|
||||||
function doSave() {
|
function doSave() {
|
||||||
state.saving = true;
|
state.saving = true;
|
||||||
updateFormEnabledState();
|
updateFormEnabledState();
|
||||||
|
@ -170,8 +183,7 @@ function openEditor() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!result.conflict) {
|
if (!result.conflict) {
|
||||||
container.classList.remove('edit');
|
closeEditor();
|
||||||
document.activeElement && document.activeElement.blur();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
state.saving = false;
|
state.saving = false;
|
||||||
|
@ -196,8 +208,7 @@ function openEditor() {
|
||||||
Promise.resolve(!isEdited(form) || confirmDiscard())
|
Promise.resolve(!isEdited(form) || confirmDiscard())
|
||||||
.then(doReset => {
|
.then(doReset => {
|
||||||
if (doReset) {
|
if (doReset) {
|
||||||
container.classList.remove('edit');
|
closeEditor();
|
||||||
document.activeElement && document.activeElement.blur();
|
|
||||||
updateFormEnabledState();
|
updateFormEnabledState();
|
||||||
form.reset();
|
form.reset();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue