Exemple #1
0
}
$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);
Exemple #2
0
 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);
 }
Exemple #3
0
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'];
Exemple #4
0
 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;
 }
Exemple #5
0
 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));
 }