Refactor the GenericTables class #51
@ -65,11 +65,10 @@ class ManageAlbums extends HTMLController
 | 
				
			|||||||
			'index_class' => 'col-md-6',
 | 
								'index_class' => 'col-md-6',
 | 
				
			||||||
			'base_url' => BASEURL . '/managealbums/',
 | 
								'base_url' => BASEURL . '/managealbums/',
 | 
				
			||||||
			'get_data' => function($offset, $limit, $order, $direction) {
 | 
								'get_data' => function($offset, $limit, $order, $direction) {
 | 
				
			||||||
				assert(in_array($order, ['id_tag', 'tag', 'slug', 'count']));
 | 
									return Tag::getOffset($offset, $limit, $order, $direction, true);
 | 
				
			||||||
				return PhotoAlbum::getHierarchy($order, $direction);
 | 
					 | 
				
			||||||
			},
 | 
								},
 | 
				
			||||||
			'get_count' => function() {
 | 
								'get_count' => function() {
 | 
				
			||||||
				return 9999;
 | 
									return Tag::getCount(false, 'Album', true);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		];
 | 
							];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -131,23 +131,7 @@ class ManageAssets extends HTMLController
 | 
				
			|||||||
			'items_per_page' => 30,
 | 
								'items_per_page' => 30,
 | 
				
			||||||
			'index_class' => 'col-md-6',
 | 
								'index_class' => 'col-md-6',
 | 
				
			||||||
			'base_url' => BASEURL . '/manageassets/',
 | 
								'base_url' => BASEURL . '/manageassets/',
 | 
				
			||||||
			'get_data' => function($offset, $limit, $order, $direction) {
 | 
								'get_data' => 'Asset::getOffset',
 | 
				
			||||||
				assert(in_array($order, ['id_asset', 'id_user_uploaded', 'title', 'subdir', 'filename']));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				return Registry::get('db')->queryAssocs('
 | 
					 | 
				
			||||||
					SELECT a.id_asset, a.subdir, a.filename,
 | 
					 | 
				
			||||||
						a.image_width, a.image_height, a.mimetype,
 | 
					 | 
				
			||||||
						u.id_user, u.first_name, u.surname
 | 
					 | 
				
			||||||
					FROM assets AS a
 | 
					 | 
				
			||||||
					LEFT JOIN users AS u ON a.id_user_uploaded = u.id_user
 | 
					 | 
				
			||||||
					ORDER BY {raw:order}
 | 
					 | 
				
			||||||
					LIMIT {int:offset}, {int:limit}',
 | 
					 | 
				
			||||||
					[
 | 
					 | 
				
			||||||
						'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
 | 
					 | 
				
			||||||
						'offset' => $offset,
 | 
					 | 
				
			||||||
						'limit' => $limit,
 | 
					 | 
				
			||||||
					]);
 | 
					 | 
				
			||||||
			},
 | 
					 | 
				
			||||||
			'get_count' => 'Asset::getCount',
 | 
								'get_count' => 'Asset::getCount',
 | 
				
			||||||
		];
 | 
							];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -105,20 +105,7 @@ class ManageErrors extends HTMLController
 | 
				
			|||||||
			'index_class' => 'col-md-6',
 | 
								'index_class' => 'col-md-6',
 | 
				
			||||||
			'base_url' => BASEURL . '/manageerrors/',
 | 
								'base_url' => BASEURL . '/manageerrors/',
 | 
				
			||||||
			'get_count' => 'ErrorLog::getCount',
 | 
								'get_count' => 'ErrorLog::getCount',
 | 
				
			||||||
			'get_data' => function($offset, $limit, $order, $direction) {
 | 
								'get_data' => 'ErrorLog::getOffset',
 | 
				
			||||||
				assert(in_array($order, ['id_entry', 'file', 'line', 'time', 'ipaddress', 'id_user']));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				return Registry::get('db')->queryAssocs('
 | 
					 | 
				
			||||||
					SELECT *
 | 
					 | 
				
			||||||
					FROM log_errors
 | 
					 | 
				
			||||||
					ORDER BY {raw:order}
 | 
					 | 
				
			||||||
					LIMIT {int:offset}, {int:limit}',
 | 
					 | 
				
			||||||
					[
 | 
					 | 
				
			||||||
						'order' => $order . ($direction === 'up' ? ' ASC' : ' DESC'),
 | 
					 | 
				
			||||||
						'offset' => $offset,
 | 
					 | 
				
			||||||
						'limit' => $limit,
 | 
					 | 
				
			||||||
					]);
 | 
					 | 
				
			||||||
			},
 | 
					 | 
				
			||||||
		];
 | 
							];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		$error_log = new GenericTable($options);
 | 
							$error_log = new GenericTable($options);
 | 
				
			||||||
 | 
				
			|||||||
