Владимир

Владимир

С нами с 28 декабря 2012; Место в рейтинге пользователей: #53
Сергей Шлоков
03 ноября 2014, 19:41
2
0
Вот еще в дополнение — изменение префикса таблиц. Может пригодится.
<?php
define('MODX_API_MODE', true);
require 'index.php';

// Включаем обработку ошибок
$modx->getService('error','error.modError');
$modx->setLogLevel(modX::LOG_LEVEL_INFO);
// 
$modx->setLogTarget(XPDO_CLI_MODE ? 'ECHO' : 'HTML');
$db = 'your_db_name';
$query = "SHOW TABLES FROM {$db}";
$old_prefix='modx';
$new_prefix='mdx';
$result = $modx->query($query);
$tables = $result->fetchAll(PDO::FETCH_ASSOC);

foreach ($tables as $table) {
	foreach ($table as $tablename) {
		$new_tablename = str_replace($old_prefix,$new_prefix, $tablename);
		$q = "rename table {$tablename} to {$new_tablename}";
		$res = $modx->query($q);
		if ($res) print 'Таблица '.$tablename.' переименование в '.$new_tablename.'\n\r'; else print 'Ошибка переименования'.'\n\r';
	}
}
?>
П.С. Файл должен быть в корне сайта. И не забудь изменить префикс в настройках core/config/config.inc.php
П.П.С. Только надо быть осторожным на рабочем сайте. Нужно проверить работу всех дополнений. Login, например, может глючить.
Богдан
13 октября 2014, 19:20
2
+2
Я так понимаю, цены только в корзине нужно менять? Я сделал такой функционал через плагин. Создаем плагин cartProcessing, вешаем на него события msOnAddToCart, msOnChangeInCart, msOnRemoveFromCart.
Текст плагина:
<?php
switch ($modx->event->name) {
    case 'msOnChangeInCart': case 'msOnAddToCart': case 'msOnRemoveFromCart':
        $miniShop2 = $modx->getService('minishop2','miniShop2',
        	MODX_CORE_PATH . 'components/minishop2/model/minishop2/', $scriptProperties);
        if (!($miniShop2 instanceof miniShop2)) return '';
        
        // Инициализируем класс в текущий контекст
        $miniShop2->initialize($modx->context->key, $scriptProperties);
        $total_count = $miniShop2->cart->status()['total_count'];
        $tmp = $miniShop2->cart->get();
        if ($total_count > 4) { // если 5 и более товаров - оптовые цены, в интернет-магазине оптовые цены забиваются в поле article
            foreach ($tmp as $key1 => $value) {
                if ($product = $modx->getObject('msProduct', $value['id'])) {
                	$realPrice = $product->get('price');
                	$optPrice = $product->get('article'); // вместо article можно указать любое другое поле товара
                	$tmp[$key1]['price'] = $optPrice;
                }
            }
        }
        else {
            foreach ($tmp as $key1 => $value) {
                if ($product = $modx->getObject('msProduct', $value['id'])) {
                	$realPrice = $product->get('price');
                	$tmp[$key1]['price'] = $realPrice;
                }
            }
        }
        $miniShop2->cart->set($tmp);
        break;
}
В данном случае, если в корзине 5 и более товаров будут отображены оптовые цены, меньше 5 шт. — розничные. Оптовые цены будут браться из поля article (можно исправить под любое поле товара).
Николай
13 октября 2014, 17:14
1
+3
К документу цепляем обычный текстовый TV, в котором будет храниться оптовая цена. Назовем ее «opt».
/core/components/minishop2/model/minishop2/mscarthandler.class.php
Ищем там строчку
$price = $product->getPrice();

В функции add
Далее меняем ее на:
global $modx;
$doc = $modx->getObject('modResource',$id);
$opt = $doc->getTVValue('opt');

