mirror of
https://github.com/alextselegidis/easyappointments.git
synced 2024-11-09 17:42:21 +03:00
Updated sorting to comply with latest layout.
This commit is contained in:
parent
23cebdda5d
commit
3d45182c2b
2 changed files with 33 additions and 4 deletions
|
@ -106,7 +106,7 @@ class Services extends EA_Controller
|
|||
|
||||
$keyword = request('keyword', '');
|
||||
|
||||
$order_by = request('order_by', 'row_order ASC, update_datetime DESC');
|
||||
$order_by = 'update_datetime DESC';
|
||||
|
||||
$limit = request('limit', 1000);
|
||||
|
||||
|
|
|
@ -94,18 +94,47 @@ App.Pages.Services = (function () {
|
|||
*/
|
||||
|
||||
const sorting = new Sortable(document.querySelector('.results'), {
|
||||
onStart : function(ev) {
|
||||
if (ev.from.querySelector('hr') == null)
|
||||
return;
|
||||
if (! (ev.item.nextSibling && ev.item.nextSibling.tagName == 'HR'))
|
||||
return;
|
||||
ev.item.dataset['hadHR'] = true;
|
||||
ev.item.nextSibling.remove();
|
||||
},
|
||||
onUpdate : async function(ev){
|
||||
resetForm();
|
||||
let afterId;
|
||||
const currentItemId = ev.item.dataset['id'];
|
||||
const hadHR = ev.item.dataset['hadHR'] == 'true';
|
||||
;
|
||||
|
||||
if (ev.newIndex == 0)
|
||||
afterId = -1;
|
||||
else if (ev.item.previousSibling !== null && ev.item.previousSibling.classList.contains('service-row')) {
|
||||
afterId = parseInt(ev.item.previousSibling.dataset['id']);
|
||||
else if (ev.item.previousSibling !== null) {
|
||||
let prevItem =ev.item.previousSibling;
|
||||
if (prevItem.tagName == 'HR')
|
||||
prevItem = prevItem.previousSibling;
|
||||
|
||||
if (! prevItem.classList.contains('service-row')){
|
||||
window.App.Utils.Message.show(lang('unexpected_issues'),'Failed to get previous service to sort!');
|
||||
throw 'Failed to get previous service to sort';
|
||||
}
|
||||
|
||||
afterId = parseInt(prevItem.dataset['id']);
|
||||
|
||||
}
|
||||
try {
|
||||
await sort(currentItemId, afterId)
|
||||
await sort(currentItemId, afterId);
|
||||
if (hadHR)
|
||||
{
|
||||
const newHr = document.createElement('HR');
|
||||
if (ev.oldIndex < ev.newIndex)
|
||||
ev.item.before(newHr);
|
||||
else
|
||||
ev.item.after(newHr);
|
||||
delete ev.item.dataset.hadHR;
|
||||
}
|
||||
}
|
||||
catch (err){
|
||||
$services.find('.form-message').addClass('alert-danger').text(lang('error')).show();
|
||||
|
|
Loading…
Reference in a new issue