forked from Public/pics
ManageAlbums: move hierarchy logic to PhotoAlbum model
This commit is contained in:
parent
4033a8813c
commit
4684482d67
@ -68,28 +68,7 @@ class ManageAlbums extends HTMLController
|
|||||||
if (!in_array($direction, ['up', 'down']))
|
if (!in_array($direction, ['up', 'down']))
|
||||||
$direction = 'up';
|
$direction = 'up';
|
||||||
|
|
||||||
$db = Registry::get('db');
|
$rows = PhotoAlbum::getHierarchy($order, $direction);
|
||||||
$res = $db->query('
|
|
||||||
SELECT *
|
|
||||||
FROM tags
|
|
||||||
WHERE kind = {string:album}
|
|
||||||
ORDER BY id_parent, {raw:order}',
|
|
||||||
[
|
|
||||||
'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
|
|
||||||
'album' => 'Album',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$albums_by_parent = [];
|
|
||||||
while ($row = $db->fetch_assoc($res))
|
|
||||||
{
|
|
||||||
if (!isset($albums_by_parent[$row['id_parent']]))
|
|
||||||
$albums_by_parent[$row['id_parent']] = [];
|
|
||||||
|
|
||||||
$albums_by_parent[$row['id_parent']][] = $row + ['children' => []];
|
|
||||||
}
|
|
||||||
|
|
||||||
$albums = self::getChildrenRecursively(0, 0, $albums_by_parent);
|
|
||||||
$rows = self::flattenChildrenRecursively($albums);
|
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'rows' => $rows,
|
'rows' => $rows,
|
||||||
@ -106,42 +85,4 @@ class ManageAlbums extends HTMLController
|
|||||||
parent::__construct('Album management - Page ' . $table->getCurrentPage() .' - ' . SITE_TITLE);
|
parent::__construct('Album management - Page ' . $table->getCurrentPage() .' - ' . SITE_TITLE);
|
||||||
$this->page->adopt(new TabularData($table));
|
$this->page->adopt(new TabularData($table));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function getChildrenRecursively($id_parent, $level, &$albums_by_parent)
|
|
||||||
{
|
|
||||||
$children = [];
|
|
||||||
if (!isset($albums_by_parent[$id_parent]))
|
|
||||||
return $children;
|
|
||||||
|
|
||||||
foreach ($albums_by_parent[$id_parent] as $child)
|
|
||||||
{
|
|
||||||
if (isset($albums_by_parent[$child['id_tag']]))
|
|
||||||
$child['children'] = self::getChildrenRecursively($child['id_tag'], $level + 1, $albums_by_parent);
|
|
||||||
|
|
||||||
$child['tag'] = ($level ? str_repeat('—', $level * 2) . ' ' : '') . $child['tag'];
|
|
||||||
$children[] = $child;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $children;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static function flattenChildrenRecursively($albums)
|
|
||||||
{
|
|
||||||
if (empty($albums))
|
|
||||||
return [];
|
|
||||||
|
|
||||||
$rows = [];
|
|
||||||
foreach ($albums as $album)
|
|
||||||
{
|
|
||||||
$rows[] = array_intersect_key($album, array_flip(['id_tag', 'tag', 'slug', 'count']));
|
|
||||||
if (!empty($album['children']))
|
|
||||||
{
|
|
||||||
$children = self::flattenChildrenRecursively($album['children']);
|
|
||||||
foreach ($children as $child)
|
|
||||||
$rows[] = array_intersect_key($child, array_flip(['id_tag', 'tag', 'slug', 'count']));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $rows;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
76
models/PhotoAlbum.php
Normal file
76
models/PhotoAlbum.php
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
<?php
|
||||||
|
/*****************************************************************************
|
||||||
|
* PhotoAlbum.php
|
||||||
|
* Contains key class PhotoAlbum.
|
||||||
|
*
|
||||||
|
* Kabuki CMS (C) 2013-2015, Aaron van Geffen
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
class PhotoAlbum extends Tag
|
||||||
|
{
|
||||||
|
public static function getHierarchy($order, $direction)
|
||||||
|
{
|
||||||
|
$db = Registry::get('db');
|
||||||
|
$res = $db->query('
|
||||||
|
SELECT *
|
||||||
|
FROM tags
|
||||||
|
WHERE kind = {string:album}
|
||||||
|
ORDER BY id_parent, {raw:order}',
|
||||||
|
[
|
||||||
|
'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
|
||||||
|
'album' => 'Album',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$albums_by_parent = [];
|
||||||
|
while ($row = $db->fetch_assoc($res))
|
||||||
|
{
|
||||||
|
if (!isset($albums_by_parent[$row['id_parent']]))
|
||||||
|
$albums_by_parent[$row['id_parent']] = [];
|
||||||
|
|
||||||
|
$albums_by_parent[$row['id_parent']][] = $row + ['children' => []];
|
||||||
|
}
|
||||||
|
|
||||||
|
$albums = self::getChildrenRecursively(0, 0, $albums_by_parent);
|
||||||
|
$rows = self::flattenChildrenRecursively($albums);
|
||||||
|
|
||||||
|
return $rows;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function getChildrenRecursively($id_parent, $level, &$albums_by_parent)
|
||||||
|
{
|
||||||
|
$children = [];
|
||||||
|
if (!isset($albums_by_parent[$id_parent]))
|
||||||
|
return $children;
|
||||||
|
|
||||||
|
foreach ($albums_by_parent[$id_parent] as $child)
|
||||||
|
{
|
||||||
|
if (isset($albums_by_parent[$child['id_tag']]))
|
||||||
|
$child['children'] = self::getChildrenRecursively($child['id_tag'], $level + 1, $albums_by_parent);
|
||||||
|
|
||||||
|
$child['tag'] = ($level ? str_repeat('—', $level * 2) . ' ' : '') . $child['tag'];
|
||||||
|
$children[] = $child;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $children;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function flattenChildrenRecursively($albums)
|
||||||
|
{
|
||||||
|
if (empty($albums))
|
||||||
|
return [];
|
||||||
|
|
||||||
|
$rows = [];
|
||||||
|
foreach ($albums as $album)
|
||||||
|
{
|
||||||
|
$rows[] = array_intersect_key($album, array_flip(['id_tag', 'tag', 'slug', 'count']));
|
||||||
|
if (!empty($album['children']))
|
||||||
|
{
|
||||||
|
$children = self::flattenChildrenRecursively($album['children']);
|
||||||
|
foreach ($children as $child)
|
||||||
|
$rows[] = array_intersect_key($child, array_flip(['id_tag', 'tag', 'slug', 'count']));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $rows;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user