| Current Path : /var/www/surf/TYPO3/vendor/typo3/cms-form/Classes/Domain/Model/Renderable/ |
| Current File : /var/www/surf/TYPO3/vendor/typo3/cms-form/Classes/Domain/Model/Renderable/RenderableInterface.php |
<?php
declare(strict_types=1);
/*
* This file is part of the TYPO3 CMS project.
*
* It is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License, either version 2
* of the License, or any later version.
*
* For the full copyright and license information, please read the
* LICENSE.txt file that was distributed with this source code.
*
* The TYPO3 project - inspiring people to share!
*/
/*
* Inspired by and partially taken from the Neos.Form package (www.neos.io)
*/
namespace TYPO3\CMS\Form\Domain\Model\Renderable;
/**
* Base interface which all Form Parts except the FormDefinition must adhere
* to (i.e. all elements which are NOT the root of a Form).
*
* Scope: frontend
* **This class is NOT meant to be sub classed by developers.**
*/
interface RenderableInterface extends RootRenderableInterface
{
/**
* Return the parent renderable
*
* @return CompositeRenderableInterface|null the parent renderable
* @internal
*/
public function getParentRenderable();
/**
* Set the new parent renderable. You should not call this directly;
* it is automatically called by addRenderable.
*
* This method should also register itself at the parent form, if possible.
*
* @param CompositeRenderableInterface $renderable
* @internal
*/
public function setParentRenderable(CompositeRenderableInterface $renderable);
/**
* Set the index of this renderable inside the parent renderable
*
* @internal
*/
public function setIndex(int $index);
/**
* Get the index inside the parent renderable
*/
public function getIndex(): int;
/**
* This function is called after a renderable has been removed from its parent
* renderable. The function should make sure to clean up the internal state,
* like resetting $this->parentRenderable or deregistering the renderable
* of the form.
*
* @internal
*/
public function onRemoveFromParentRenderable();
/**
* Register this element at the parent form, if there is a connection to the parent form.
*
* @internal
*/
public function registerInFormIfPossible();
/**
* Get the template name of the renderable
*/
public function getTemplateName(): string;
/**
* Returns whether this renderable is enabled
*/
public function isEnabled(): bool;
}