From f2d5498813434e2b27239c1fdd5f1193b67170d8 Mon Sep 17 00:00:00 2001 From: Vanessa Date: Tue, 28 Jun 2022 18:03:03 +0800 Subject: [PATCH] :art: fix https://github.com/siyuan-note/siyuan/issues/5307 --- app/src/layout/dock/Outline.ts | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/app/src/layout/dock/Outline.ts b/app/src/layout/dock/Outline.ts index 79ceba2f8..12b2afb5f 100644 --- a/app/src/layout/dock/Outline.ts +++ b/app/src/layout/dock/Outline.ts @@ -12,6 +12,7 @@ import {focusBlock} from "../../protyle/util/selection"; import {pushBack} from "../../util/backForward"; import {escapeHtml} from "../../util/escape"; import {unicode2Emoji} from "../../emoji"; +import {onGet} from "../../protyle/util/onGet"; export class Outline extends Model { private tree: Tree; @@ -152,7 +153,17 @@ export class Outline extends Model { } else if (target.isSameNode(this.headerElement.nextElementSibling) || target.classList.contains("block__icons")) { getAllModels().editor.find(item => { if (this.blockId === item.editor.protyle.block.rootID) { - item.editor.protyle.contentElement.scrollTop = 0; + if (item.editor.protyle.scroll.element.classList.contains("fn__none")) { + item.editor.protyle.contentElement.scrollTop = 0; + } else { + fetchPost("/api/filetree/getDoc", { + id: item.editor.protyle.block.rootID, + mode: 0, + size: Constants.SIZE_GET, + }, getResponse => { + onGet(getResponse, item.editor.protyle, [Constants.CB_GET_FOCUS]); + }); + } return true; } });