core/api/modules/tovar_cat/index.php

138 lines
5.8 KiB
PHP
Raw Normal View History

2022-12-11 13:55:49 +05:00
<?php
ini_set('display_errors', 0 );
2023-07-12 20:02:20 +05:00
// \DB::set("ALTER TABLE `tovar_category` ADD `hide` int(1) NULL DEFAULT '0'");
$smarty -> caching = false;
2023-01-07 18:55:55 +05:00
$smarty -> cache_lifetime = 2592000;// 86400 - сутки, 2592000 - месяц
2023-07-12 20:02:20 +05:00
2023-01-07 18:55:55 +05:00
function delhtml ($text) { // ФУНКЦИЯ очистки кода
$old1 = array(".html");#Ищем вредное ">",, "<"
$new1 = array("");#Меняем на полезное"&gt;", , "&lt;"
$text = str_replace($old1, $new1, $text);#Собсно сама замена =)
return $text;
}
2022-12-11 13:55:49 +05:00
2023-07-12 20:02:20 +05:00
//Антипоисковик
if ( \core::findtxt($_GET['id'], 'html' )==0) header('HTTP/1.0 404 not found');
2023-04-09 19:52:26 +05:00
2023-01-07 18:55:55 +05:00
$period=delhtml($_GET['id']);
$pieces = explode("-",$period);
$pieces[0] = ( $pieces[0] ) ? $pieces[0] : 0; //категория
$page = ( $pieces[1] ) ? $pieces[1] : 0; // текущая страница
2023-01-02 21:33:36 +05:00
2023-07-12 20:02:20 +05:00
/* ----------------------------------------------------------------------
10.06.2023
АВТОСОРТИРОВЩИК
---------------------------------------------------------------------- */
$autosort=\DB::getAll("SELECT * FROM `tovar_category_filter` WHERE `tovar_category`=? AND `partner`<>'diznet'", $pieces[0]);
for ($i=0; $i<count($autosort); $i++){
\DB::set("UPDATE `tovar` SET `category`=? WHERE `title` LIKE ?", array($pieces[0], $autosort[$i]['txt']));
}
2023-01-07 18:55:55 +05:00
$categoryInfo=\DB::getAll("SELECT * FROM `tovar_category` WHERE `id`=? LIMIT 1", $pieces[0]);
$smarty->assign('page_info', $categoryInfo);//получаем инфо о категории
2023-01-24 15:51:26 +05:00
2023-07-12 20:02:20 +05:00
$childrenCategory=\DB::getAll("SELECT `id`, `title` FROM `tovar_category` WHERE `status` = 1 AND `category` = ? ORDER BY `title`", $pieces[0] );
2023-02-25 22:58:56 +05:00
//Если нет дочерних категорий, берем текущие....
2023-01-24 15:51:26 +05:00
if (!$childrenCategory){
2023-07-12 20:02:20 +05:00
$childrenCategory=\DB::getAll("SELECT `id`, `title` FROM `tovar_category` WHERE `status` = 1 AND `category` = ? ORDER BY `title`", $categoryInfo[0]['category'] );
2023-01-24 15:51:26 +05:00
}
2023-02-25 22:58:56 +05:00
/* ----------------------------------------------------------------------
24.02.2023
Выводим изображения категорий
---------------------------------------------------------------------- */
2023-07-12 20:02:20 +05:00
/*
2023-02-25 22:58:56 +05:00
for ($i=0; $i<count($childrenCategory); $i++){
//Смотрим на всякий случай картинки в таблице tovar_category и переносим в tovar_category_img
// Убрать в конце 2023 года!!!
$obl_img=\DB::getValue("SELECT `img` FROM `tovar_category` WHERE `id`=? LIMIT 1", $childrenCategory[$i]['id']);
if ($obl_img){
$md5=md5_file('img/' . $_SERVER['SERVER_NAME'] . '/tovar_cat/' . $obl_img . '.jpg');
$insert_id = \DB::add ( "INSERT INTO `tovar_category_img` (`filename`, `tovar_category_id`, `md5`) VALUES (?, ?, ?)", array(
$obl_img, $childrenCategory[$i]['id'], $md5
) );
\DB::set("UPDATE `tovar_category` SET `img`=? WHERE `id`=? LIMIT 1", array("", $childrenCategory[$i]['id']) );
unset($obl_img);
unset($md5);
}
//А это не убирать!
$childrenCategory[$i]['img']=\DB::getValue("SELECT `filename` FROM `tovar_category_img` WHERE `tovar_category_id`=? LIMIT 1", $childrenCategory[$i]['id']);
}
2023-07-12 20:02:20 +05:00
*/
2023-02-25 22:58:56 +05:00
2023-01-24 15:51:26 +05:00
2023-01-07 18:55:55 +05:00
$smarty->assign('list', $childrenCategory);//получаем дочерние категории
2023-01-02 21:33:36 +05:00
2023-01-07 18:55:55 +05:00
/* ----------------------------------------------------------------------
19.09.2022
2023-03-05 20:22:21 +05:00
Узнаем обложку раздела - переделано в слайдер
2023-01-07 18:55:55 +05:00
---------------------------------------------------------------------- */
2023-01-02 21:33:36 +05:00
2023-07-12 20:02:20 +05:00
$kol = 24; //количество записей для вывода
2023-02-25 22:58:56 +05:00
$art=($page>0)? ($page * $kol) - $kol : 0;// определяем, с какой записи нам выводить
2023-07-12 20:02:20 +05:00
$total = \DB::getValue ( "SELECT COUNT(*) FROM `tovar` WHERE `category` = ? AND `status`=1", $pieces[0] );
2023-01-07 18:55:55 +05:00
$str_pag = ceil($total / $kol);
2023-02-25 22:58:56 +05:00
2023-07-12 20:02:20 +05:00
$childrenTovar=\DB::getAll("SELECT `id`, `title`, `linkimg`, `cena` FROM `tovar` WHERE `category` = ? AND `status`=1 ORDER BY `title` LIMIT $art, $kol", $pieces[0]);
2023-02-25 22:58:56 +05:00
2023-01-02 21:33:36 +05:00
for ($i=0; $i<count($childrenTovar); $i++){
2023-02-25 22:58:56 +05:00
//А это не убирать!
2023-07-12 20:02:20 +05:00
//$childrenTovar[$i]['cena']=\DB::getValue("SELECT `cena` FROM `tovar_price_history` WHERE `tovar_id`=? ORDER BY `t` DESC LIMIT 1", $childrenTovar[$i]['id']);
2023-04-09 19:52:26 +05:00
$childrenTovar[$i]['img']=\DB::getValue("SELECT `filename` FROM `tovar_img` WHERE `tovar_id`=? LIMIT 1", $childrenTovar[$i]['id']);
2023-07-12 20:02:20 +05:00
if (!$childrenTovar[$i]['img'])$childrenTovar[$i]['img']=$childrenTovar[$i]['linkimg'];
else
$childrenTovar[$i]['img']="/img/" . $_SERVER['SERVER_NAME'] . "/tovar/" . $childrenTovar[$i]['img'] . ".jpg";
2023-01-02 21:33:36 +05:00
}
2022-12-17 18:15:09 +05:00
2023-02-25 22:58:56 +05:00
2022-12-17 18:15:09 +05:00
$smarty->assign('list2', $childrenTovar);//получаем дочерние категории
2022-12-11 13:55:49 +05:00
/* ----------------------------------------------------------------------
2023-01-07 18:55:55 +05:00
03.01.2023
Хлебные крошки
2022-12-11 13:55:49 +05:00
---------------------------------------------------------------------- */
2022-12-17 18:15:09 +05:00
2023-01-07 18:55:55 +05:00
$smarty->assign('Breadcrumb', \core::getBreadcrumb( 'tovar_category', $categoryInfo[0]['category'] ) );
2023-01-02 21:33:36 +05:00
/* ----------------------------------------------------------------------
2023-01-07 18:55:55 +05:00
03.01.2023
Пагинатор
2023-01-02 21:33:36 +05:00
---------------------------------------------------------------------- */
2023-01-07 18:55:55 +05:00
$paginator='<nav aria-label="123" style="margin-top: 40px; margin-bottom: 40px;"><ul class="pagination">';
for ($i = 1; $i <= $str_pag; $i++){
if ($i==$page)
$paginator.= "<li class='page-item text-center'><a href='/tovar_cat/" . $pieces[0] . "-" .$i.".html' class='page-link'><b>".$i."</b></a></li>";
else
$paginator.= "<li class='page-item text-center'><a href='/tovar_cat/" . $pieces[0] . "-" .$i.".html' class='page-link'>".$i." </a></li>";
}
$paginator.='</ul></nav>';
$smarty->assign('paginator', $paginator);
2023-02-25 22:58:56 +05:00
?>