[CLEANUP] Use Permission constants consistently
[Packages/TYPO3.CMS.git] / typo3 / sysext / backend / Classes / Tree / View / BrowseTreeView.php
1 <?php
2 namespace TYPO3\CMS\Backend\Tree\View;
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 use TYPO3\CMS\Backend\Utility\BackendUtility;
18 use TYPO3\CMS\Core\Database\ConnectionPool;
19 use TYPO3\CMS\Core\Type\Bitmask\Permission;
20 use TYPO3\CMS\Core\Utility\GeneralUtility;
21
22 /**
23 * Generate a page-tree, browsable.
24 */
25 class BrowseTreeView extends AbstractTreeView
26 {
27 /**
28 * @var array
29 */
30 public $fieldArray = [
31 'uid',
32 'pid',
33 'title',
34 'doktype',
35 'nav_title',
36 'mount_pid',
37 'php_tree_stop',
38 't3ver_id',
39 't3ver_state',
40 'hidden',
41 'starttime',
42 'endtime',
43 'fe_group',
44 'module',
45 'extendToSubpages',
46 'nav_hide',
47 't3ver_wsid',
48 't3ver_move_id',
49 'is_siteroot'
50 ];
51
52 /**
53 * override to use this treeName
54 * @var string
55 */
56 public $treeName = 'browsePages';
57
58 /**
59 * override to use this table
60 * @var string
61 */
62 public $table = 'pages';
63
64 /**
65 * override to use this domIdPrefix
66 * @var string
67 */
68 public $domIdPrefix = 'pages';
69
70 /**
71 * @var bool
72 */
73 public $ext_showNavTitle = false;
74
75 /**
76 * Initialize, setting what is necessary for browsing pages.
77 * Using the current user.
78 *
79 * @param string $clause Additional clause for selecting pages.
80 * @param string $orderByFields record ORDER BY field
81 */
82 public function init($clause = '', $orderByFields = '')
83 {
84 // This will hide records from display - it has nothing to do with user rights!!
85 $clauseExcludePidList = '';
86 if ($pidList = $this->getBackendUser()->getTSConfigVal('options.hideRecords.pages')) {
87 if ($pidList = implode(',', GeneralUtility::intExplode(',', $pidList))) {
88 $clauseExcludePidList = ' AND pages.uid NOT IN (' . $pidList . ')';
89 }
90 }
91 // This is very important for making trees of pages: Filtering out deleted pages, pages with no access to and sorting them correctly:
92 parent::init(' AND ' . $this->getBackendUser()->getPagePermsClause(Permission::PAGE_SHOW) . ' ' . $clause . $clauseExcludePidList, 'sorting');
93 $this->title = $GLOBALS['TYPO3_CONF_VARS']['SYS']['sitename'];
94 $this->MOUNTS = $this->getBackendUser()->returnWebmounts();
95 if ($pidList) {
96 // Remove mountpoint if explicitly set in options.hideRecords.pages (see above)
97 $hideList = explode(',', $pidList);
98 $this->MOUNTS = array_diff($this->MOUNTS, $hideList);
99 }
100 }
101
102 /**
103 * Creates title attribute content for pages.
104 * Uses API function in \TYPO3\CMS\Backend\Utility\BackendUtility which will retrieve lots of useful information for pages.
105 *
106 * @param array $row The table row.
107 * @return string
108 */
109 public function getTitleAttrib($row)
110 {
111 return BackendUtility::titleAttribForPages($row, '1=1 ' . $this->clause, 0);
112 }
113
114 /**
115 * Wrapping the image tag, $icon, for the row, $row (except for mount points)
116 *
117 * @param string $icon The image tag for the icon
118 * @param array $row The row for the current element
119 * @return string The processed icon input value.
120 * @access private
121 */
122 public function wrapIcon($icon, $row)
123 {
124 // Wrap icon in click-menu link.
125 $theIcon = '';
126 if (!$this->ext_IconMode) {
127 $theIcon = BackendUtility::wrapClickMenuOnIcon($icon, $this->treeName, $this->getId($row), 0);
128 } elseif ($this->ext_IconMode === 'titlelink') {
129 $aOnClick = 'return jumpTo(' . GeneralUtility::quoteJSvalue($this->getJumpToParam($row)) . ',this,'
130 . GeneralUtility::quoteJSvalue($this->domIdPrefix . $this->getId($row)) . ',' . $this->bank . ');';
131 $theIcon = '<a href="#" onclick="' . htmlspecialchars($aOnClick) . '">' . $icon . '</a>';
132 }
133 return $theIcon;
134 }
135
136 /**
137 * Returns the title for the input record. If blank, a "no title" label (localized) will be returned.
138 * Do NOT htmlspecialchar the string from this function - has already been done.
139 *
140 * @param array $row The input row array (where the key "title" is used for the title)
141 * @param int $titleLen Title length (30)
142 * @return string The title.
143 */
144 public function getTitleStr($row, $titleLen = 30)
145 {
146 if ($this->ext_showNavTitle && isset($row['nav_title']) && trim($row['nav_title']) !== '') {
147 $title = parent::getTitleStr(['title' => $row['nav_title']], $titleLen);
148 } else {
149 $title = parent::getTitleStr($row, $titleLen);
150 }
151 if (!empty($row['is_siteroot']) && $this->getBackendUser()->getTSConfigVal('options.pageTree.showDomainNameWithTitle')) {
152 $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable('sys_domain');
153 $row = $queryBuilder
154 ->select('domainName', 'sorting')
155 ->from('sys_domain')
156 ->where(
157 $queryBuilder->expr()->eq(
158 'pid',
159 $queryBuilder->createNamedParameter($row['uid'], \PDO::PARAM_INT)
160 )
161 )
162 ->orderBy('sorting')
163 ->setMaxResults(1)
164 ->execute()
165 ->fetch();
166
167 if ($row !== false) {
168 $title = sprintf('%s [%s]', $title, htmlspecialchars($row['domainName']));
169 }
170 }
171 return $title;
172 }
173 }