1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-27 01:02:42 +01:00

Fix the attempt of graceful alignment for Hovercards

Summary:
Refs T1048; Fixes T2902 - (Probably) fixes @vrana's issue. I managed
to repro it on Ubuntu FF (though on Windows with 1.0GHz/512MB it's
really worse...).

This revises the approach to the graceful degradation for
`too-far-to-the-screen-edge-edge-case`.

I noticed that `x` could become very negative, up to about ~`-170px`.
This is due to the //"already-on-the-left-side"// nature of object tags.
`50 - 200 - 20` = `negative`. Adding `100px` (node.dimension.x / 4) to
that won't really help, as the hovercard would still be offscreen.

Instead, display them left-aligned with the object tags on the left edge
per default, and offer centerization in center cases. This is also better
for Pholio, Phriction, which have a way lower min-x than Maniphest,
Differential.

I also disabled placing the hovercard below the tag in case there's not
enough space on the north side. The hovercard would not display 99.99% of
the times after being hidden (and it retains the flickering behaviour).
Another reason is also our current hide-behaviour, which only assumes
north-side alignment. Adding south-side didn't really work (I'm bad with
JS), so I didn't bother with it. Disabling this is //acceptable//, since
it only really affects Pholio, Phriction. And nobody places object tags
in the first line, anyway. Except for my test pages, of course :/

Btw, this also removes the weird jaggy horizontal shifts for object of
various lengths (e.g. `{D4356}`, `{rP32ofhw0842obw}` etc.). I think
that's only good.

Test Plan:
Hovered in Pholio, Phriction in Chrome, FF. Did not touch
left screen border.

Hovered in Maniphest, Differential. Tags farther to the left were
aligned left, tags more in the center were pretty centered.

Reviewers: epriestley, vrana

Reviewed By: epriestley

CC: aran, Korvin

Maniphest Tasks: T1048, T2902

Differential Revision: https://secure.phabricator.com/D5612
This commit is contained in:
Anh Nhan Nguyen 2013-04-07 18:10:43 -07:00 committed by epriestley
parent 3c1a0b76fa
commit dbcd38aa88
3 changed files with 58 additions and 54 deletions

View file

