mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-13 16:21:07 +01:00
Fix two bugs with DraggableList
Summary: Ref T1344. This fixes two issues with DraggableList: - In lists which allowed it, you could drag the top item above itself and get a dashed-border ghost item. This didn't make sense and didn't behave well. Just don't treat this operation as valid. - In lists which allowed it, you could drag any non-top item to the topmost position, then drag it to an invalid position. The dashed-border ghost item would not be removed properly if this happend. - Also fix some minor leftovers with Celerity. Test Plan: - Dragged the first item above itself; now an invalid operation with no ghost. - Dragged another item to the first position then back to its original position; ghost vanishes. - Clean lint. Reviewers: chad, btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T1344 Differential Revision: https://secure.phabricator.com/D7939
This commit is contained in:
parent
996930da2a
commit
7ffddcd136
3 changed files with 14 additions and 5 deletions
|
@ -213,7 +213,7 @@ final class CelerityResourceMap {
|
|||
* is unknown.
|
||||
*/
|
||||
public function getRequiredSymbolsForName($name) {
|
||||
$hash = idx($this->symbolMap, $name);
|
||||
$hash = idx($this->nameMap, $name);
|
||||
if ($hash === null) {
|
||||
return null;
|
||||
}
|
||||
|
|
|
@ -147,7 +147,7 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
|||
$path);
|
||||
$need = $external_classes;
|
||||
|
||||
$resource_name = substr($path, strlen('webroot'));
|
||||
$resource_name = substr($path, strlen('webroot/'));
|
||||
$requires = $celerity->getRequiredSymbolsForName($resource_name);
|
||||
if (!$requires) {
|
||||
$requires = array();
|
||||
|
@ -170,7 +170,7 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
|||
// If JS requires CSS, just assume everything is fine.
|
||||
unset($requires[$key]);
|
||||
} else {
|
||||
$symbol_path = 'webroot'.$requires_name;
|
||||
$symbol_path = 'webroot/'.$requires_name;
|
||||
list($ignored, $req_install) = $this->getUsedAndInstalledSymbolsForPath(
|
||||
$symbol_path);
|
||||
if (array_intersect_key($req_install, $external_classes)) {
|
||||
|
|
|
@ -197,12 +197,21 @@ JX.install('DraggableList', {
|
|||
break;
|
||||
}
|
||||
|
||||
// If the dragged row is the first row, don't allow it to be dragged
|
||||
// into the first position, since this operation doesn't make sense.
|
||||
if (cur_target === null) {
|
||||
var first_item = targets[targets.length - 1].item;
|
||||
if (dragging === first_item) {
|
||||
cur_target = false;
|
||||
}
|
||||
}
|
||||
|
||||
// If we've selected a new target, update the UI to show where we're
|
||||
// going to drop the row.
|
||||
|
||||
if (cur_target != target) {
|
||||
if (cur_target !== target) {
|
||||
|
||||
if (target) {
|
||||
if (target !== false) {
|
||||
JX.DOM.remove(ghost);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue