} $p = explode(',', $lim); if (sizeof($p) != 2) { return Ans::err($ans, 'Is wrong paramter lim'); } $start = (int) $p[0]; $count = (int) $p[1]; $args = array($start, $count); $list = Catalog::cache('producers.php', function ($start, $count) { $ans = array(); $data = Catalog::init(); $prods = array(); Xlsx::runPoss($data, function &(&$pos) use(&$prods) { if (empty($prods[$pos['producer']])) { $prods[$pos['producer']] = 0; } $prods[$pos['producer']]++; $r = null; return $r; }); arsort($prods, SORT_NUMERIC); $prods = array_slice($prods, $start, $count); return $prods; }, $args, isset($_GET['re'])); $ans['menu'] = Load::loadJSON('-catalog/menu.json'); $ans['list'] = $list; $conf = Catalog::$conf; $ans['breadcrumbs'][] = array('main' => true, 'href' => '', 'title' => 'Главная', 'add' => 'group'); $ans['breadcrumbs'][] = array('href' => '', 'title' => $conf['title'], 'add' => 'group'); $ans['breadcrumbs'][] = array('active' => true, 'href' => 'producers', 'title' => 'Производители'); return Ans::ret($ans);
public static function init() { $data = Catalog::init(); Xlsx::runGroups($data, function (&$group, $i, &$parent) { $group['data'] = array_filter($group['data'], function (&$pos) { //Убираем позиции у которых не указана цена //if($pos['Синхронизация']!='Да')return false; if (!$pos['Цена']) { return false; } $pos['Цена'] = preg_replace('/\\s/', '', $pos['Цена']); if (!$pos['Цена']) { return false; } if (strtolower($pos['Маркет']) == 'да') { $pos['Описание'] = strip_tags($pos['Описание']); $pos['Описание'] = preg_replace('/ /', ' ', $pos['Описание']); return true; } }); $group['data'] = array_values($group['data']); }); Xlsx::runGroups($data, function (&$group, $i, &$parent) { if ($group['childs']) { $group['childs'] = array_filter($group['childs'], function (&$g) { if (!$g['data'] && !$g['childs']) { return false; } return true; }); $group['childs'] = array_values($group['childs']); } }, array(), true); Xlsx::runPoss($data, function (&$pos) { $conf = Catalog::$conf; Xlsx::addFiles($conf['dir'], $pos, array('Производитель', 'article')); foreach ($pos['images'] as $k => $v) { $src = $pos['images'][$k]; $p = explode('/', $src); foreach ($p as $i => $n) { $p[$i] = urlencode($n); $p[$i] = preg_replace('/\\+/', '%20', $p[$i]); } $pos['images'][$k] = implode('/', $p); } }); return static::parse($data); }
use infrajs\config\Config; //Nostoer::on(); $orig_val = Path::toutf(strip_tags($_GET['val'])); $orig_art = Path::toutf(strip_tags($_GET['art'])); $val = mb_strtolower($orig_val); $art = mb_strtolower($orig_art); $args = array($val, $art); $ans = array(); $pos = Catalog::cache('position', function ($val, $art) { $data = Catalog::init(); // список всей продукции return Xlsx::runPoss($data, function &(&$pos, $i, &$group) use(&$val, &$art) { $r = null; if (mb_strtolower($pos['producer']) !== $val) { return $r; } if (mb_strtolower($pos['article']) !== $art) { return $r; } return $pos; }); }, $args, isset($_GET['re'])); if (isset($_GET['seo'])) { if (!$pos) { return Ans::err($ans, 'Position not found'); } $link = $_GET['seo']; $link = $link . '/' . urlencode($pos['producer']) . '/' . urlencode($pos['article']); $ans['external'] = '-catalog/seo.json'; $ans['title'] = $pos['Производитель'] . ' ' . $pos['Артикул']; if (!empty($pos['Наименование'])) { $ans['title'] = $pos['Наименование'] . ' ' . $ans['title'];
public static function &get($src) { $data = xls_make($src); xls_processDescr($data); xls_processPoss($data); Xlsx::runGroups($data, function &(&$gr) { unset($gr['parent']); $r = null; return $r; }); Xlsx::runPoss($data, function &(&$pos) { unset($pos['parent']); $r = null; return $r; }); return $data; }
public static function getPoss($mdgroup) { if ($mdgroup) { foreach ($mdgroup as $group => $v) { break; } } else { $group = false; } return Catalog::cache('getPoss', function &($group) { $data = Catalog::init(); if ($group) { $data = Xlsx::runGroups($data, function &($gr) use($group) { if ($gr['title'] == $group) { return $gr; } $r = null; return $r; }); } $poss = array(); Xlsx::runPoss($data, function &(&$pos) use(&$poss) { $poss[] =& $pos; $r = null; return $r; }); return $poss; }, array($group)); }