Прайс-листы большие и не очень с помощью migx + pdoPage
Доброго дня уважаемые!
Давно хотел здесь, что-то нужное и полезное написать, но руки дошли только сейчас, да и тема на мой взгляд актуальная. Ну так вот, стояла задача по организации прайс-листов на сайте медицинского центра, причем не просто вывод, а с поиском и выбором категории на основе csv, то есть все данные должны браться только из csv.
В целом стояли такие задачи:
1. Загрузка csv прайсов через форму в админке
2. Фильтрация по категориям в csv (отдельное поле категория в csv)
3. Поиск по прайсу
4. ajax подгрузка строк
Мое решение:
сниппет getPrice
форма с поиском
Форма с выбором категории
pdoPage
1. убрать ограничения по csv
2. перевести на fenom
Подобного решения на форуме не нашел, может кому и пригодится.
Давно хотел здесь, что-то нужное и полезное написать, но руки дошли только сейчас, да и тема на мой взгляд актуальная. Ну так вот, стояла задача по организации прайс-листов на сайте медицинского центра, причем не просто вывод, а с поиском и выбором категории на основе csv, то есть все данные должны браться только из csv.
В целом стояли такие задачи:
1. Загрузка csv прайсов через форму в админке
2. Фильтрация по категориям в csv (отдельное поле категория в csv)
3. Поиск по прайсу
4. ajax подгрузка строк
Мое решение:
сниппет getPrice
<?php
if($method != 'search') {
$csv = file_get_contents($_SERVER['DOCUMENT_ROOT'].$file);
$array = str_getcsv($csv, "\n");
$json = json_encode($array);
}
$idx = 1;
switch ($method) {
case 'search':
if(!empty($_GET['search'])) {
$out = '{"el1:contains":"'.$_GET['search'].'"}';
}elseif (!empty($_GET['way'])) {
$out = '{"el2":"'.$_GET['way'].'"}';
}
return $out;
break;
case 'options':
foreach ($array as $row) {
$new = explode(';', $row);
if($new[1] != '') $categories[] = $new[1];
$categories = array_unique($categories);
unset($categories[0]);
}
$idx = 1;
foreach ($categories as $item) {
$migx[$idx-1]['MIGX_id'] = $idx;
$migx[$idx-1]['category'] = $item;
$idx++;
}
break;
default:
foreach ($array as $row) {
$new = explode(';', $row);
$migx[$idx-1]['MIGX_id'] = $idx;
$x = 1;
foreach ($new as $a) {
$migx[$idx-1]['el'.$x] = $a;
$x++;
}
$idx++;
}
break;
}
return json_encode($migx);
форма с поиском
<form action="[[~[[*id]]]]" method="GET" class="form-search">
<input type="text" name="search" placeholder="Поиск по прайсу" value="[[!#GET.search]]">
<button type="submit"></button>
<div class="desc">Например, <span class="blue">невролог</span> </div>
</form>
Форма с выбором категории
<form action="[[~[[*id]]]]" class="sorting" method="GET">
<div class="input-group">
<select name="way" id="way">
<option value="">Все направления</option>
[[!getImageList?
&value=`[[getPrice? &file=`[[*pricelist_new]]` &method=`options`]]`
&tpl=`wayOptions.tpl`
&limit=`0`
]]
</select>
</div>
</form>
pdoPage
<div class="table-services table-pricelist" style="border:none" id="pdopage">
<div class="rows">
[[!pdoPage?
&element=`getImageList`
&value=`[[getPrice? &file=`[[*pricelist_new]]`]]`
&limit=`100`
&tpl=`pricelist_new.tpl`
&where=`[[!getPrice? &method=`search`]]`
&ajax=`1`
&ajaxMode=`scroll`
]]
</div>
[[!+page.nav]]
</div>
Сам csv:- разделитель; (точка с запятой)
- кодировка UTF-8
1. убрать ограничения по csv
2. перевести на fenom
Подобного решения на форуме не нашел, может кому и пригодится.