vendor/contao/core-bundle/src/Resources/contao/elements/ContentElement.php line 283

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of Contao.
  4.  *
  5.  * (c) Leo Feyer
  6.  *
  7.  * @license LGPL-3.0-or-later
  8.  */
  9. namespace Contao;
  10. use Contao\Model\Collection;
  11. /**
  12.  * Parent class for content elements.
  13.  *
  14.  * @property integer $id
  15.  * @property integer $pid
  16.  * @property string  $ptable
  17.  * @property integer $sorting
  18.  * @property integer $tstamp
  19.  * @property string  $type
  20.  * @property string  $headline
  21.  * @property string  $text
  22.  * @property boolean $addImage
  23.  * @property boolean $inline
  24.  * @property boolean $overwriteMeta
  25.  * @property string  $singleSRC
  26.  * @property string  $alt
  27.  * @property string  $title
  28.  * @property string  $size
  29.  * @property string  $imagemargin
  30.  * @property string  $imageUrl
  31.  * @property boolean $fullsize
  32.  * @property string  $caption
  33.  * @property string  $floating
  34.  * @property string  $html
  35.  * @property string  $listtype
  36.  * @property string  $listitems
  37.  * @property string  $tableitems
  38.  * @property string  $summary
  39.  * @property boolean $thead
  40.  * @property boolean $tfoot
  41.  * @property boolean $tleft
  42.  * @property boolean $sortable
  43.  * @property integer $sortIndex
  44.  * @property string  $sortOrder
  45.  * @property string  $mooHeadline
  46.  * @property string  $mooStyle
  47.  * @property string  $mooClasses
  48.  * @property string  $highlight
  49.  * @property string  $code
  50.  * @property string  $url
  51.  * @property boolean $target
  52.  * @property boolean $overwriteLink
  53.  * @property string  $titleText
  54.  * @property string  $linkTitle
  55.  * @property string  $embed
  56.  * @property string  $rel
  57.  * @property boolean $useImage
  58.  * @property string  $multiSRC
  59.  * @property string  $orderSRC
  60.  * @property boolean $useHomeDir
  61.  * @property integer $perRow
  62.  * @property integer $perPage
  63.  * @property integer $numberOfItems
  64.  * @property string  $sortBy
  65.  * @property boolean $metaIgnore
  66.  * @property string  $galleryTpl
  67.  * @property string  $customTpl
  68.  * @property string  $playerSRC
  69.  * @property string  $youtube
  70.  * @property string  $vimeo
  71.  * @property string  $posterSRC
  72.  * @property string  $playerSize
  73.  * @property array   $playerOptions
  74.  * @property string  $playerPreload
  75.  * @property integer $playerStart
  76.  * @property integer $playerStop
  77.  * @property string  $playerCaption
  78.  * @property string  $playerAspect
  79.  * @property string  $playerColor
  80.  * @property array   $youtubeOptions
  81.  * @property array   $vimeoOptions
  82.  * @property boolean $splashImage
  83.  * @property integer $sliderDelay
  84.  * @property integer $sliderSpeed
  85.  * @property integer $sliderStartSlide
  86.  * @property boolean $sliderContinuous
  87.  * @property integer $cteAlias
  88.  * @property integer $articleAlias
  89.  * @property integer $article
  90.  * @property integer $form
  91.  * @property integer $module
  92.  * @property boolean $protected
  93.  * @property string  $groups
  94.  * @property boolean $guests
  95.  * @property string  $cssID
  96.  * @property boolean $invisible
  97.  * @property string  $start
  98.  * @property string  $stop
  99.  * @property string  $com_order
  100.  * @property integer $com_perPage
  101.  * @property boolean $com_moderate
  102.  * @property boolean $com_bbcode
  103.  * @property boolean $com_disableCaptcha
  104.  * @property boolean $com_requireLogin
  105.  * @property string  $com_template
  106.  * @property string  $classes
  107.  * @property string  $typePrefix
  108.  * @property integer $origId
  109.  * @property string  $hl
  110.  *
  111.  * @author Leo Feyer <https://github.com/leofeyer>
  112.  */
  113. abstract class ContentElement extends Frontend
  114. {
  115.     /**
  116.      * Template
  117.      * @var string
  118.      */
  119.     protected $strTemplate;
  120.     /**
  121.      * Column
  122.      * @var string
  123.      */
  124.     protected $strColumn;
  125.     /**
  126.      * Model
  127.      * @var ContentModel
  128.      */
  129.     protected $objModel;
  130.     /**
  131.      * Current record
  132.      * @var array
  133.      */
  134.     protected $arrData = array();
  135.     /**
  136.      * Style array
  137.      * @var array
  138.      */
  139.     protected $arrStyle = array();
  140.     /**
  141.      * Initialize the object
  142.      *
  143.      * @param ContentModel $objElement
  144.      * @param string       $strColumn
  145.      */
  146.     public function __construct($objElement$strColumn='main')
  147.     {
  148.         if ($objElement instanceof Model || $objElement instanceof Collection)
  149.         {
  150.             /** @var ContentModel $objModel */
  151.             $objModel $objElement;
  152.             if ($objModel instanceof Collection)
  153.             {
  154.                 $objModel $objModel->current();
  155.             }
  156.             $this->objModel $objModel;
  157.         }
  158.         parent::__construct();
  159.         $this->arrData $objElement->row();
  160.         $this->cssID StringUtil::deserialize($objElement->cssIDtrue);
  161.         if ($this->customTpl)
  162.         {
  163.             $request System::getContainer()->get('request_stack')->getCurrentRequest();
  164.             // Use the custom template unless it is a back end request
  165.             if (!$request || !System::getContainer()->get('contao.routing.scope_matcher')->isBackendRequest($request))
  166.             {
  167.                 $this->strTemplate $this->customTpl;
  168.             }
  169.         }
  170.         $arrHeadline StringUtil::deserialize($objElement->headline);
  171.         $this->headline = \is_array($arrHeadline) ? $arrHeadline['value'] : $arrHeadline;
  172.         $this->hl = \is_array($arrHeadline) ? $arrHeadline['unit'] : 'h1';
  173.         $this->strColumn $strColumn;
  174.     }
  175.     /**
  176.      * Set an object property
  177.      *
  178.      * @param string $strKey
  179.      * @param mixed  $varValue
  180.      */
  181.     public function __set($strKey$varValue)
  182.     {
  183.         $this->arrData[$strKey] = $varValue;
  184.     }
  185.     /**
  186.      * Return an object property
  187.      *
  188.      * @param string $strKey
  189.      *
  190.      * @return mixed
  191.      */
  192.     public function __get($strKey)
  193.     {
  194.         return $this->arrData[$strKey] ?? parent::__get($strKey);
  195.     }
  196.     /**
  197.      * Check whether a property is set
  198.      *
  199.      * @param string $strKey
  200.      *
  201.      * @return boolean
  202.      */
  203.     public function __isset($strKey)
  204.     {
  205.         return isset($this->arrData[$strKey]);
  206.     }
  207.     /**
  208.      * Return the model
  209.      *
  210.      * @return Model
  211.      */
  212.     public function getModel()
  213.     {
  214.         return $this->objModel;
  215.     }
  216.     /**
  217.      * Parse the template
  218.      *
  219.      * @return string
  220.      */
  221.     public function generate()
  222.     {
  223.         if ($this->isHidden())
  224.         {
  225.             return '';
  226.         }
  227.         $this->Template = new FrontendTemplate($this->strTemplate);
  228.         $this->Template->setData($this->arrData);
  229.         $this->compile();
  230.         // Do not change this order (see #6191)
  231.         $this->Template->style = !empty($this->arrStyle) ? implode(' '$this->arrStyle) : '';
  232.         $this->Template->class trim('ce_' $this->type ' ' . ($this->cssID[1] ?? ''));
  233.         $this->Template->cssID = !empty($this->cssID[0]) ? ' id="' $this->cssID[0] . '"' '';
  234.         $this->Template->inColumn $this->strColumn;
  235.         if (!$this->Template->headline)
  236.         {
  237.             $this->Template->headline $this->headline;
  238.         }
  239.         if (!$this->Template->hl)
  240.         {
  241.             $this->Template->hl $this->hl;
  242.         }
  243.         if (!empty($this->objModel->classes) && \is_array($this->objModel->classes))
  244.         {
  245.             $this->Template->class .= ' ' implode(' '$this->objModel->classes);
  246.         }
  247.         // Tag the content element (see #2137)
  248.         if (System::getContainer()->has('fos_http_cache.http.symfony_response_tagger'))
  249.         {
  250.             $responseTagger System::getContainer()->get('fos_http_cache.http.symfony_response_tagger');
  251.             $responseTagger->addTags(array('contao.db.tl_content.' $this->id));
  252.         }
  253.         return $this->Template->parse();
  254.     }
  255.     protected function isHidden()
  256.     {
  257.         // Skip unsaved elements (see #2708)
  258.         if (isset($this->tstamp) && !$this->tstamp)
  259.         {
  260.             return true;
  261.         }
  262.         $isInvisible $this->invisible || ($this->start && $this->start time()) || ($this->stop && $this->stop <= time());
  263.         // The element is visible, so show it
  264.         if (!$isInvisible)
  265.         {
  266.             return false;
  267.         }
  268.         $tokenChecker System::getContainer()->get('contao.security.token_checker');
  269.         // Preview mode is enabled, so show the element
  270.         if ($tokenChecker->hasBackendUser() && $tokenChecker->isPreviewMode())
  271.         {
  272.             return false;
  273.         }
  274.         $request System::getContainer()->get('request_stack')->getCurrentRequest();
  275.         // We are in the back end, so show the element
  276.         if ($request && System::getContainer()->get('contao.routing.scope_matcher')->isBackendRequest($request))
  277.         {
  278.             return false;
  279.         }
  280.         return true;
  281.     }
  282.     /**
  283.      * Compile the content element
  284.      */
  285.     abstract protected function compile();
  286.     /**
  287.      * Find a content element in the TL_CTE array and return the class name
  288.      *
  289.      * @param string $strName The content element name
  290.      *
  291.      * @return string The class name
  292.      */
  293.     public static function findClass($strName)
  294.     {
  295.         foreach ($GLOBALS['TL_CTE'] as $v)
  296.         {
  297.             foreach ($v as $kk=>$vv)
  298.             {
  299.                 if ($kk == $strName)
  300.                 {
  301.                     return $vv;
  302.                 }
  303.             }
  304.         }
  305.         return '';
  306.     }
  307. }
  308. class_alias(ContentElement::class, 'ContentElement');