1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 07:11:04 +01:00

Improve tooltip behavior for Application menu items

Summary:
Ref T12174.

  - Fix text antialiasing pop-in at the end of the animation in Safari.
  - Fix flickery animation replay when mousing inside a tooltip element, or rapidly switching between tooltip elements.
    - To accomplish this: don't play the animation if the last tip was hidden less than 500ms ago.

Test Plan:
  - Viewed a tooltip in Safari.
  - Waved cursor wildly over application items, both left-right (within an item) and up-down (between items).

Tooltips appeared stable and non-flickery in all cases.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T12174

Differential Revision: https://secure.phabricator.com/D17272
This commit is contained in:
epriestley 2017-01-30 06:27:12 -08:00
parent ad01e26af7
commit 49b03c0353
3 changed files with 56 additions and 16 deletions

View file

@ -9,8 +9,8 @@ return array(
'names' => array( 'names' => array(
'conpherence.pkg.css' => 'e25569a9', 'conpherence.pkg.css' => 'e25569a9',
'conpherence.pkg.js' => '6249a1cf', 'conpherence.pkg.js' => '6249a1cf',
'core.pkg.css' => '25cda14d', 'core.pkg.css' => '7cd6d9cb',
'core.pkg.js' => 'f1e0e26f', 'core.pkg.js' => '1fa7c0c5',
'darkconsole.pkg.js' => 'e7393ebb', 'darkconsole.pkg.js' => 'e7393ebb',
'differential.pkg.css' => '4815647b', 'differential.pkg.css' => '4815647b',
'differential.pkg.js' => 'ddfeb49b', 'differential.pkg.js' => 'ddfeb49b',
@ -29,7 +29,7 @@ return array(
'rsrc/css/aphront/phabricator-nav-view.css' => 'b29426e9', 'rsrc/css/aphront/phabricator-nav-view.css' => 'b29426e9',
'rsrc/css/aphront/table-view.css' => '213a5981', 'rsrc/css/aphront/table-view.css' => '213a5981',
'rsrc/css/aphront/tokenizer.css' => '9a8cb501', 'rsrc/css/aphront/tokenizer.css' => '9a8cb501',
'rsrc/css/aphront/tooltip.css' => '3f325821', 'rsrc/css/aphront/tooltip.css' => '8f9faa9a',
'rsrc/css/aphront/typeahead-browse.css' => '8904346a', 'rsrc/css/aphront/typeahead-browse.css' => '8904346a',
'rsrc/css/aphront/typeahead.css' => 'd4f16145', 'rsrc/css/aphront/typeahead.css' => 'd4f16145',
'rsrc/css/application/almanac/almanac.css' => 'dbb9b3af', 'rsrc/css/application/almanac/almanac.css' => 'dbb9b3af',
@ -486,7 +486,7 @@ return array(
'rsrc/js/core/ShapedRequest.js' => '7cbe244b', 'rsrc/js/core/ShapedRequest.js' => '7cbe244b',
'rsrc/js/core/TextAreaUtils.js' => '320810c8', 'rsrc/js/core/TextAreaUtils.js' => '320810c8',
'rsrc/js/core/Title.js' => '485aaa6c', 'rsrc/js/core/Title.js' => '485aaa6c',
'rsrc/js/core/ToolTip.js' => 'd02f7181', 'rsrc/js/core/ToolTip.js' => '8fadb715',
'rsrc/js/core/behavior-active-nav.js' => 'e379b58e', 'rsrc/js/core/behavior-active-nav.js' => 'e379b58e',
'rsrc/js/core/behavior-audio-source.js' => '59b251eb', 'rsrc/js/core/behavior-audio-source.js' => '59b251eb',
'rsrc/js/core/behavior-autofocus.js' => '7319e029', 'rsrc/js/core/behavior-autofocus.js' => '7319e029',
@ -553,7 +553,7 @@ return array(
'aphront-panel-view-css' => '8427b78d', 'aphront-panel-view-css' => '8427b78d',
'aphront-table-view-css' => '213a5981', 'aphront-table-view-css' => '213a5981',
'aphront-tokenizer-control-css' => '9a8cb501', 'aphront-tokenizer-control-css' => '9a8cb501',
'aphront-tooltip-css' => '3f325821', 'aphront-tooltip-css' => '8f9faa9a',
'aphront-typeahead-control-css' => 'd4f16145', 'aphront-typeahead-control-css' => 'd4f16145',
'application-search-view-css' => '20ae9d85', 'application-search-view-css' => '20ae9d85',
'auth-css' => '0877ed6e', 'auth-css' => '0877ed6e',
@ -811,7 +811,7 @@ return array(
'phabricator-standard-page-view' => '894d8a25', 'phabricator-standard-page-view' => '894d8a25',
'phabricator-textareautils' => '320810c8', 'phabricator-textareautils' => '320810c8',
'phabricator-title' => '485aaa6c', 'phabricator-title' => '485aaa6c',
'phabricator-tooltip' => 'd02f7181', 'phabricator-tooltip' => '8fadb715',
'phabricator-ui-example-css' => '528b19de', 'phabricator-ui-example-css' => '528b19de',
'phabricator-uiexample-javelin-view' => 'd4a14807', 'phabricator-uiexample-javelin-view' => 'd4a14807',
'phabricator-uiexample-reactor-button' => 'd19198c8', 'phabricator-uiexample-reactor-button' => 'd19198c8',
@ -1602,6 +1602,12 @@ return array(
'javelin-stratcom', 'javelin-stratcom',
'javelin-util', 'javelin-util',
), ),
'8fadb715' => array(
'javelin-install',
'javelin-util',
'javelin-dom',
'javelin-vector',
),
'8ff5e24c' => array( '8ff5e24c' => array(
'javelin-behavior', 'javelin-behavior',
'javelin-stratcom', 'javelin-stratcom',
@ -2016,12 +2022,6 @@ return array(
'cd2b9b77' => array( 'cd2b9b77' => array(
'phui-oi-list-view-css', 'phui-oi-list-view-css',
), ),
'd02f7181' => array(
'javelin-install',
'javelin-util',
'javelin-dom',
'javelin-vector',
),
'd0c516d5' => array( 'd0c516d5' => array(
'javelin-behavior', 'javelin-behavior',
'javelin-dom', 'javelin-dom',

View file

@ -5,8 +5,25 @@
.jx-tooltip-container { .jx-tooltip-container {
position: absolute; position: absolute;
padding: 5px; padding: 5px;
opacity: 1; }
transition: opacity 0.25s ease;
.jx-tooltip-appear {
animation: 0.5s tooltip-appear;
/* Without this, there's a nasty pop-in effect at the end of the animation
when Safari changes font smoothing. The text becomes visibly more bold
after the last frame of animation. */
-webkit-font-smoothing: subpixel-antialiased;
}
@keyframes tooltip-appear {
0% {
opacity: 0;
}
100% {
opacity: 1;
}
} }
.jx-tooltip-hidden { .jx-tooltip-hidden {

View file

@ -11,6 +11,7 @@ JX.install('Tooltip', {
statics: { statics: {
_node: null, _node: null,
_last: null,
_lock: 0, _lock: 0,
show : function(root, scale, align, content) { show : function(root, scale, align, content) {
@ -46,7 +47,7 @@ JX.install('Tooltip', {
var node = JX.$N( var node = JX.$N(
'div', 'div',
{ className: 'jx-tooltip-container jx-tooltip-hidden' }, { className: 'jx-tooltip-container' },
node_inner); node_inner);
node.style.maxWidth = scale + 'px'; node.style.maxWidth = scale + 'px';
@ -61,7 +62,28 @@ JX.install('Tooltip', {
// Jump through some hoops trying to auto-position the tooltip // Jump through some hoops trying to auto-position the tooltip
var pos = self._getSmartPosition(align, root, node); var pos = self._getSmartPosition(align, root, node);
pos.setPos(node); pos.setPos(node);
JX.DOM.alterClass(node, 'jx-tooltip-hidden', false);
// Animate the tip if we haven't shown any tips recently. If we are
// already showing a tip (or hid one very recently) just show the tip
// immediately. This makes hunting for a particular item by mousing
// through tips smoother: you only have to sit through the animation
// once, at the beginning.
var is_recent = false;
var last_tip = self._last;
if (last_tip) {
// If we recently hid a tip, compute how many milliseconds ago we
// hid it.
var last_tip_age = (new Date().getTime() - self._last);
if (last_tip_age < 500) {
is_recent = true;
}
}
if (!is_recent) {
JX.DOM.alterClass(node, 'jx-tooltip-appear', true);
}
}, },
_getSmartPosition: function (align, root, node) { _getSmartPosition: function (align, root, node) {
@ -194,6 +216,7 @@ JX.install('Tooltip', {
if (this._node) { if (this._node) {
JX.DOM.remove(this._node); JX.DOM.remove(this._node);
this._node = null; this._node = null;
this._last = new Date().getTime();
} }
}, },