Прайс-листы большие и не очень с помощью migx + pdoPage

Доброго дня уважаемые!
Давно хотел здесь, что-то нужное и полезное написать, но руки дошли только сейчас, да и тема на мой взгляд актуальная. Ну так вот, стояла задача по организации прайс-листов на сайте медицинского центра, причем не просто вывод, а с поиском и выбором категории на основе 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

Подобного решения на форуме не нашел, может кому и пригодится.
Andrey Frost
29 декабря 2017, 04:51
modx.pro
2
1 089
+1

Комментарии: 0

Авторизуйтесь или зарегистрируйтесь, чтобы оставлять комментарии.
0