Skip to content
Snippets Groups Projects
PluginRenderer.php 3.92 KiB
Newer Older
Kevin von Spiczak's avatar
Kevin von Spiczak committed
<?php

namespace SGalinski\SgVimeo\Hooks\PageLayoutView;

/***************************************************************
 *  Copyright notice
 *  (c) sgalinski Internet Services (https://www.sgalinski.de)
 *  All rights reserved
 *  This script is part of the TYPO3 project. The TYPO3 project is
 *  free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 3 of the License, or
 *  (at your option) any later version.
 *  The GNU General Public License can be found at
 *  http://www.gnu.org/copyleft/gpl.html.
 *  This script is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *  This copyright notice MUST APPEAR in all copies of the script!
 ***************************************************************/

use SGalinski\SgVimeo\Preview\PreviewService;
Kevin von Spiczak's avatar
Kevin von Spiczak committed
use TYPO3\CMS\Backend\Utility\BackendUtility;
use TYPO3\CMS\Backend\View\PageLayoutView;
use TYPO3\CMS\Backend\View\PageLayoutViewDrawItemHookInterface;
use TYPO3\CMS\Core\Localization\LanguageService;
Kevin von Spiczak's avatar
Kevin von Spiczak committed
use TYPO3\CMS\Core\Utility\GeneralUtility;

/**
 * Class PluginRenderer
 * Renders back-end preview for the SG Vimeo Videos plugin
 *
 * @package SGalinski\SgVimeo\Hooks
 * @deprecated All of this class will be removed when PageLayoutView support is dropped
Kevin von Spiczak's avatar
Kevin von Spiczak committed
 */
class PluginRenderer implements PageLayoutViewDrawItemHookInterface {

	/**
	 * @var PreviewService
	 */
	protected $previewService;

	public function init() {
		$this->previewService = GeneralUtility::makeInstance(PreviewService::class);
	}

Kevin von Spiczak's avatar
Kevin von Spiczak committed
	/**
	 * Preprocesses the preview rendering of a content element of type "sg_vimeo"
	 *
	 * @param PageLayoutView $parentObject Calling parent object
	 * @param bool $drawItem Whether to draw the item using the default functionality
	 * @param string $headerContent Header content
	 * @param string $itemContent Item content
	 * @param array $row Record row of tt_content
	 * @return void
	 * @noinspection ReferencingObjectsInspection
	 * @deprecated All of this class will be removed when TYPO3 10 support is dropped
Kevin von Spiczak's avatar
Kevin von Spiczak committed
	 */
	public function preProcess(
		PageLayoutView &$parentObject,
		&$drawItem,
		&$headerContent,
		&$itemContent,
		array &$row
Kevin von Spiczak's avatar
Kevin von Spiczak committed
	): void {
		$this->init();
		trigger_error(
			'Using the old style of rendering backend previews is deprecated and will not longer work when TYPO3 10'
			. ' support is dropped! Please switch to using the Fluid Based Page Module instead!',
			E_USER_DEPRECATED
		);
Kevin von Spiczak's avatar
Kevin von Spiczak committed
		if ($row['list_type'] === 'sgvimeo_vimeo') {
			$drawItem = FALSE;

			$this->adaptPluginHeaderContent($headerContent, $row);

			$view = $this->previewService->getPluginView($row);
Kevin von Spiczak's avatar
Kevin von Spiczak committed

			$itemContent .= $view->render();
		}
	}

	/**
	 * Adapts the given $headerContent.
	 * To be used in all plugin previews so the Header Contents appear similarly.
	 *
	 * @param string $headerContent
	 * @param array $row
Kevin von Spiczak's avatar
Kevin von Spiczak committed
	 */
	protected function adaptPluginHeaderContent(&$headerContent, $row): void {
		$headerContent = '<h4>' . $this->getPluginNameForHeaderContent(
			(int) $row['pid'],
			$row['list_type']
		) . $headerContent . '</h4>';
Kevin von Spiczak's avatar
Kevin von Spiczak committed
	}

	/**
	 * Finds the label of the given $listType element on the page with the given $pid
	 * and returns it wrapped for use in the backend preview's header content.
	 *
	 * @param int $pid
	 * @param string $listType
	 * @return string
	 */
	protected function getPluginNameForHeaderContent(int $pid, string $listType): string {
		/** @var LanguageService $languageService */
Kevin von Spiczak's avatar
Kevin von Spiczak committed
		$languageService = GeneralUtility::makeInstance(LanguageService::class);

		$pluginName = $languageService->sL(
			BackendUtility::getLabelFromItemListMerged(
				$pid,
				'tt_content',
				'list_type',
				$listType
Kevin von Spiczak's avatar
Kevin von Spiczak committed
			)
		);
		return '<span class="label label-primary">' . $pluginName . '</span>&nbsp;';
	}
}