@ -81,28 +81,10 @@ class ManageTags extends HTMLController
 | 
				
			|||||||
			'index_class' => 'col-md-6',
 | 
								'index_class' => 'col-md-6',
 | 
				
			||||||
			'base_url' => BASEURL . '/managetags/',
 | 
								'base_url' => BASEURL . '/managetags/',
 | 
				
			||||||
			'get_data' => function($offset, $limit, $order, $direction) {
 | 
								'get_data' => function($offset, $limit, $order, $direction) {
 | 
				
			||||||
				assert(in_array($order, ['id_tag', 'tag', 'slug', 'count']));
 | 
									return Tag::getOffset($offset, $limit, $order, $direction, false);
 | 
				
			||||||
 | 
					 | 
				
			||||||
				return Registry::get('db')->queryAssocs('
 | 
					 | 
				
			||||||
					SELECT t.*, u.id_user, u.first_name, u.surname
 | 
					 | 
				
			||||||
					FROM tags AS t
 | 
					 | 
				
			||||||
					LEFT JOIN users AS u ON t.id_user_owner = u.id_user
 | 
					 | 
				
			||||||
					WHERE kind != {string:album}
 | 
					 | 
				
			||||||
					ORDER BY {raw:order}
 | 
					 | 
				
			||||||
					LIMIT {int:offset}, {int:limit}',
 | 
					 | 
				
			||||||
					[
 | 
					 | 
				
			||||||
						'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
 | 
					 | 
				
			||||||
						'offset' => $offset,
 | 
					 | 
				
			||||||
						'limit' => $limit,
 | 
					 | 
				
			||||||
						'album' => 'Album',
 | 
					 | 
				
			||||||
					]);
 | 
					 | 
				
			||||||
			},
 | 
								},
 | 
				
			||||||
			'get_count' => function() {
 | 
								'get_count' => function() {
 | 
				
			||||||
				return Registry::get('db')->queryValue('
 | 
									return Tag::getCount(false, null, false);
 | 
				
			||||||
					SELECT COUNT(*)
 | 
					 | 
				
			||||||
					FROM tags
 | 
					 | 
				
			||||||
					WHERE kind != {string:album}',
 | 
					 | 
				
			||||||
					['album' => 'Album']);
 | 
					 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		];
 | 
							];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -100,20 +100,7 @@ class ManageUsers extends HTMLController
 | 
				
			|||||||
			'items_per_page' => 30,
 | 
								'items_per_page' => 30,
 | 
				
			||||||
			'index_class' => 'col-md-6',
 | 
								'index_class' => 'col-md-6',
 | 
				
			||||||
			'base_url' => BASEURL . '/manageusers/',
 | 
								'base_url' => BASEURL . '/manageusers/',
 | 
				
			||||||
			'get_data' => function($offset, $limit, $order, $direction) {
 | 
								'get_data' => 'Member::getOffset',
 | 
				
			||||||
				assert(in_array($order, ['id_user', 'surname', 'first_name', 'slug', 'emailaddress', 'last_action_time', 'ip_address', 'is_admin']));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
				return Registry::get('db')->queryAssocs('
 | 
					 | 
				
			||||||
					SELECT *
 | 
					 | 
				
			||||||
					FROM users
 | 
					 | 
				
			||||||
					ORDER BY {raw:order}
 | 
					 | 
				
			||||||
					LIMIT {int:offset}, {int:limit}',
 | 
					 | 
				
			||||||
					[
 | 
					 | 
				
			||||||
						'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
 | 
					 | 
				
			||||||
						'offset' => $offset,
 | 
					 | 
				
			||||||
						'limit' => $limit,
 | 
					 | 
				
			||||||
					]);
 | 
					 | 
				
			||||||
			},
 | 
					 | 
				
			||||||
			'get_count' => 'Member::getCount',
 | 
								'get_count' => 'Member::getCount',
 | 
				
			||||||
		];
 | 
							];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -680,6 +680,23 @@ class Asset
 | 
				
			|||||||
			FROM assets');
 | 
								FROM assets');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public static function getOffset($offset, $limit, $order, $direction)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							return Registry::get('db')->queryAssocs('
 | 
				
			||||||
 | 
								SELECT a.id_asset, a.subdir, a.filename,
 | 
				
			||||||
 | 
									a.image_width, a.image_height, a.mimetype,
 | 
				
			||||||
 | 
									u.id_user, u.first_name, u.surname
 | 
				
			||||||
 | 
								FROM assets AS a
 | 
				
			||||||
 | 
								LEFT JOIN users AS u ON a.id_user_uploaded = u.id_user
 | 
				
			||||||
 | 
								ORDER BY {raw:order}
 | 
				
			||||||
 | 
								LIMIT {int:offset}, {int:limit}',
 | 
				
			||||||
 | 
								[
 | 
				
			||||||
 | 
									'order' => $order . ($direction == 'up' ? ' ASC' : ' DESC'),
 | 
				
			||||||
 | 
									'offset' => $offset,
 | 
				
			||||||
 | 
									'limit' => $limit,
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public function save()
 | 
						public function save()
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		if (empty($this->id_asset))
 | 
							if (empty($this->id_asset))
 | 
				
			||||||
 | 
				
			|||||||
@ -33,4 +33,20 @@ class ErrorLog
 | 
				
			|||||||
			SELECT COUNT(*)
 | 
								SELECT COUNT(*)
 | 
				
			||||||
			FROM log_errors');
 | 
								FROM log_errors');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public static function getOffset($offset, $limit, $order, $direction)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							assert(in_array($order, ['id_entry', 'file', 'line', 'time', 'ipaddress', 'id_user']));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return Registry::get('db')->queryAssocs('
 | 
				
			||||||
 | 
								SELECT *
 | 
				
			||||||
 | 
								FROM log_errors
 | 
				
			||||||
 | 
								ORDER BY {raw:order}
 | 
				
			||||||
 | 
								LIMIT {int:offset}, {int:limit}',
 | 
				
			||||||
 | 
								[
 | 
				
			||||||
 | 
									'order' => $order . ($direction === 'up' ? ' ASC' : ' DESC'),
 | 
				
			||||||
 | 
									'offset' => $offset,
 | 
				
			||||||
 | 
									'limit' => $limit,
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -187,6 +187,22 @@ class Member extends User
 | 
				
			|||||||
			FROM users');
 | 
								FROM users');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public static function getOffset($offset, $limit, $order, $direction)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							assert(in_array($order, ['id_user', 'surname', 'first_name', 'slug', 'emailaddress', 'last_action_time', 'ip_address', 'is_admin']));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return Registry::get('db')->queryAssocs('
 | 
				
			||||||
 | 
								SELECT *
 | 
				
			||||||
 | 
								FROM users
 | 
				
			||||||
 | 
								ORDER BY {raw:order}
 | 
				
			||||||
 | 
								LIMIT {int:offset}, {int:limit}',
 | 
				
			||||||
 | 
								[
 | 
				
			||||||
 | 
									'order' => $order . ($direction === 'up' ? ' ASC' : ' DESC'),
 | 
				
			||||||
 | 
									'offset' => $offset,
 | 
				
			||||||
 | 
									'limit' => $limit,
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public function getProps()
 | 
						public function getProps()
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		// We should probably phase out the use of this function, or refactor the access levels of member properties...
 | 
							// We should probably phase out the use of this function, or refactor the access levels of member properties...
 | 
				
			||||||
 | 
				
			|||||||
@ -1,76 +0,0 @@
 | 
				
			|||||||
<?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;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
							
								
								
									
										100
									
								
								models/Tag.php
									
									
									
									
									
								
							
							
						
						
									
										100
									
								
								models/Tag.php
									
									
									
									
									
								
							@ -24,6 +24,11 @@ class Tag
 | 
				
			|||||||
			$this->$attribute = $value;
 | 
								$this->$attribute = $value;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						public function __toString()
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							return $this->tag;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public static function fromId($id_tag, $return_format = 'object')
 | 
						public static function fromId($id_tag, $return_format = 'object')
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		$db = Registry::get('db');
 | 
							$db = Registry::get('db');
 | 
				
			||||||
@ -409,27 +414,98 @@ class Tag
 | 
				
			|||||||
			['tags' => $tags]);
 | 
								['tags' => $tags]);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public static function getCount($only_active = 1, $kind = '')
 | 
						public static function getCount($only_used = true, $kind = '', $isAlbum = false)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		$where = [];
 | 
							$where = [];
 | 
				
			||||||
		if ($only_active)
 | 
							if ($only_used)
 | 
				
			||||||
			$where[] = 'count > 0';
 | 
								$where[] = 'count > 0';
 | 
				
			||||||
		if (!empty($kind))
 | 
							if (empty($kind))
 | 
				
			||||||
			$where[] = 'kind = {string:kind}';
 | 
								$kind = 'Album';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!empty($where))
 | 
							$where[] = 'kind {raw:operator} {string:kind}';
 | 
				
			||||||
			$where = 'WHERE ' . implode(' AND ', $where);
 | 
							$where = implode(' AND ', $where);
 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			$where = '';
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		return Registry::get('db')->queryValue('
 | 
							return Registry::get('db')->queryValue('
 | 
				
			||||||
			SELECT COUNT(*)
 | 
								SELECT COUNT(*)
 | 
				
			||||||
			FROM tags ' . $where,
 | 
								FROM tags
 | 
				
			||||||
			['kind' => $kind]);
 | 
								WHERE ' . $where,
 | 
				
			||||||
 | 
								[
 | 
				
			||||||
 | 
									'kind' => $kind,
 | 
				
			||||||
 | 
									'operator' => $isAlbum ? '=' : '!=',
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	public function __toString()
 | 
						public static function getOffset($offset, $limit, $order, $direction, $isAlbum = false)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		return $this->tag;
 | 
							assert(in_array($order, ['id_tag', 'tag', 'slug', 'count']));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							$db = Registry::get('db');
 | 
				
			||||||
 | 
							$res = $db->query('
 | 
				
			||||||
 | 
								SELECT t.*, u.id_user, u.first_name, u.surname
 | 
				
			||||||
 | 
								FROM tags AS t
 | 
				
			||||||
 | 
								LEFT JOIN users AS u ON t.id_user_owner = u.id_user
 | 
				
			||||||
 | 
								WHERE kind {raw:operator} {string:album}
 | 
				
			||||||
 | 
								ORDER BY id_parent, {raw:order}
 | 
				
			||||||
 | 
								LIMIT {int:offset}, {int:limit}',
 | 
				
			||||||
 | 
								[
 | 
				
			||||||
 | 
									'order' => $order . ($direction === 'up' ? ' ASC' : ' DESC'),
 | 
				
			||||||
 | 
									'offset' => $offset,
 | 
				
			||||||
 | 
									'limit' => $limit,
 | 
				
			||||||
 | 
									'album' => 'Album',
 | 
				
			||||||
 | 
									'operator' => $isAlbum ? '=' : '!=',
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							$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)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								static $headers_to_keep = ['id_tag', 'tag', 'slug', 'count', 'id_user', 'first_name', 'surname'];
 | 
				
			||||||
 | 
								$rows[] = array_intersect_key($album, array_flip($headers_to_keep));
 | 
				
			||||||
 | 
								if (!empty($album['children']))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									$children = self::flattenChildrenRecursively($album['children']);
 | 
				
			||||||
 | 
									foreach ($children as $child)
 | 
				
			||||||
 | 
										$rows[] = array_intersect_key($child, array_flip($headers_to_keep));
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return $rows;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user