<?php /***************************************************************************** * ManageAlbums.php * Contains the controller for admin album management. * * Kabuki CMS (C) 2013-2017, Aaron van Geffen *****************************************************************************/ class ManageAlbums extends HTMLController { public function __construct() { // Ensure it's just admins at this point. if (!Registry::get('user')->isAdmin()) throw new NotAllowedException(); $options = [ 'form' => [ 'action' => BASEURL . '/editalbum/', 'method' => 'get', 'class' => 'floatright', 'buttons' => [ 'add' => [ 'type' => 'submit', 'caption' => 'Add new album', ], ], ], 'columns' => [ 'id_album' => [ 'value' => 'id_tag', 'header' => 'ID', 'is_sortable' => true, ], 'tag' => [ 'header' => 'Album', 'is_sortable' => true, 'parse' => [ 'link' => BASEURL . '/editalbum/?id={ID_TAG}', 'data' => 'tag', ], ], 'slug' => [ 'header' => 'Slug', 'is_sortable' => true, 'parse' => [ 'link' => BASEURL . '/editalbum/?id={ID_TAG}', 'data' => 'slug', ], ], 'count' => [ 'header' => '# Photos', 'is_sortable' => true, 'value' => 'count', ], ], 'start' => !empty($_GET['start']) ? (int) $_GET['start'] : 0, 'sort_order' => !empty($_GET['order']) ? $_GET['order'] : null, 'sort_direction' => !empty($_GET['dir']) ? $_GET['dir'] : null, 'title' => 'Manage albums', 'no_items_label' => 'No albums meet the requirements of the current filter.', 'items_per_page' => 9999, 'index_class' => 'floatleft', 'base_url' => BASEURL . '/managealbums/', 'get_data' => function($offset = 0, $limit = 9999, $order = '', $direction = 'up') { if (!in_array($order, ['id_tag', 'tag', 'slug', 'count'])) $order = 'tag'; if (!in_array($direction, ['up', 'down'])) $direction = 'up'; $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' => $rows, 'order' => $order, 'direction' => ($direction == 'up' ? 'up' : 'down'), ]; }, 'get_count' => function() { return 9999; } ]; $table = new GenericTable($options); parent::__construct('Album management - Page ' . $table->getCurrentPage() .' - ' . SITE_TITLE); $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; } }