<?php
/**
* Pimcore
*
* This source file is available under two different licenses:
* - GNU General Public License version 3 (GPLv3)
* - Pimcore Commercial License (PCL)
* Full copyright and license information is available in
* LICENSE.md which is distributed with this source code.
*
* @copyright Copyright (c) Pimcore GmbH (http://www.pimcore.org)
* @license http://www.pimcore.org/license GPLv3 and PCL
*/
namespace Pimcore\Templating\Renderer;
use Pimcore\Document\Editable\EditmodeEditableDefinitionCollector;
use Pimcore\Http\Request\Resolver\EditmodeResolver;
use Pimcore\Model\Document\Editable;
use Pimcore\Model\Document\Editable\LazyLoadingInterface;
use Pimcore\Model\Document\Editable\Loader\EditableLoaderInterface;
use Pimcore\Model\Document\PageSnippet;
use Psr\Log\LoggerAwareInterface;
use Psr\Log\LoggerAwareTrait;
/**
* @internal
*/
class EditableRenderer implements LoggerAwareInterface
{
use LoggerAwareTrait;
/**
* @var EditableLoaderInterface
*/
protected $editableLoader;
/**
* @var EditmodeResolver
*/
protected $editmodeResolver;
protected ?EditmodeEditableDefinitionCollector $configCollector;
/**
* @param EditableLoaderInterface $editableLoader
* @param EditmodeResolver $editmodeResolver
* @param EditmodeEditableDefinitionCollector $configCollector
*/
public function __construct(EditableLoaderInterface $editableLoader, EditmodeResolver $editmodeResolver, EditmodeEditableDefinitionCollector $configCollector)
{
$this->editableLoader = $editableLoader;
$this->editmodeResolver = $editmodeResolver;
$this->configCollector = $configCollector;
}
/**
* @param string $type
*
* @return bool
*/
public function editableExists($type)
{
return $this->editableLoader->supports($type);
}
/**
* @param PageSnippet $document
* @param string $type
* @param string $name
* @param array $config
* @param bool|null $editmode
*
* @return Editable\EditableInterface
*
* @throws \Exception
*/
public function getEditable(PageSnippet $document, string $type, string $name, array $config = [], bool $editmode = null): Editable\EditableInterface
{
$type = strtolower($type);
$originalName = $name;
$name = Editable::buildEditableName($type, $originalName, $document);
$realName = Editable::buildEditableRealName($originalName, $document);
if (null === $editmode) {
$editmode = $this->editmodeResolver->isEditmode();
}
$editable = $document->getEditable($name);
if ($editable instanceof Editable\EditableInterface && $editable->getType() === $type) {
// call the load() method if it exists to reinitialize the data (eg. from serializing, ...)
//TODO Pimcore 11: remove method_exists BC layer
if ($editable instanceof LazyLoadingInterface || method_exists($editable, 'load')) {
if (!$editable instanceof LazyLoadingInterface) {
trigger_deprecation('pimcore/pimcore', '10.3',
sprintf('Usage of method_exists is deprecated since version 10.3 and will be removed in Pimcore 11.' .
'Implement the %s interface instead.', LazyLoadingInterface::class));
}
$editable->load();
}
} else {
$editable = $this->editableLoader->build($type);
$editable->setName($name);
$document->setEditable($editable);
//set default value on initial build
if (isset($config['defaultValue'])) {
$editable->setDataFromResource($config['defaultValue']);
}
}
$editable->setDocument($document);
$editable->setEditmode($editmode);
// set the real name of this editable, without the prefixes and suffixes from blocks and areablocks
$editable->setRealName($realName);
$editable->setConfig($config);
if ($editmode) {
$editable->setEditableDefinitionCollector($this->configCollector);
}
return $editable;
}
/**
* Renders an editable
*
* @param PageSnippet $document
* @param string $type
* @param string $name
* @param array $options
* @param bool|null $editmode
*
* @return mixed
*
* @throws \Exception
*/
public function render(PageSnippet $document, string $type, string $name, array $options = [], bool $editmode = null)
{
return $this->getEditable($document, $type, $name, $options, $editmode);
}
}