Skip to content
Snippets Groups Projects
TsrefController.php 5.26 KiB
Newer Older
damjan's avatar
damjan committed
<?php
damjan's avatar
damjan committed
namespace SGalinski\TypoScriptReferenceFrontend\Controller;

/*                                                                        *
 * This script belongs to the TYPO3 Flow package "SGalinski.TypoScriptReferenceFrontend".*
 *                                                                        *
 *                                                                        */

use SGalinski\TypoScriptReferenceFrontend\Domain\Model\Attribute;
use SGalinski\TypoScriptReferenceFrontend\Service\TsrefRestService;
damjan's avatar
damjan committed
use SGalinski\TypoScriptReferenceFrontend\Utilities\Conversion;
damjan's avatar
damjan committed
use TYPO3\Flow\Annotations as Flow;

class TsrefController extends \TYPO3\Flow\Mvc\Controller\ActionController {
damjan's avatar
damjan committed
	/**
	 * @var TsrefRestService
	 */
	protected $tsrefRestService;

	/**
	 * The constructor is used for dependency injection.
	 *
	 * @param TsrefRestService $service
	 */
	public function __construct(TsrefRestService $service) {
		$this->tsrefRestService = $service;
	}

	/**
	 * The action which fetches the data for typoScript reference page, and displays the page.
	 * @param int $typeId
	 * @return void
damjan's avatar
damjan committed
	 */
	public function indexAction($typeId = NULL) {
			$selectedType = $this->tsrefRestService->getAttributeById($typeId);
			$properties = $this->tsrefRestService->getPropertiesByParentId($typeId);
			$this->view->assign('properties', $properties);
			$this->view->assign('selectedType', $selectedType);

			// If the type extends a type (superType), the superType name is being fetched among other fields
			if (isset($selectedType->parent_id)) {
				$superType = $this->tsrefRestService->getAttributeById($selectedType->parent_id);
				$this->view->assign('superType', $superType);
			}
		$this->prepareTypeMenu($typeId);
damjan's avatar
damjan committed
	}
	 * Adds a new type or saves changes in edited type.
	 *
	 * @param Attribute $theType
damjan's avatar
damjan committed
	 * @param boolean $editForm
	 * @return void
	 */
damjan's avatar
damjan committed
	public function submitTypeAction(Attribute $theType, $editForm) {
		if ($editForm) {
			$result = $this->tsrefRestService->editAttribute($theType);
damjan's avatar
damjan committed
		} else {
			$result = $this->tsrefRestService->addNewAttribute($theType);
damjan's avatar
damjan committed
		}
damjan's avatar
damjan committed
		// TODO: Return error message. Or success message.
		$this->forward('index', 'tsref', 'SGalinski.TypoScriptReferenceFrontend', ['typeId' => $theType->getId()]);
	}

	/**
	 * Prepares and opens the page for adding new / editing the type
	 * @param int $theTypeId
	 */
	public function editTypeAction($theTypeId = NULL) {
		$theType = new Attribute();

		if ($theTypeId !== NULL) {
			// Edit type
			$selectedTypeAsStdClass = $this->tsrefRestService->getAttributeById($theTypeId);
			$theType->initialiseAttribute($selectedTypeAsStdClass);
		}

		$this->prepareTypeMenu($theTypeId);
damjan's avatar
damjan committed
		$typo3Groups = $this->tsrefRestService->getAllTypo3Groups();

		$this->view->assign('typo3Groups', $typo3Groups);
		$this->view->assign('theType', $theType);
		$this->view->assign('editForm', ($theTypeId !== NULL));
damjan's avatar
damjan committed

	/**
	 * Adds a new property or saves the changes in edited property.
	 *
	 * @param Attribute $theProperty
	 * @param boolean $editForm
	 * @return void
	 */
	public function submitPropertyAction(Attribute $theProperty, $editForm) {
		if ($editForm) {
			$result = $this->tsrefRestService->editAttribute($theProperty);
		} else {
			$result = $this->tsrefRestService->addNewAttribute($theProperty);
		}
		// TODO: Return error message. Or success message.
		$this->forward(
			'index', 'tsref', 'SGalinski.TypoScriptReferenceFrontend', ['typeId' => $theProperty->getParent()]
		);
	}

damjan's avatar
damjan committed
	/**
	 * Prepares and opens the page for adding new / editing the property
	 *
	 * @param int $parentTypeId
	 * @param int $thePropertyId
	 */
	public function editPropertyAction($parentTypeId, $thePropertyId = NULL) {
		$theProperty = new Attribute();

		if ($thePropertyId !== NULL) {
			// Edit type
			$selectedPropertyAsStdClass = $this->tsrefRestService->getAttributeById($thePropertyId);
			$theProperty->initialiseAttribute($selectedPropertyAsStdClass);
		}
		$theProperty->setParent($parentTypeId);

		$this->prepareTypeMenu($parentTypeId);
		$typo3Groups = $this->tsrefRestService->getAllTypo3Groups();

		$this->view->assign('typo3Groups', $typo3Groups);
		$this->view->assign('theProperty', $theProperty);
		$this->view->assign('editForm', ($thePropertyId !== NULL));
damjan's avatar
damjan committed
	}
	/**
	 * Deletes attribute by $attributeId.
	 * If the attribute is a type, $parentTypeId should be NULL.
	 * If the attribute is a property, $parentTypeId should be specified,
	 * and then that type will be presented after deletion of the property.
	 *
	 * @param int $attributeId
	 * @param int $parentTypeId
	 * @throws \TYPO3\Flow\Mvc\Exception\ForwardException
	 */
	public function deleteAttributeAction($attributeId, $parentTypeId = NULL) {
		$result = $this->tsrefRestService->patchAttribute($attributeId, ['deleted' => TRUE]);
		// TODO: Return error message. Or success message.
		$this->forward(
			'index', 'tsref', 'SGalinski.TypoScriptReferenceFrontend', ['typeId' => $parentTypeId]
		);
	}

	/**
	 * Sets view variables needed for type menu.
	 *
	 * @param $theTypeId
	 */
	protected function prepareTypeMenu($theTypeId) {
		$types = $this->tsrefRestService->getTypes();
		$associativeTypes = Conversion::toAssociativeIdNamesArray($types);
		$this->view->assign('types', $associativeTypes);
		$this->view->assign('selectedTypeId', $theTypeId);
	}
damjan's avatar
damjan committed
}