Added visual cue when moving cross pages

Implemented a better sorting algorithm for sorting cross pages

Removed sorting to first page and last page as this would mean re-indexing allot of items potentially
This commit is contained in:
UndefinedOffset 2012-05-18 10:50:09 -03:00
parent ade87d5ff1
commit b0fcb318ad
4 changed files with 70 additions and 41 deletions

View File

@ -16,5 +16,3 @@ To move an item to another page drag the row over the respective page button and
## @TODO ## @TODO
* Optimize re-ordering of a has_many relationship when sorting on a single page * Optimize re-ordering of a has_many relationship when sorting on a single page
* Add visual cue that a row can be dropped over the page icons
* Implement shifting when sorting cross pages

View File

@ -278,7 +278,6 @@ class GridFieldSortableRows implements GridField_HTMLProvider, GridField_ActionP
user_error('Target item not found', E_USER_ERROR); user_error('Target item not found', E_USER_ERROR);
} }
$sortPosition = $targetItem->$sortColumn;
$currentPage = 1; $currentPage = 1;
@ -293,53 +292,84 @@ class GridFieldSortableRows implements GridField_HTMLProvider, GridField_ActionP
} }
if ($data['Target'] == 'firstpage') { if ($data['Target'] == 'previouspage') {
$sortPosition = $paginator->getItemsPerPage(); $sortPositions = $items->limit($paginator->getItemsPerPage() + 1, ($paginator->getItemsPerPage() * ($currentPage - 1)) - 1)->column($sortColumn);
} else if ($data['Target'] == 'previouspage') {
$sortPosition = $paginator->getItemsPerPage() * ($currentPage - 1);
} else if ($data['Target'] == 'nextpage') { } else if ($data['Target'] == 'nextpage') {
$sortPosition = ($paginator->getItemsPerPage() * $currentPage) + 1; $sortPositions = $items->limit($paginator->getItemsPerPage() + 1, $paginator->getItemsPerPage() * ($currentPage - 1))->column($sortColumn);
} else if ($data['Target'] == 'lastpage') {
$sortPosition = ($paginator->getItemsPerPage() * (ceil($items->count() / $paginator->getItemsPerPage()) - 1)) + 1;
} else { } else {
user_error('Not implemented: '.$data['Target'], E_USER_ERROR); user_error('Not implemented: '.$data['Target'], E_USER_ERROR);
} }
if($targetItem->$sortColumn != $sortPosition) { //Start transaction if supported
//Start transaction if supported if(DB::getConn()->supportsTransactions()) {
if(DB::getConn()->supportsTransactions()) { DB::getConn()->transactionStart();
DB::getConn()->transactionStart(); }
}
if($data['Target']=='previouspage') {
//Swap with the item around the target position
$swapItem = $items->where('"'.$sortColumn.'" >= '.$sortPosition)->First();
if ($many_many) { if ($many_many) {
DB::query('UPDATE "' . $table DB::query('UPDATE "' . $table
. '" SET "' . $sortColumn.'" = ' . $targetItem->$sortColumn . '" SET "' . $sortColumn.'" = ' . $sortPositions[0]
. ' WHERE "' . $componentField . '" = ' . $swapItem->ID . ' AND "' . $parentField . '" = ' . $owner->ID);
} else {
$swapItem->$sortColumn = $targetItem->$sortColumn;
$swapItem->write();
}
//Update target item position
if ($many_many) {
DB::query('UPDATE "' . $table
. '" SET "' . $sortColumn.'" = ' . $sortPosition
. ' WHERE "' . $componentField . '" = ' . $targetItem->ID . ' AND "' . $parentField . '" = ' . $owner->ID); . ' WHERE "' . $componentField . '" = ' . $targetItem->ID . ' AND "' . $parentField . '" = ' . $owner->ID);
} else { } else {
$targetItem->$sortColumn = $sortPosition; $targetItem->$sortColumn = $sortPositions[0];
$targetItem->write(); $targetItem->write();
} }
//End transaction if supported $i = 1;
if(DB::getConn()->supportsTransactions()) { foreach ($items as $obj) {
DB::getConn()->transactionEnd(); if ($obj->ID == $targetItem->ID) {
continue;
}
if ($many_many) {
DB::query('UPDATE "' . $table
. '" SET "' . $sortColumn.'" = ' . $sortPositions[$i]
. ' WHERE "' . $componentField . '" = ' . $obj->ID . ' AND "' . $parentField . '" = ' . $owner->ID);
} else {
$obj->$sortColumn = $sortPositions[$i];
$obj->write();
}
$i++;
} }
} else {
if ($many_many) {
DB::query('UPDATE "' . $table
. '" SET "' . $sortColumn.'" = ' . $sortPositions[count($sortPositions) - 1]
. ' WHERE "' . $componentField . '" = ' . $targetItem->ID . ' AND "' . $parentField . '" = ' . $owner->ID);
} else {
$targetItem->$sortColumn = $sortPositions[count($sortPositions) - 1];
$targetItem->write();
}
$i = 0;
foreach ($items as $obj) {
if ($obj->ID == $targetItem->ID) {
continue;
}
if ($many_many) {
DB::query('UPDATE "' . $table
. '" SET "' . $sortColumn.'" = ' . $sortPositions[$i]
. ' WHERE "' . $componentField . '" = ' . $obj->ID . ' AND "' . $parentField . '" = ' . $owner->ID);
} else {
$obj->$sortColumn = $sortPositions[$i];
$obj->write();
}
$i++;
}
}
//End transaction if supported
if(DB::getConn()->supportsTransactions()) {
DB::getConn()->transactionEnd();
} }
} }
} }

View File

@ -8,4 +8,8 @@
.cms table.ss-gridfield-table.dragSorting tbody tr td { .cms table.ss-gridfield-table.dragSorting tbody tr td {
cursor: move; cursor: move;
}
.cms table.ss-gridfield-table .datagrid-pagination button.sortablerows-droptarget {
background-image: url(./../images/pagination-arrows-drop.gif) !important;
} }

View File

@ -47,10 +47,11 @@
} }
}).disableSelection(); }).disableSelection();
gridField.find('.datagrid-pagination button').each(function() { gridField.find('.datagrid-pagination .ss-gridfield-previouspage, .datagrid-pagination .ss-gridfield-nextpage').each(function() {
$(this).droppable({ $(this).droppable({
disabled: $(this).is(':disabled'), disabled: $(this).is(':disabled'),
accept: 'tr.ss-gridfield-item', accept: 'tr.ss-gridfield-item',
activeClass: 'sortablerows-droptarget',
tolerance: 'pointer', tolerance: 'pointer',
drop: function(event, ui) { drop: function(event, ui) {
gridField.find('tbody').sortable('cancel'); gridField.find('tbody').sortable('cancel');
@ -60,14 +61,10 @@
var target=''; var target='';
if($(this).hasClass('ss-gridfield-firstpage')) { if($(this).hasClass('ss-gridfield-previouspage')) {
target='firstpage';
}else if($(this).hasClass('ss-gridfield-previouspage')) {
target='previouspage'; target='previouspage';
}else if($(this).hasClass('ss-gridfield-nextpage')) { }else if($(this).hasClass('ss-gridfield-nextpage')) {
target='nextpage'; target='nextpage';
}else if($(this).hasClass('ss-gridfield-lastpage')) {
target='lastpage';
} }