Files
AtomicOld/api/ArticlesCategories.php

208 lines
7.5 KiB
PHP
Raw Permalink Normal View History

2026-02-14 19:34:54 +03:00
<?php
/**
* Simpla CMS
*
* @copyright 2014 Vitaly Raevsky
* @link http://bwdesign.ru
* @email vitaly.raevsky@gmail.com
*
*/
require_once('Simpla.php');
class ArticlesCategories extends Simpla
{
// Список указателей на категории в дереве категорий (ключ = id категории)
private $all_articles_categories;
// Дерево категорий
private $articles_categories_tree;
// Функция возвращает массив категорий
public function get_articles_categories($filter = array())
{
if(!isset($this->articles_categories_tree))
$this->init_articles_categories();
return $this->all_articles_categories;
}
// Функция возвращает дерево категорий
public function get_articles_categories_tree()
{
if(!isset($this->articles_categories_tree))
$this->init_articles_categories();
return $this->articles_categories_tree;
}
// Функция возвращает заданную категорию
public function get_articles_category($id)
{
if(!isset($this->all_articles_categories))
$this->init_articles_categories();
if(is_int($id) && array_key_exists(intval($id), $this->all_articles_categories))
return $category = $this->all_articles_categories[intval($id)];
elseif(is_string($id))
foreach ($this->all_articles_categories as $category)
if ($category->url == $id)
return $this->get_articles_category((int)$category->id);
return false;
}
// Добавление категории
public function add_articles_category($category)
{
$category = (array)$category;
if(empty($category['url']))
{
$category['url'] = preg_replace("/[\s]+/ui", '_', $category['name']);
$category['url'] = strtolower(preg_replace("/[^0-9a-zа-я_]+/ui", '', $category['url']));
}
// Если есть категория с таким URL, добавляем к нему число
while($this->get_articles_category((string)$category['url']))
{
if(preg_match('/(.+)_([0-9]+)$/', $category['url'], $parts))
$category['url'] = $parts[1].'_'.($parts[2]+1);
else
$category['url'] = $category['url'].'_2';
}
$this->db->query("INSERT INTO __articles_categories SET ?%", $category);
$id = $this->db->insert_id();
$this->db->query("UPDATE __articles_categories SET position=id WHERE id=?", $id);
$this->init_articles_categories();
return $id;
}
// Изменение категории
public function update_articles_category($id, $category)
{
$query = $this->db->placehold("UPDATE __articles_categories SET ?% WHERE id=? LIMIT 1", $category, intval($id));
$this->db->query($query);
$this->init_articles_categories();
return $id;
}
// Удаление категории
public function delete_articles_category($id)
{
if(!$category = $this->get_articles_category(intval($id)))
return false;
foreach($category->children as $id)
{
if(!empty($id))
{
$this->delete_image($id);
$query = $this->db->placehold("DELETE FROM __articles_categories WHERE id=? LIMIT 1", $id);
$this->db->query($query);
$query = $this->db->placehold("DELETE FROM __products_articles_categories WHERE category_id=?", $id);
$this->db->query($query);
$this->init_articles_categories();
}
}
return true;
}
// Удалить изображение категории
public function delete_image($category_id)
{
$query = $this->db->placehold("SELECT image FROM __article_categories WHERE id=?", $category_id);
$this->db->query($query);
$filename = $this->db->result('image');
if(!empty($filename))
{
$query = $this->db->placehold("UPDATE __article_categories SET image=NULL WHERE id=?", $category_id);
$this->db->query($query);
$query = $this->db->placehold("SELECT count(*) as count FROM __article_categories WHERE image=? LIMIT 1", $filename);
$this->db->query($query);
$count = $this->db->result('count');
if($count == 0)
{
@unlink($this->config->root_dir.$this->config->categories_images_dir.$filename);
}
$this->init_articles_categories();
}
}
// Инициализация категорий, после которой категории будем выбирать из локальной переменной
private function init_articles_categories()
{
// Дерево категорий
$tree = new stdClass();
$tree->subcategories = array();
// Указатели на узлы дерева
$pointers = array();
$pointers[0] = &$tree;
$pointers[0]->path = array();
// Выбираем все категории
$query = $this->db->placehold("SELECT c.id, c.parent_id, c.name, c.description, c.url, c.meta_title, c.meta_keywords, c.meta_description, c.image, c.visible, c.position
FROM __articles_categories c ORDER BY c.parent_id, c.position");
// Выбор категорий с подсчетом количества товаров для каждой. Может тормозить при большом количестве товаров.
// $query = $this->db->placehold("SELECT c.id, c.parent_id, c.name, c.description, c.url, c.meta_title, c.meta_keywords, c.meta_description, c.image, c.visible, c.position, COUNT(p.id) as products_count
// FROM __articles_categories c LEFT JOIN __products_categories pc ON pc.category_id=c.id LEFT JOIN __products p ON p.id=pc.product_id AND p.visible GROUP BY c.id ORDER BY c.parent_id, c.position");
$this->db->query($query);
$articles_categories = $this->db->results();
$finish = false;
// Не кончаем, пока не кончатся категории, или пока ниодну из оставшихся некуда приткнуть
while(!empty($articles_categories) && !$finish)
{
$flag = false;
// Проходим все выбранные категории
foreach($articles_categories as $k=>$category)
{
if(isset($pointers[$category->parent_id]))
{
// В дерево категорий (через указатель) добавляем текущую категорию
$pointers[$category->id] = $pointers[$category->parent_id]->subcategories[] = $category;
// Путь к текущей категории
$curr = $pointers[$category->id];
$pointers[$category->id]->path = array_merge((array)$pointers[$category->parent_id]->path, array($curr));
// Убираем использованную категорию из массива категорий
unset($articles_categories[$k]);
$flag = true;
}
}
if(!$flag) $finish = true;
}
// Для каждой категории id всех ее деток узнаем
$ids = array_reverse(array_keys($pointers));
foreach($ids as $id)
{
if($id>0)
{
$pointers[$id]->children[] = $id;
if(isset($pointers[$pointers[$id]->parent_id]->children))
$pointers[$pointers[$id]->parent_id]->children = array_merge($pointers[$id]->children, $pointers[$pointers[$id]->parent_id]->children);
else
$pointers[$pointers[$id]->parent_id]->children = $pointers[$id]->children;
// Добавляем количество товаров к родительской категории, если текущая видима
// if(isset($pointers[$pointers[$id]->parent_id]) && $pointers[$id]->visible)
// $pointers[$pointers[$id]->parent_id]->products_count += $pointers[$id]->products_count;
}
}
unset($pointers[0]);
unset($ids);
$this->articles_categories_tree = $tree->subcategories;
$this->all_articles_categories = $pointers;
}
}