I am developing a prestashop module to position products in a brand. I created a table with id_product - position and id_manufacturer. In each brand currently I have a product in position 0 and other with positions greater than 0. What I am trying to do in my module is when I move a product, the products that are at 0 should be available. increments from 0 to n and that my product that I automatically move this puts at the requested position.
This is what my product list looks like
I wish that the sort would be suddenly from the largest to the smallest. Here is my JS code:
$('.admindraganddropproducts #list_products tbody').sortable({
start: function(e, ui) {
$(this).attr('data-previndex', ui.item.index());
},
update: function (event, ui) {
var list = ui.item.parent('tbody');
var pos = $('tbody.ui-sortable > tr').size();
var element_id = ui.item.attr('id');
var movement = ui.position.top - ui.originalPosition.top > 0 ? 1 : 0;
$(this).removeAttr('data-previndex');
$(list.find('tr').each(function () {
pos--;
$(this).find('input.position_product_manufacturer').val(pos);
}));
$('.loading_products').css('display', 'block');
$.ajax({
url: draganddrop_manufacturer_products,
type: 'post',
async: true,
dataType: "json",
data: {
ajax: true,
controller: 'AdminDrag',
action: 'Position',
id_manufacturer: $('#manufacturer_select option:selected').val(),
id_product: $('#' + element_id + ' input.id_product').val(),
way: movement,
position: $('#' + element_id + ' input.position_product_manufacturer').val(),
},
success: function (data) {
$('.loading_products').css('display', 'none');
if (!data.error) {
$('#list_products').before('<div class="alert alert-success">' + data.message + '</div>');
} else {
$('#list_products').before('<div class="alert alert-danger">' + data.message + '</div>');
}
var id_manufacturer_url = GetURLParameter('id_manufacturer');
if (!id_manufacturer_url) {
window.location.href = window.location.href + '&id_manufacturer=' + $('#manufacturer_select option:selected').val();
} else {
location.reload();
}
}
});
}
});
when I move the element the repositioning is done correctly but it is php side where I get stuck. Here is my PHP:
public function updatePositionProductManufacturer($way, $position, $id_manufacturer)
{
$res = Db::getInstance()->executeS('
SELECT mp.`id_product`, mp.`position`, mp.`id_manufacturer`
FROM `' . _DB_PREFIX_ . 'manufacturer_product` mp
WHERE mp.`id_manufacturer` = ' . (int) $id_manufacturer . '
ORDER BY mp.`position` DESC');
if (!$res) {
return false;
}
$movedProduct = false;
foreach ($res as $product) {
if ((int) $product['id_product'] == (int) $this->id_product) {
$movedProduct = $product;
}
}
if ($movedProduct === false) {
return false;
}
// < and > statements rather than BETWEEN operator
// since BETWEEN is treated differently according to databases
$result = (Db::getInstance()->execute('
UPDATE ' . _DB_PREFIX_ . 'manufacturer_product mp
SET mp.position = mp.position ' . ((int)$way ? '- 1' : '+ 1') . '
WHERE mp.position
' . ((int)$way
? '> ' . (int) $movedProduct['position'] . ' AND mp.position <= ' . (int) $position
: '< ' . (int) $movedProduct['position'] . ' AND mp.position >= ' . (int) $position) . '
AND mp.id_manufacturer =' . (int) $movedProduct['id_manufacturer'])
&& Db::getInstance()->execute('
UPDATE ' . _DB_PREFIX_ . 'manufacturer_product mp
SET mp.position = ' . (int) $position . '
WHERE mp.id_manufacturer = ' . (int) $movedProduct['id_manufacturer'] . '
AND mp.id_product =' . (int) $movedProduct['id_product']));
return $result;
}
it doesn't work at all.
Do you have an idea of ??the problem.
Thank you for your help.