if ($response['data']['count'] => 100) {
  $price = $opt;
} else {
  $price = $product->getPrice();
}
Далее ищем
public function change($key, $count) {
И немного изменяем ее.
После
$count = $response['data']['count'];
Дописываем код:
global $modx;
$doc = $modx->getObject('modResource',$this->cart[$key]['id']);
$opt = $doc->getTVValue('opt');

if ($response['data']['count'] => 100) {
  $this->cart[$key]['price'] = $opt;
} else {
  $this->cart[$key]['price'] = $product->getPrice();
}
Да грубо, но это работает. Извиняюсь перед Владимиром что возможно лишил его 2 000р. Я подобную задачу решал, и мне не жалко подсказать за бесплатно.
Василий Наумкин
30 сентября 2014, 11:46
2
0
Или не больше 2х LIKE, если не знаешь точного имени:
&where=`{"File.name:LIKE":"%file1%","OR:File.name:LIKE":"%file2%"}`
или сколько угодно в IN, если знаешь:
&where=`{"File.name:IN":["file1.jpg","file2.jpg"]}`

Больше 2х LIKE использовать не получится, потому что иначе ключ массива «OR:File.name:LIKE» в условии будет повторяться и значение в нём — затираться.
Василий Наумкин
30 сентября 2014, 00:05
1
0
Найди 10 отличий с предыдущим примером.
[[!msProducts?
	&parents=`0`
	&innerJoin=`{"msProductFile":{"alias":"File","on":"msProduct.id = File.product_id"}}`
	&groupby=`msProduct.id`
	&where=`{"File.name:LIKE":"%IMG_0049%"}`
]]
Василий Наумкин
29 сентября 2014, 17:59
2
+1
Получится, там же строка с JSON.

Но правильнее, конечно, так:
[[!msProducts?
	&parents=`0`
	&innerJoin=`{"Options":{"class":"msProductOption"}}`
	&groupby=`msProduct.id`
	&where=`{"Options.key":"color","Options.value:IN":["Белый","Белая"]}`
]]
Сергей Шлоков
05 сентября 2014, 13:29
5
0
Если так просто, хотелось бы узнать как. Лично у меня не получилось ни на 2.2 ни на 2.3. — не хочет работать этот friendly_urls_strict.
Поэтому решаю эту задачу одним из способов:
1. Выставляю канонический урл
<link rel="canonical" href="[[~[[*id]]]]? &scheme=`full`]]" />
2. Или добавляю в .htaccess код
# Rewrite domain.com -> domain.com/
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_URI} !\..{1,10}$
RewriteCond %{REQUEST_URI} !(.*)/$
RewriteRule ^(.*)$ http://site.ru/$1/ [L,R=301]
Работает гарантировано.
Василий Наумкин
31 июля 2014, 14:55
1
0
Если он выводит число, то можно так:
$number = $modx->runSnippet('HitsPage', $scriptProperties);
$output = $modx->runSnippet('pdoResources', $scriptProperties);

return str_replace('[[+плейсхолдер]]', $number, $output);
То есть, вручную заменяем нужный плейсхолдер числом от HitsPage.
Василий Наумкин
31 июля 2014, 13:38
1
0
Изменить плагин проще, да?

Вызов:
[[AjaxSnippet?
&snippet=`MySnippetWrapper`
&parents=`.....`
&tpl=`rating-lst` 
&showHidden=`0` 
&includeTVs=`LikeDislike` 
&tvPrefix=``
&sortbyTVType=`integer`
&sortbyTV=`LikeDislike`
&limit=`5`
&as_mode=`onload`
]]

Сниппет MySnippetWrapper:
<?php
$modx->runSnippet('HitsPage', $scriptProperties);

return $modx->runSnippet('pdoResources', $scriptProperties)

HitsPage я в глаза не видел, но по идее он должен выставить плейсхолдеры которые уже отработают в чанках pdoResources. Таким образом можно готовить информацию на вывод как угодно в своем сниппете.
Василий Наумкин
04 июля 2014, 14:34
1
+1
&where=`["Любое условие на чистом SQL"]`

Наверное, нужно использовать CAST(), а может и так заработает:
&where=`["TVproperty_price.value >= 10000000"]`