![Pandemic](/assets/images/avatars//393e4ceb7ef7717d6a0f828d6c3ce357-64.jpg?t=1739910393)
Pandemic
С нами с 22 ноября 2023; Место в рейтинге пользователей: #857Как автоматом указать характеристики только те что есть в товарах для категории?
Как в категории указать все характеристики что используются в товарах этой категории? в minishop2
[РЕШЕНО]
Суть в том чтобы в админке появились только те характеристики у товара которые есть, это значит поставить все уникальные характеристики для категории, нужно было именно такое решение, сделал сам. А если не нужно их указывать в админке для редактирования, то да проще будет вывести их список через pdoResources указав класс msCategoryOption
Буду рад кто исправит это код(КОД РАБОЧИЙ), чтобы был чище, так как делался на быструю руку решить задачу, а так же не было знаний для реализации этой задачи.
[РЕШЕНО]
Суть в том чтобы в админке появились только те характеристики у товара которые есть, это значит поставить все уникальные характеристики для категории, нужно было именно такое решение, сделал сам. А если не нужно их указывать в админке для редактирования, то да проще будет вывести их список через pdoResources указав класс msCategoryOption
Буду рад кто исправит это код(КОД РАБОЧИЙ), чтобы был чище, так как делался на быструю руку решить задачу, а так же не было знаний для реализации этой задачи.
<?php
function prepareSqlQuery($sqlQuery){
global $modx;
return $modx->query($sqlQuery);
}
function extractResultsFromQueryObject($sqlQueryResult, $itemsToRetreive, $multiDimensionRetreive=false){
global $modx;
$results = array();
if (is_object($sqlQueryResult)) {
while ($row = $sqlQueryResult->fetch(PDO::FETCH_ASSOC)) {
if($multiDimensionRetreive){
foreach($itemsToRetreive as $key => $value){
array_push($results, $row[$key], $row[$value]);
}
} else {
foreach($itemsToRetreive as $itemToRetreive){
array_push($results, $row[$itemToRetreive]);
}
}
}
}
return $results;
}
$prepareSqlQueryOfRetreiveCategories = prepareSqlQuery('SELECT modx_site_content.id FROM `modx_site_content` WHERE modx_site_content.class_key = "msCategory"');
$categoriesIds = extractResultsFromQueryObject($prepareSqlQueryOfRetreiveCategories, array('id'));
if(count($categoriesIds) <= 0){
return 'Have no categories';
}
foreach($categoriesIds as $categoryId){
$productsQueryObject = prepareSqlQuery('SELECT modx_site_content.id FROM `modx_site_content` WHERE modx_site_content.class_key = "msProduct" AND modx_site_content.parent = "'.$categoryId.'"');
$productsIds = extractResultsFromQueryObject($productsQueryObject, array('id'));
if(count($productsIds) <= 0) continue;
$productsIds = implode(",", $productsIds);
$distinctProductOptionsSqlQuery = prepareSqlQuery('SELECT DISTINCT modx_ms2_product_options.key FROM `modx_ms2_product_options` WHERE modx_ms2_product_options.product_id IN ('.$productsIds.")");
$distinctProductOptions = extractResultsFromQueryObject($distinctProductOptionsSqlQuery, array('key'));
if(count($distinctProductOptions) <= 0) continue;
$uniqueOptions = "";
$uniqueOptionsLength = count($distinctProductOptions);
foreach ($distinctProductOptions as $idx => $value) {
if($idx >= $uniqueOptionsLength - 1){
$uniqueOptions .= "'$value'";
} else{
$uniqueOptions .= "'$value',";
}
}
$uniqueOptionsIdsSqlQuery = prepareSqlQuery('SELECT modx_ms2_options.id,modx_ms2_options.key FROM `modx_ms2_options` WHERE modx_ms2_options.key IN ('.$uniqueOptions.')');
$uniqueOptionsIds = extractResultsFromQueryObject($uniqueOptionsIdsSqlQuery, array('id'));
if(count($uniqueOptionsIds) <= 0) continue;
/* #################################### ##################################### */
foreach($uniqueOptionsIds as $idx => $uniqueOptionId){
if (!$cop = $modx->getObject('msCategoryOption', array('option_id' => $uniqueOptionId, 'category_id' => $categoryId))) {
$table = $modx->getTableName('msCategoryOption');
$sql = "INSERT INTO {$table} (`option_id`,`category_id`,`active`) VALUES ({$uniqueOptionId}, {$categoryId}, 1);";
$stmt = $modx->prepare($sql);
$stmt->execute();
} else {
$q = $modx->newQuery('msCategoryOption');
$q->command('UPDATE');
$q->where(array('option_id' => $uniqueOptionId, 'category_id' => $categoryId));
$q->set(array('active' => 1));
$q->prepare();
$q->stmt->execute();
}
}
/* #################################### ##################################### */
echo 'Done';
}
При выводе 2 блоков xlike, при клике на лайк или дизлайк, изменяется оба значения на кликнутое, как исправить?
Я вывел 2 раза так как по дизайну у меня есть 4 оценочных блока, выводил так.
{'!xLike' | snippet : [
'guest' => true,
'mode' => 'db',
'tpl' => 'tpl.xLike',
'likes' => $_modx->resource['greatNews'],
'dislikes' => $_modx->resource['goodNews']
]}
{'!xLike' | snippet : [
'guest' => true,
'mode' => 'db',
'tpl' => 'tpl.xLike',
'likes' => $_modx->resource['notReallyNews'],
'dislikes' => $_modx->resource['whatIsAboutThisNews']
]}
Кликаю на дизлайк в 1 блоке, всё отображается правильно, но при перезагрузке оба значения лайков или дизлайков становятся одинаковыми, хотя кликал на 1 Настройка конфигурации NGINX + PHP-FPM 7.4 на Ubuntu 22.04 + Fastpanel для MODX 2.8.7
Добрый день.
Поднимаю сервер VDS для MODX 2.8.5. Ubuntu 22.04 + Fastpanel. Связка NGINX + PHP-FPM 7.4. Cертификат Let's Encrypt Wildcard создан через панель. Стандартную настройку конфигов сделал такую (настройки сохраняются в разделе «Ручная настройка» в панели управления. Учтите, что при ручных настройках панель начнет вас предупреждать о попытке поменять стандартные настройки и будет просить ввести код подтверждения, если вы это сделаете — то ручные настройки затрутся и придётся настраивать заново).
Поднимаю сервер VDS для MODX 2.8.5. Ubuntu 22.04 + Fastpanel. Связка NGINX + PHP-FPM 7.4. Cертификат Let's Encrypt Wildcard создан через панель. Стандартную настройку конфигов сделал такую (настройки сохраняются в разделе «Ручная настройка» в панели управления. Учтите, что при ручных настройках панель начнет вас предупреждать о попытке поменять стандартные настройки и будет просить ввести код подтверждения, если вы это сделаете — то ручные настройки затрутся и придётся настраивать заново).
Как добавить выполнение моего снипета в очередь чтобы не мешать основной работе?
Есть скрипт что отправляет уведомление в ватсап, оно занимает время, хочу поставить его в очередь но не могу понять как, подскажите пожалуйста как это сделать?
[miniShop2] Добавляем свои поля в заказ в админке
Бывает необходимость расширить таблицу заказов miniShop2. Можно легко это сделать с помощью несложных действий.
mSearch2 - сортировка кастомным select 'ом
Возникла необходимость кастомизировать стандартную сортировку компонента mSearch2.
Cортировка имела следующий вид:![](https://modx.pro/assets/images/tickets/13306/8cb9b70f4c41322f0deda5aa1a270cd299d67ac2.png)
Как оказалось компонент не может работать с select, а работает только тегом a. Ну да ладно, попробуем исправить это.
На сайте modx.pro в ветке Вопросы нашел вопрос Как сделать сортировку через select? от пользователя DimenSi. Вопрос частично решен если бы не одно НО
Cортировка имела следующий вид:
![](https://modx.pro/assets/images/tickets/13306/8cb9b70f4c41322f0deda5aa1a270cd299d67ac2.png)
Как оказалось компонент не может работать с select, а работает только тегом a. Ну да ладно, попробуем исправить это.
На сайте modx.pro в ветке Вопросы нашел вопрос Как сделать сортировку через select? от пользователя DimenSi. Вопрос частично решен если бы не одно НО
перестали работать фильтры, фильтрация срабатывает только после сортировки. Т.е. меняешь ценовой диапазон → ничего, после этого меняешь сортировку → срабатывает и сортировка и фильтр.
ПЛАН РАБОТЫ
- Установка кастомного селеста
- Написание скрипта для взаимодействия сортировки с компонентом