From a55ece023ade11aabadbb3fd8293aceb08ec4da0 Mon Sep 17 00:00:00 2001 From: Cheng-Han, Wu Date: Tue, 15 Mar 2016 11:12:45 +0800 Subject: Improved checkCursorMenu and checkCursorTag performance and fully rewrite its position method for UX and verified --- public/js/index.js | 130 +++++++++++++++++++++++++++++++++-------------------- 1 file changed, 82 insertions(+), 48 deletions(-) diff --git a/public/js/index.js b/public/js/index.js index e0213734..79c2af0b 100644 --- a/public/js/index.js +++ b/public/js/index.js @@ -54,7 +54,7 @@ var defaultExtraKeys = { var idleTime = 300000; //5 mins var updateViewDebounce = 200; -var cursorMenuThrottle = 100; +var cursorMenuThrottle = 50; var cursorActivityDebounce = 50; var cursorAnimatePeriod = 100; var supportContainers = ['success', 'info', 'warning', 'danger']; @@ -531,6 +531,8 @@ var ui = { view: $(".ui-view-area"), codemirror: $(".ui-edit-area .CodeMirror"), codemirrorScroll: $(".ui-edit-area .CodeMirror .CodeMirror-scroll"), + codemirrorSizer: $(".ui-edit-area .CodeMirror .CodeMirror-sizer"), + codemirrorSizerInner: $(".ui-edit-area .CodeMirror .CodeMirror-sizer > div"), markdown: $(".ui-view-area .markdown-body") } }; @@ -1897,33 +1899,41 @@ function emitUserStatus(force) { } function checkCursorTag(coord, ele) { - if (!ele) return; - var curosrtagMargin = 60; - var cursor = editor.getCursor(); - //var viewport = editor.getViewport(); - //var viewportHeight = (viewport.to - viewport.from) * editor.defaultTextHeight(); + if (!ele) return; // return if element not exists + // set margin + var tagRightMargin = 0; + var tagBottomMargin = 2; + // use sizer to get the real doc size (won't count status bar and gutters) + var docWidth = ui.area.codemirrorSizer.width(); + var docHeight = ui.area.codemirrorSizer.height(); + // get editor size (status bar not count in) var editorWidth = ui.area.codemirror.width(); var editorHeight = ui.area.codemirror.height(); - var width = ele.width(); - var height = ele.height(); - if (!lineHeightMap) - buildMapInner(); + // get element size + var width = ele.outerWidth(); + var height = ele.outerHeight(); + var padding = (ele.outerWidth() - ele.width()) / 2; + // get coord position var left = coord.left; - var top = lineHeightMap[cursor.line] * defaultTextHeight; //coord.top; - top -= ele.closest('.CodeMirror-sizer > *').position().top; + var top = coord.top; + // get doc top offset (to workaround with viewport) + var docTopOffset = ui.area.codemirrorSizerInner.position().top; + // set offset var offsetLeft = -3; var offsetTop = defaultTextHeight; - var statusBarHeight = 0; - if (statusBar) - statusBarHeight = statusBar.outerHeight(); + // only do when have width and height if (width > 0 && height > 0) { - if (left + width + offsetLeft > editorWidth - curosrtagMargin) { - offsetLeft = -(width + 10); + // flip x when element right bound larger than doc width + if (left + width + offsetLeft + tagRightMargin > docWidth) { + offsetLeft = -(width + tagRightMargin) + padding + offsetLeft; } - if (top + height + offsetTop > Math.max(editor.doc.height, editorHeight) + curosrtagMargin - statusBarHeight * 2 && top - height > curosrtagMargin) { - offsetTop = -(height + 4); + // flip y when element bottom bound larger than doc height + // and element top position is larger than element height + if (top + docTopOffset + height + offsetTop + tagBottomMargin > Math.max(editor.doc.height, editorHeight) && top + docTopOffset > height + tagBottomMargin) { + offsetTop = -(height); } } + // set position ele[0].style.left = offsetLeft + 'px'; ele[0].style.top = offsetTop + 'px'; } @@ -2464,56 +2474,80 @@ if ($('.cursor-menu').length <= 0) { $("