Mercurial > hg
changeset 31848:7160bdd56b84
hgweb: add a floating tooltip to invite on followlines action
In followlines.js, we create a <div id="followlines-tooltip"> element to draw
attention of users on "followlines" feature. The element shows up on hover of
source lines after one second and follows the cursor. After first click (start
line selection), the text changes and indicates that next click will terminate
selection.
author | Denis Laxalde <denis.laxalde@logilab.fr> |
---|---|
date | Thu, 06 Apr 2017 19:15:09 +0200 |
parents | 39d36c2db68e |
children | 5c1abb4bd3ee |
files | mercurial/templates/static/followlines.js mercurial/templates/static/style-paper.css |
diffstat | 2 files changed, 63 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/templates/static/followlines.js Sat Apr 08 14:33:20 2017 -0700 +++ b/mercurial/templates/static/followlines.js Thu Apr 06 19:15:09 2017 +0200 @@ -17,6 +17,34 @@ return; } + // tooltip to invite on lines selection + var tooltip = document.createElement('div'); + tooltip.id = 'followlines-tooltip'; + tooltip.classList.add('hidden'); + var initTooltipText = 'click to start following lines history from here'; + tooltip.textContent = initTooltipText; + sourcelines.appendChild(tooltip); + + var tooltipTimeoutID; + //* move the "tooltip" with cursor (top-right) and show it after 1s */ + function moveAndShowTooltip(e) { + if (typeof tooltipTimeoutID !== 'undefined') { + // avoid accumulation of timeout callbacks (blinking) + window.clearTimeout(tooltipTimeoutID); + } + tooltip.classList.add('hidden'); + var x = (e.clientX + 10) + 'px', + y = (e.clientY - 20) + 'px'; + tooltip.style.top = y; + tooltip.style.left = x; + tooltipTimeoutID = window.setTimeout(function() { + tooltip.classList.remove('hidden'); + }, 1000); + } + + // on mousemove, show tooltip close to cursor position + sourcelines.addEventListener('mousemove', moveAndShowTooltip); + // retrieve all direct <span> children of <pre class="sourcelines"> var spans = Array.prototype.filter.call( sourcelines.children, @@ -65,6 +93,10 @@ // registered for other click with <span> target return; } + + // update tooltip text + tooltip.textContent = 'click again to terminate line block selection here'; + var startId = parseInt(startElement.id.slice(1)); startElement.classList.add(lineSelectedCSSClass); // CSS @@ -83,13 +115,25 @@ // remove this event listener sourcelines.removeEventListener('click', lineSelectEnd); + // hide tooltip and disable motion tracking + tooltip.classList.add('hidden'); + sourcelines.removeEventListener('mousemove', moveAndShowTooltip); + window.clearTimeout(tooltipTimeoutID); + + //* restore initial "tooltip" state */ + function restoreTooltip() { + tooltip.textContent = initTooltipText; + sourcelines.addEventListener('mousemove', moveAndShowTooltip); + } + // compute line range (startId, endId) var endId = parseInt(endElement.id.slice(1)); if (endId == startId) { // clicked twice the same line, cancel and reset initial state - // (CSS and event listener for selection start) + // (CSS, event listener for selection start, tooltip) removeSelectedCSSClass(); sourcelines.addEventListener('click', lineSelectStart); + restoreTooltip(); return; } var inviteElement = endElement; @@ -118,6 +162,8 @@ sourcelines.removeEventListener('click', cancel); // remove styles on selected lines removeSelectedCSSClass(); + // restore tooltip element + restoreTooltip(); } // bind cancel event to click on <button>
--- a/mercurial/templates/static/style-paper.css Sat Apr 08 14:33:20 2017 -0700 +++ b/mercurial/templates/static/style-paper.css Thu Apr 06 19:15:09 2017 +0200 @@ -320,6 +320,22 @@ font-family: sans-serif; } +div#followlines-tooltip { + display: none; + position: fixed; + background-color: #ffc; + border: 1px solid #999; + padding: 2px; +} + +.sourcelines:hover > div#followlines-tooltip { + display: inline; +} + +.sourcelines:hover > div#followlines-tooltip.hidden { + display: none; +} + .sourcelines > a { display: inline-block; position: absolute;