148 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?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' => 'float-end',
 | 
						|
				'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' => 'float-start',
 | 
						|
			'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;
 | 
						|
	}
 | 
						|
}
 |