@ -1905,7 +1905,7 @@ celerity_register_resource_map(array(
), ),
'javelin-behavior-phabricator-hovercards' => 'javelin-behavior-phabricator-hovercards' =>
array( array(
'uri' => '/res/65824840/rsrc/js/application/core/behavior-hovercard.js', 'uri' => '/res/7c16603a/rsrc/js/application/core/behavior-hovercard.js',
'type' => 'js', 'type' => 'js',
'requires' => 'requires' =>
array( array(
@ -2749,7 +2749,7 @@ celerity_register_resource_map(array(
), ),
'maniphest-task-edit-css' => 'maniphest-task-edit-css' =>
array( array(
'uri' => '/res/e9eddd31/rsrc/css/application/maniphest/task-edit.css', 'uri' => '/res/0760f768/rsrc/css/application/maniphest/task-edit.css',
'type' => 'css', 'type' => 'css',
'requires' => 'requires' =>
array( array(
@ -2911,7 +2911,7 @@ celerity_register_resource_map(array(
), ),
'phabricator-core-css' => 'phabricator-core-css' =>
array( array(
'uri' => '/res/09a94677/rsrc/css/core/core.css', 'uri' => '/res/169b95b3/rsrc/css/core/core.css',
'type' => 'css', 'type' => 'css',
'requires' => 'requires' =>
array( array(
@ -3043,7 +3043,7 @@ celerity_register_resource_map(array(
), ),
'phabricator-hovercard' => 'phabricator-hovercard' =>
array( array(
'uri' => '/res/80f2fdb1/rsrc/js/application/core/Hovercard.js', 'uri' => '/res/d70f1091/rsrc/js/application/core/Hovercard.js',
'type' => 'js', 'type' => 'js',
'requires' => 'requires' =>
array( array(
@ -3900,7 +3900,7 @@ celerity_register_resource_map(array(
), array( ), array(
'packages' => 'packages' =>
array( array(
'b5f1b8bd' => '30e5f188' =>
array( array(
'name' => 'core.pkg.css', 'name' => 'core.pkg.css',
'symbols' => 'symbols' =>
@ -3942,7 +3942,7 @@ celerity_register_resource_map(array(
34 => 'phabricator-object-item-list-view-css', 34 => 'phabricator-object-item-list-view-css',
35 => 'global-drag-and-drop-css', 35 => 'global-drag-and-drop-css',
), ),
'uri' => '/res/pkg/b5f1b8bd/core.pkg.css', 'uri' => '/res/pkg/30e5f188/core.pkg.css',
'type' => 'css', 'type' => 'css',
), ),
'd95b69e5' => 'd95b69e5' =>
@ -4132,16 +4132,16 @@ celerity_register_resource_map(array(
'reverse' => 'reverse' =>
array( array(
'aphront-attached-file-view-css' => '6b1fccc6', 'aphront-attached-file-view-css' => '6b1fccc6',
'aphront-dialog-view-css' => 'b5f1b8bd', 'aphront-dialog-view-css' => '30e5f188',
'aphront-error-view-css' => 'b5f1b8bd', 'aphront-error-view-css' => '30e5f188',
'aphront-form-view-css' => 'b5f1b8bd', 'aphront-form-view-css' => '30e5f188',
'aphront-list-filter-view-css' => 'b5f1b8bd', 'aphront-list-filter-view-css' => '30e5f188',
'aphront-pager-view-css' => 'b5f1b8bd', 'aphront-pager-view-css' => '30e5f188',
'aphront-panel-view-css' => 'b5f1b8bd', 'aphront-panel-view-css' => '30e5f188',
'aphront-table-view-css' => 'b5f1b8bd', 'aphront-table-view-css' => '30e5f188',
'aphront-tokenizer-control-css' => 'b5f1b8bd', 'aphront-tokenizer-control-css' => '30e5f188',
'aphront-tooltip-css' => 'b5f1b8bd', 'aphront-tooltip-css' => '30e5f188',
'aphront-typeahead-control-css' => 'b5f1b8bd', 'aphront-typeahead-control-css' => '30e5f188',
'differential-changeset-view-css' => '8aaacd1b', 'differential-changeset-view-css' => '8aaacd1b',
'differential-core-view-css' => '8aaacd1b', 'differential-core-view-css' => '8aaacd1b',
'differential-inline-comment-editor' => 'e96b08f8', 'differential-inline-comment-editor' => 'e96b08f8',
@ -4155,7 +4155,7 @@ celerity_register_resource_map(array(
'differential-table-of-contents-css' => '8aaacd1b', 'differential-table-of-contents-css' => '8aaacd1b',
'diffusion-commit-view-css' => 'c8ce2d88', 'diffusion-commit-view-css' => 'c8ce2d88',
'diffusion-icons-css' => 'c8ce2d88', 'diffusion-icons-css' => 'c8ce2d88',
'global-drag-and-drop-css' => 'b5f1b8bd', 'global-drag-and-drop-css' => '30e5f188',
'inline-comment-summary-css' => '8aaacd1b', 'inline-comment-summary-css' => '8aaacd1b',
'javelin-aphlict' => 'd95b69e5', 'javelin-aphlict' => 'd95b69e5',
'javelin-behavior' => 'a2f94024', 'javelin-behavior' => 'a2f94024',
@ -4227,47 +4227,47 @@ celerity_register_resource_map(array(
'javelin-util' => 'a2f94024', 'javelin-util' => 'a2f94024',
'javelin-vector' => 'a2f94024', 'javelin-vector' => 'a2f94024',
'javelin-workflow' => 'a2f94024', 'javelin-workflow' => 'a2f94024',
'lightbox-attachment-css' => 'b5f1b8bd', 'lightbox-attachment-css' => '30e5f188',
'maniphest-task-summary-css' => '6b1fccc6', 'maniphest-task-summary-css' => '6b1fccc6',
'maniphest-transaction-detail-css' => '6b1fccc6', 'maniphest-transaction-detail-css' => '6b1fccc6',
'phabricator-busy' => 'd95b69e5', 'phabricator-busy' => 'd95b69e5',
'phabricator-content-source-view-css' => '8aaacd1b', 'phabricator-content-source-view-css' => '8aaacd1b',
'phabricator-core-buttons-css' => 'b5f1b8bd', 'phabricator-core-buttons-css' => '30e5f188',
'phabricator-core-css' => 'b5f1b8bd', 'phabricator-core-css' => '30e5f188',
'phabricator-crumbs-view-css' => 'b5f1b8bd', 'phabricator-crumbs-view-css' => '30e5f188',
'phabricator-directory-css' => 'b5f1b8bd', 'phabricator-directory-css' => '30e5f188',
'phabricator-drag-and-drop-file-upload' => 'e96b08f8', 'phabricator-drag-and-drop-file-upload' => 'e96b08f8',
'phabricator-dropdown-menu' => 'd95b69e5', 'phabricator-dropdown-menu' => 'd95b69e5',
'phabricator-file-upload' => 'd95b69e5', 'phabricator-file-upload' => 'd95b69e5',
'phabricator-filetree-view-css' => 'b5f1b8bd', 'phabricator-filetree-view-css' => '30e5f188',
'phabricator-flag-css' => 'b5f1b8bd', 'phabricator-flag-css' => '30e5f188',
'phabricator-form-view-css' => 'b5f1b8bd', 'phabricator-form-view-css' => '30e5f188',
'phabricator-header-view-css' => 'b5f1b8bd', 'phabricator-header-view-css' => '30e5f188',
'phabricator-jump-nav' => 'b5f1b8bd', 'phabricator-jump-nav' => '30e5f188',
'phabricator-keyboard-shortcut' => 'd95b69e5', 'phabricator-keyboard-shortcut' => 'd95b69e5',
'phabricator-keyboard-shortcut-manager' => 'd95b69e5', 'phabricator-keyboard-shortcut-manager' => 'd95b69e5',
'phabricator-main-menu-view' => 'b5f1b8bd', 'phabricator-main-menu-view' => '30e5f188',
'phabricator-menu-item' => 'd95b69e5', 'phabricator-menu-item' => 'd95b69e5',
'phabricator-nav-view-css' => 'b5f1b8bd', 'phabricator-nav-view-css' => '30e5f188',
'phabricator-notification' => 'd95b69e5', 'phabricator-notification' => 'd95b69e5',
'phabricator-notification-css' => 'b5f1b8bd', 'phabricator-notification-css' => '30e5f188',
'phabricator-notification-menu-css' => 'b5f1b8bd', 'phabricator-notification-menu-css' => '30e5f188',
'phabricator-object-item-list-view-css' => 'b5f1b8bd', 'phabricator-object-item-list-view-css' => '30e5f188',
'phabricator-object-selector-css' => '8aaacd1b', 'phabricator-object-selector-css' => '8aaacd1b',
'phabricator-prefab' => 'd95b69e5', 'phabricator-prefab' => 'd95b69e5',
'phabricator-project-tag-css' => '6b1fccc6', 'phabricator-project-tag-css' => '6b1fccc6',
'phabricator-remarkup-css' => 'b5f1b8bd', 'phabricator-remarkup-css' => '30e5f188',
'phabricator-shaped-request' => 'e96b08f8', 'phabricator-shaped-request' => 'e96b08f8',
'phabricator-side-menu-view-css' => 'b5f1b8bd', 'phabricator-side-menu-view-css' => '30e5f188',
'phabricator-standard-page-view' => 'b5f1b8bd', 'phabricator-standard-page-view' => '30e5f188',
'phabricator-textareautils' => 'd95b69e5', 'phabricator-textareautils' => 'd95b69e5',
'phabricator-tooltip' => 'd95b69e5', 'phabricator-tooltip' => 'd95b69e5',
'phabricator-transaction-view-css' => 'b5f1b8bd', 'phabricator-transaction-view-css' => '30e5f188',
'phabricator-zindex-css' => 'b5f1b8bd', 'phabricator-zindex-css' => '30e5f188',
'sprite-apps-large-css' => 'b5f1b8bd', 'sprite-apps-large-css' => '30e5f188',
'sprite-gradient-css' => 'b5f1b8bd', 'sprite-gradient-css' => '30e5f188',
'sprite-icon-css' => 'b5f1b8bd', 'sprite-icon-css' => '30e5f188',
'sprite-menu-css' => 'b5f1b8bd', 'sprite-menu-css' => '30e5f188',
'syntax-highlighting-css' => 'b5f1b8bd', 'syntax-highlighting-css' => '30e5f188',
), ),
)); ));

View file

@ -80,21 +80,24 @@ JX.install('Hovercard', {
var n = JX.Vector.getDim(child); var n = JX.Vector.getDim(child);
// Move the tip so it's nicely aligned. // Move the tip so it's nicely aligned.
// I'm just doing north alignment for now // I'm just doing north/south alignment for now
// TODO: Gracefully align to the side in edge cases // TODO: Fix southern graceful align
// I know, hardcoded paddings... var margin = 20;
var x = parseInt(p.x - ((n.x - d.x) / 2)) + 20; // We can't shift left by ~$margin or more here due to Pholio, Phriction
var y = parseInt(p.y - n.y) - 20; var x = parseInt(p.x) - margin / 2;
var y = parseInt(p.y - n.y) - margin;
// Why use 4? Shouldn't it be just 2? // If more in the center, we can safely center
if (x < (n.x / 4)) { if (x > (n.x / 2) + margin) {
x += (n.x / 4); x = parseInt(p.x - (n.x / 2) + d.x);
} }
if (y < n.y) { // Temporarily disabled, since it gives weird results (you can only see
// Place it at the bottom // a hovercard once, as soon as it's hidden, it cannot be shown again)
y += n.y + d.y + 50; // if (y < n.y) {
} // // Place it southern, since northern is not enough space
// y = p.y + d.y + margin;
// }
node.style.left = x + 'px'; node.style.left = x + 'px';
node.style.top = y + 'px'; node.style.top = y + 'px';

View file

@ -36,6 +36,7 @@ JX.behavior('phabricator-hovercards', function(config) {
var root = JX.Hovercard.getAnchor(); var root = JX.Hovercard.getAnchor();
var node = JX.Hovercard.getCard(); var node = JX.Hovercard.getCard();
// TODO: Add southern cases here, too
var mouse = JX.$V(e); var mouse = JX.$V(e);
var node_pos = JX.$V(node); var node_pos = JX.$V(node);
var node_dim = JX.Vector.getDim(node); var node_dim = JX.Vector.getDim(node);