- <?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\Model\Document\Editable;
- use Pimcore\Document\Editable\Block\BlockName;
- use Pimcore\Document\Editable\EditableHandler;
- use Pimcore\Extension\Document\Areabrick\AreabrickManagerInterface;
- use Pimcore\Extension\Document\Areabrick\EditableDialogBoxInterface;
- use Pimcore\Model;
- use Pimcore\Templating\Renderer\EditableRenderer;
- use Pimcore\Tool\HtmlUtils;
- use Pimcore\Tool\Serialize;
- /**
-  * @method \Pimcore\Model\Document\Editable\Dao getDao()
-  */
- class Area extends Model\Document\Editable
- {
-     /**
-      * The Type configured for the area
-      *
-      * @internal
-      *
-      * @var string|null
-      */
-     protected $type;
-     /**
-      * {@inheritdoc}
-      */
-     public function getBrickType()
-     {
-         return $this->type;
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function getType()
-     {
-         return 'area';
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function getData()
-     {
-         return [
-             'type' => $this->type,
-         ];
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function getDataForResource()
-     {
-         return [
-             'type' => $this->type,
-         ];
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function getDataEditmode() /** : mixed */
-     {
-         return [
-             'type' => $this->type,
-         ];
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function admin()
-     {
-         $attributes = $this->getEditmodeElementAttributes();
-         $attributeString = HtmlUtils::assembleAttributeString($attributes);
-         $this->outputEditmode('<div ' . $attributeString . '>');
-         $this->frontend();
-         $this->outputEditmode('</div>');
-     }
-     /**
-      * @param array $config
-      * @param EditableRenderer $editableRenderer
-      * @param string $dialogId
-      */
-     private function renderDialogBoxEditables(array $config, EditableRenderer $editableRenderer, string $dialogId)
-     {
-         if (isset($config['items']) && is_array($config['items'])) {
-             // layout component
-             foreach ($config['items'] as $child) {
-                 $this->renderDialogBoxEditables($child, $editableRenderer, $dialogId);
-             }
-         } elseif (isset($config['name']) && isset($config['type'])) {
-             $editable = $editableRenderer->getEditable($this->getDocument(), $config['type'], $config['name'], $config['config'] ?? []);
-             if (!$editable instanceof Model\Document\Editable) {
-                 throw new \Exception(sprintf('Invalid editable type "%s" configured for Dialog Box', $config['type']));
-             }
-             $editable->setInDialogBox($dialogId);
-             $editable->addConfig('dialogBoxConfig', $config);
-             $this->outputEditmode($editable->render());
-         } elseif (is_array($config) && isset($config[0])) {
-             foreach ($config as $item) {
-                 $this->renderDialogBoxEditables($item, $editableRenderer, $dialogId);
-             }
-         }
-     }
-     private function buildInfoObject(): Area\Info
-     {
-         $config = $this->getConfig();
-         // create info object and assign it to the view
-         $info = new Area\Info();
-         $info->setId($config['type']);
-         $info->setEditable($this);
-         $info->setIndex(0);
-         $params = [];
-         if (is_array($config['params'][$config['type']] ?? null)) {
-             $params = $config['params'][$config['type']];
-         }
-         if (is_array($config['globalParams'] ?? null)) {
-             $params = array_merge($config['globalParams'], $params);
-         }
-         $info->setParams($params);
-         return $info;
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function frontend()
-     {
-         $config = $this->getConfig();
-         // TODO inject area handler via DI when editables are built by container
-         $editableHandler = \Pimcore::getContainer()->get(EditableHandler::class);
-         // don't show disabled bricks
-         if (!$editableHandler->isBrickEnabled($this, $config['type'] && ($config['dontCheckEnabled'] ?? false) !== true)) {
-             return;
-         }
-         // push current block name
-         $blockState = $this->getBlockState();
-         $blockState->pushBlock(BlockName::createFromEditable($this));
-         // create info object and assign it to the view
-         $info = $this->buildInfoObject();
-         // start at first index
-         $blockState->pushIndex(1);
-         $areabrickManager = \Pimcore::getContainer()->get(AreabrickManagerInterface::class);
-         $dialogConfig = null;
-         $brick = $areabrickManager->getBrick($this->config['type']);
-         $info = $this->buildInfoObject();
-         if ($this->getEditmode() && $brick instanceof EditableDialogBoxInterface) {
-             $dialogConfig = $brick->getEditableDialogBoxConfiguration($this, $info);
-             if ($dialogConfig->getItems()) {
-                 $dialogConfig->setId('dialogBox-' . $this->getName());
-             } else {
-                 $dialogConfig = null;
-             }
-         }
-         if ($dialogConfig) {
-             $attributes = $this->getEditmodeElementAttributes();
-             $dialogAttributes = [
-                 'data-dialog-id' => $dialogConfig->getId(),
-             ];
-             $dialogAttributes = HtmlUtils::assembleAttributeString($dialogAttributes);
-             $this->outputEditmode('<div class="pimcore_area_dialog" data-name="' . $attributes['data-name'] . '" data-real-name="' . $attributes['data-real-name'] . '" ' . $dialogAttributes . '></div>');
-         }
-         $params = [];
-         if (isset($config['params']) && is_array($config['params']) && array_key_exists($config['type'], $config['params'])) {
-             if (is_array($config['params'][$config['type']])) {
-                 $params = $config['params'][$config['type']];
-             }
-         }
-         $info->setParams($params);
-         if ($dialogConfig) {
-             $editableRenderer = \Pimcore::getContainer()->get(EditableRenderer::class);
-             $this->outputEditmode('<template id="dialogBoxConfig-' . $dialogConfig->getId() . '">' . \json_encode($dialogConfig) . '</template>');
-             $this->renderDialogBoxEditables($dialogConfig->getItems(), $editableRenderer, $dialogConfig->getId());
-         }
-         echo $editableHandler->renderAreaFrontend($info);
-         // remove current block and index from stack
-         $blockState->popIndex();
-         $blockState->popBlock();
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function setDataFromResource($data)
-     {
-         if (strlen($data) > 2) {
-             $data = Serialize::unserialize($data);
-         }
-         $this->type = $data['type'] ?? null;
-         return $this;
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function setDataFromEditmode($data)
-     {
-         if (is_array($data)) {
-             $this->type = $data['type'] ?? null;
-         }
-         return $this;
-     }
-     /**
-      * {@inheritdoc}
-      */
-     public function isEmpty()
-     {
-         return false;
-     }
-     /**
-      * Gets an element from the referenced brick. E.g. if you have an area "myArea" which defines "gallery-single-images"
-      * as used areabrick and this areabrick defines a block "gallery", you can use $area->getElement('gallery') to get
-      * an instance of the block element.
-      *
-      * @param string $name
-      *
-      * @return Model\Document\Editable
-      */
-     public function getElement(string $name)
-     {
-         $document = $this->getDocument();
-         $parentBlockNames = $this->getParentBlockNames();
-         $parentBlockNames[] = $this->getName();
-         $id = Model\Document\Editable::buildChildEditableName($name, 'area', $parentBlockNames, 1);
-         $editable = $document->getEditable($id);
-         if ($editable) {
-             $editable->setParentBlockNames($parentBlockNames);
-         }
-         return $editable;
-     }
- }
-