Новости Joomla

0 Пользователей и 1 Гость просматривают эту тему.
  • 3 Ответов
  • 496 Просмотров
*

DenVeR777

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Иногда бывает необходимо поменять цены на все товары, на группы или категории товаров, чтобы запустить акцию.
Вроде все просто, фильтруем, выбираем нужные, нажимаем изменить, умножаем цены на 1-скидка, ставим "Использовать старое значение цены"... И все вроде бы классно, нам удалось сделать скидку на тысячу товаров! НО в атрибутах старая цена не поменялась  !
Когда товаров немного это не проблема, взяли поправили ручками(если помните старые цены) и все готово, а вот когда их несколько тысяч...*suicide*

Решение(актуально для JS 4.17.0):
в файле /administrator/components/com_jshopping/models/products.php в районе 943 строки находим следующий код:
Код
        if ($post['product_old_price']!=""){
                $price = saveAsPrice($post['product_old_price']);
                if ($post['mod_old_price']=='%')
                    $_adv_query[] = " `old_price`=`old_price` * '".$price."' / 100 ";
                elseif($post['mod_old_price']=='=')
                    $_adv_query[] = " `old_price`= '".$price."' ";
                else
                    $_adv_query[] = " `old_price`=`old_price` ".$post['mod_old_price']." '".$price."' ";
        }
меняем его на
Код
        if ($post['product_old_price']!=""){
            if ($post['use_old_val_price']!=1){
                $price = saveAsPrice($post['product_old_price']);
                if ($post['mod_old_price']=='%')
                    $_adv_query[] = " `old_price`=`old_price` * '".$price."' / 100 ";
                elseif($post['mod_old_price']=='=')
                    $_adv_query[] = " `old_price`= '".$price."' ";
                else
                    $_adv_query[] = " `old_price`=`old_price` ".$post['mod_old_price']." '".$price."' ";
            }
        }

Далее в этом же файле находим в районе 1015 строки:
Код
if ($post['use_old_val_price']==1){
   $product->set('product_old_price', $oldprice);
}
заменяем на
Код
if ($post['use_old_val_price']==1){
   $db = JFactory::getDBO();
   $product->set('product_old_price', $oldprice);
   $query = "update `#__jshopping_products_attr` SET `old_price`=`price` where product_id='".$db->escape($id)."'";
   $db->setQuery($query);
   $db->query();
}

Немного грязно, но работать будет - проверено  ;)

А теперь вопрос к знатокам:
Я не исключаю, что я туповат *ОХ-Х-Х* и просто не увидел какую-то галочку в интерфейсе. Пожалуйста сообщите об этом. А если нет, то куда написать? После обновления все эти хаки слетят к чертям(
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
просто не увидел какую-то галочку в интерфейсе
ее нет.

После обновления все эти хаки слетят к чертям
чтоб не слетели, нужно это сделать плагином. либо есть готовый https://nevigen.com/ru/addons/massovoe-izmenenie-tsen-dlya-atributov-tovarov-v-joomshopping.html
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

DenVeR777

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Спасибо!
А я не смог ничего найти по проблеме, мне быстрее и дешевле было плагин купить, чем разбираться с кодом JS))
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну свою задачу то вы уже решили, вам уже по всей видимости он и не нужен :) но вообще плагин более универсальный, поскольку например старая цена для разных атрибутов может отличаться суммой, т.е. для одного атрибута это может быть +100 руб, а для другого +150, и т.п., а у вас всегда одна и та же разница добавляется. ну и как вы уже правильно заметили, хаки придется править при каждом обновлении...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться