Your IP : 216.73.217.95


Current Path : /var/www/surf/TYPO3/vendor/typo3/cms-backend/Classes/Preview/
Upload File :
Current File : /var/www/surf/TYPO3/vendor/typo3/cms-backend/Classes/Preview/PreviewRendererInterface.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!
 */

namespace TYPO3\CMS\Backend\Preview;

use TYPO3\CMS\Backend\View\BackendLayout\Grid\GridColumnItem;

/**
 * Interface PreviewRendererInterface
 *
 * Contract for classes capable of rendering previews of a given record
 * from a table. Responsible for rendering preview header, preview content
 * and wrapping of those two values.
 *
 * Responsibilities are segmented into three methods, one for each responsibility,
 * which is done in order to allow overriding classes to change those parts
 * individually without having to replace other parts. Rather than relying on
 * implementations to be friendly and divide code into smaller pieces and
 * give them (at least) protected visibility, the key methods are instead required
 * on the interface directly.
 *
 * Callers are then responsible for calling each method and combining/wrapping
 * the output appropriately.
 */
interface PreviewRendererInterface
{
    /**
     * Dedicated method for rendering preview header HTML for
     * the page module only. Receives the the GridColumnItem
     * that contains the record for which a preview header
     * should be rendered and returned.
     */
    public function renderPageModulePreviewHeader(GridColumnItem $item): string;

    /**
     * Dedicated method for rendering preview body HTML for
     * the page module only. Receives the the GridColumnItem
     * that contains the record for which a preview should be
     * rendered and returned.
     */
    public function renderPageModulePreviewContent(GridColumnItem $item): string;

    /**
     * Render a footer for the record to display in page module below
     * the body of the item's preview.
     */
    public function renderPageModulePreviewFooter(GridColumnItem $item): string;

    /**
     * Dedicated method for wrapping a preview header and body
     * HTML. Receives $item, an instance of GridColumnItem holding
     * among other things the record, which can be used to determine
     * appropriate wrapping.
     */
    public function wrapPageModulePreview(string $previewHeader, string $previewContent, GridColumnItem $item): string;
}