Последние темы


удалить товар из корзины shopkeeper по id

  • Всем привет. Не подскажите как удалить товар из корзины shopkeeper по id, а не порядковому номеру

  • Если JS то так:

    SHK.deleteItem({id: 12});
    

    12 - ID товара

  • Странно, но у меня удаляет полностью всю корзину, shopkeeper 2

  • Странно, но у меня удаляет полностью всю корзину, shopkeeper 2

    Ничего странного не вижу. Я писал про SHK 3.

  • Такой возможности в , shopkeeper 2 нет.... но можно ее добавить 🙂

    //Чтобы обращаться к элементам корзины в Шопкипер 2, необходимо в класс shopkeeper.class.php добавить методы:
    //Тут я учел что в корзине может быть несколько объектов с одинаковым айдишником но разными ценами, параметрами и так далее, поэтому сразу решаем универсальную задачу - даем не идентификатор, а объект, он по корзине ищет этот объект, получает его индекс в корзине, ну и далее работа проходит как обычно
    
    
    public function isFiltred($object, $element)//Фильтрация объекта
    {
        $flag=true;
        foreach ($object as $fieldname=>$fieldval)
        {
                if (is_array($fieldval))
                {
                    if (!$this->isFiltred($fieldval, $element[$fieldname])){return false;}
                }else
                {
                    if ($element[$fieldname]!=$fieldval){$flag=false;}
                }
        }
        return $flag;
    }
    public function getCartIndex($object)//Поиск объекта удовлетворяющего фильтру
    {
       $index=0;
       $i=0;
       foreach ($_SESSION['shk_purchases'] as $cartitem) {
                if ($this->isFiltred($object, $cartitem)){$index=$i;}
                $i++;
        } 
        return $index;
    }
    public function recountDataArrayObject($object,$count,$plus=true)//Основной метод, пересчет, но обращение не по индексу а по объекту
    {
        $index=$this->getCartIndex($object);
        if($count<=0) return;
        else $count = $this->cleanCount($count);
        $curSavedP = $_SESSION['shk_purchases'];
        $curSavedP[$index]['count'] = $plus==true ? $curSavedP[$index]['count']+$count : $count;
        $_SESSION['shk_purchases'] = $curSavedP;
    }
    public function recountDataArrayObjectPlus($object)
    {
        $index=$this->getCartIndex($object);
        $curSavedP = $_SESSION['shk_purchases'];
        $curSavedP[$index]['count']++;
        $_SESSION['shk_purchases'] = $curSavedP;
    }
    public function recountDataArrayObjectMinus($object)
    {
        $index=$this->getCartIndex($object);
        $curSavedP = $_SESSION['shk_purchases'];
        $curSavedP[$index]['count']--;
        if ($curSavedP[$index]['count']>0)
        {
            $_SESSION['shk_purchases'] = $curSavedP;
        }
    }
    
    
    
    //Чтобы тестить полученные штуки, предлагаю временно в файлк ajax-action.php внести такое изменение:
    $request = $_POST; заменить на $request = $_REQUEST; это чисто для удобства чтобы хавать как GET так и POST запросы
    //ну а теперь в этом же файлике, где стоит свич по действиям добавляем свои действия:
    
    case "recountobject":
                $shopCart->recountDataArrayObject(json_decode($request['object']),$request['count'],false);
            break;
            case "plusobject":
                $shopCart->recountDataArrayObjectPlus(json_decode($request['object']));
            break;
            case "minusobject":
                $shopCart->recountDataArrayObjectMinus(json_decode($request['object']));
            break;
    
    
    
    //Как работать: 
    
    //объекту 41 изменили количество на 7
    http://site.ru/assets/components/shopkeeper/connector_fe.php?action=recountobject&count=7&object={"id":41}}
    
    //а теперь представим, что у нас есть два объекта с одинаковым айдишником в корзине, но с разными атрибутами
    http://site.ru/assets/components/shopkeeper/connector_fe.php?action=recountobject&count=7&object={"id":42,"tv_add":{"dopps":"big"}}
    - задали значение позиции с айдишником 42, у которой есть дополнительное поле dopps со значением big (ну например пицца большая/маленькая)
    
    //Так же можно поступить формируя объект поиска любой сложности по разным полям. например найти товар с такой то ценой и ему задать какое то количество:
    http://site.ru/assets/components/shopkeeper/connector_fe.php?action=recountobject&count=7&object={"price":100}
    
 

Последние комментарии

  • @Andchir Чета не додумался. Спасибо огромное, завелось.

    Читать далее
  • Потому что в этой функции нет объекта $modx. Можно попробовать добавить такую строчку вверху функции (внутри):

    global $modx;

    Читать далее
  • Добрый день.
    Задача: Есть таблица где записываются id данных из других созданных таблиц.
    Нужно в функции filter_export и filter_import объединить данные из разных таблиц.

    Как я пробывал решить свою задачку:

    function filter_export($value_arr,$doc_id=0) { //var_dump($output_arr); //exit; $output_arr = $value_arr; if(isset($output_arr['execution'])) { $ids = $output_arr['execution']; $result = $modx->query("SELECT * FROM LKp3KJ_my_execution WHERE id = $ids"); $row = $result->fetch(PDO::FETCH_ASSOC); $output_arr['execution'] = $row[title]; } /* if(isset($output_arr['price'])) $output_arr[1] = floatval($output_arr[1]) - 200; */ return $output_arr; }

    В ответ получаю 500 ошибку на странице импорт/экспорт.

    Читать далее
  • Спасибо за содействие! Приношу извинения за неудобства.

    Читать далее