[TASK] Move TCA renderings to designated classes
[Packages/TYPO3.CMS.git] / typo3 / sysext / backend / Classes / Form / Element / UserElement.php
1 <?php
2 namespace TYPO3\CMS\Backend\Form\Element;
3
4 /**
5 * This file is part of the TYPO3 CMS project.
6 *
7 * It is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU General Public License, either version 2
9 * of the License, or any later version.
10 *
11 * For the full copyright and license information, please read the
12 * LICENSE.txt file that was distributed with this source code.
13 *
14 * The TYPO3 project - inspiring people to share!
15 */
16
17 /**
18 * Generation of TCEform elements of the type "user"
19 */
20 class UserElement {
21
22 /**
23 * @var \TYPO3\CMS\Backend\Form\FormEngine
24 */
25 protected $formEngine;
26
27 /**
28 * Constructor function, setting the FormEngine
29 *
30 * @param \TYPO3\CMS\Backend\Form\FormEngine $formEngine
31 */
32 public function __construct(\TYPO3\CMS\Backend\Form\FormEngine $formEngine) {
33 $this->formEngine = $formEngine;
34 }
35
36 /**
37 * User defined field type
38 *
39 * @param string $table The table name of the record
40 * @param string $field The field name which this element is supposed to edit
41 * @param array $row The record data array where the value(s) for the field can be found
42 * @param array $additionalInformation An array with additional configuration options.
43 * @return string The HTML code for the TCEform field
44 */
45 public function render($table, $field, $row, &$additionalInformation) {
46 $additionalInformation['table'] = $table;
47 $additionalInformation['field'] = $field;
48 $additionalInformation['row'] = $row;
49 $additionalInformation['parameters'] = isset($additionalInformation['fieldConf']['config']['parameters']) ? $additionalInformation['fieldConf']['config']['parameters'] : array();
50 $additionalInformation['pObj'] = &$this;
51 return \TYPO3\CMS\Core\Utility\GeneralUtility::callUserFunction($additionalInformation['fieldConf']['config']['userFunc'], $additionalInformation, $this);
52 }
53 }