<?php
/*****************************************************************************
 * EditAlbum.php
 * Contains the album edit controller.
 *
 * Kabuki CMS (C) 2013-2017, Aaron van Geffen
 *****************************************************************************/

class EditAlbum extends HTMLController
{
	public function __construct()
	{
		// Ensure it's just admins at this point.
		if (!Registry::get('user')->isAdmin())
			throw new NotAllowedException();

		$id_tag = isset($_GET['id']) ? (int) $_GET['id'] : 0;
		if (empty($id_tag) && !isset($_GET['add']))
			throw new UnexpectedValueException('Requested album not found or not requesting a new album.');

		// Adding an album?
		if (isset($_GET['add']))
		{
			parent::__construct('Add a new album');
			$form_title = 'Add a new album';
			$this->page->addClass('editalbum');
		}
		// Deleting one?
		elseif (isset($_GET['delete']))
		{
			// So far so good?
			$album = Tag::fromId($id_tag);
			if (Session::validateSession('get') && $tag->kind === 'Album' && $tag->delete())
			{
				header('Location: ' . BASEURL . '/managealbums/');
				exit;
			}
			else
				trigger_error('Cannot delete album: an error occured while processing the request.', E_USER_ERROR);
		}
		// Editing one, then, surely.
		else
		{
			$album = Tag::fromId($id_tag);
			if ($album->kind !== 'Album')
				trigger_error('Cannot edit album: not an album.', E_USER_ERROR);

			parent::__construct('Edit album \'' . $album->tag . '\'');
			$form_title = 'Edit album \'' . $album->tag . '\'';
			$this->page->addClass('editalbum');
		}

		// Session checking!
		if (empty($_POST))
			Session::resetSessionToken();
		else
			Session::validateSession();

		if ($id_tag)
			$after_form = '<a href="' . BASEURL . '/editalbum/?id=' . $id_tag . '&delete&' . Session::getSessionTokenKey() . '=' . Session::getSessionToken() . '" class="btn btn-danger" onclick="return confirm(\'Are you sure you want to delete this album? You cannot undo this!\');">Delete album</a>';
		elseif (!$id_tag)
			$after_form = '<button name="submit_and_new" class="btn">Save and add another</button>';

		$form = new Form([
			'request_url' => BASEURL . '/editalbum/?' . ($id_tag ? 'id=' . $id_tag : 'add'),
			'content_below' => $after_form,
			'fields' => [
				'id_parent' => [
					'type' => 'numeric',
					'label' => 'Parent album ID',
				],
				'id_asset_thumb' => [
					'type' => 'numeric',
					'label' => 'Thumbnail asset ID',
					'is_optional' => true,
				],
				'tag' => [
					'type' => 'text',
					'label' => 'Album title',
					'size' => 50,
					'maxlength' => 255,
				],
				'slug' => [
					'type' => 'text',
					'label' => 'URL slug',
					'size' => 50,
					'maxlength' => 255,
				],
				'description' => [
					'type' => 'textbox',
					'label' => 'Description',
					'size' => 50,
					'maxlength' => 255,
					'is_optional' => true,
				],
			],
		]);

		// Create the form, add in default values.
		$form->setData($id_tag ? get_object_vars($album) : $_POST);
		$formview = new FormView($form, $form_title ?? '');
		$this->page->adopt($formview);

		if (!empty($_POST))
		{
			$form->verify($_POST);

			// Anything missing?
			if (!empty($form->getMissing()))
				return $formview->adopt(new Alert('Some data missing', 'Please fill out the following fields: ' . implode(', ', $form->getMissing()), 'error'));

			$data = $form->getData();

			// Quick stripping.
			$data['slug'] = strtr(strtolower($data['slug']), [' ' => '-', '--' => '-', '&' => 'and', '=>' => '', "'" => "", ":"=> "", '/' => '-', '\\' => '-']);

			// TODO: when updating slug, update slug for all photos in this album.

			// Creating a new album?
			if (!$id_tag)
			{
				$data['kind'] = 'Album';
				$return = Tag::createNew($data);
				if ($return === false)
					return $formview->adopt(new Alert('Cannot create this album', 'Something went wrong while creating the album...', 'error'));

				if (isset($_POST['submit_and_new']))
				{
					header('Location: ' . BASEURL . '/editalbum/?add');
					exit;
				}
			}
			// Just updating?
			else
			{
				foreach ($data as $key => $value)
					$album->$key = $value;

				$album->save();
			}

			// Redirect to the album management page.
			header('Location: ' . BASEURL . '/managealbums/');
			exit;
		}
	}
}