[TASK] Remove require statements for classes
[Packages/TYPO3.CMS.git] / typo3 / alt_doc_nodoc.php
1 <?php
2 /***************************************************************
3 * Copyright notice
4 *
5 * (c) 1999-2011 Kasper Skårhøj (kasperYYYY@typo3.com)
6 * All rights reserved
7 *
8 * This script is part of the TYPO3 project. The TYPO3 project is
9 * free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * The GNU General Public License can be found at
15 * http://www.gnu.org/copyleft/gpl.html.
16 * A copy is found in the textfile GPL.txt and important notices to the license
17 * from the author is found in LICENSE.txt distributed with these scripts.
18 *
19 *
20 * This script is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
24 *
25 * This copyright notice MUST APPEAR in all copies of the script!
26 ***************************************************************/
27
28 /**
29 * No-document script
30 * This is used by eg. the Doc module if no documents is registered as "open"
31 * (a concept which is better known from the "classic backend"...)
32 *
33 * Revised for TYPO3 3.6 November/2003 by Kasper Skårhøj
34 * XHTML compliant
35 *
36 * @author Kasper Skårhøj <kasperYYYY@typo3.com>
37 */
38
39 require('init.php');
40 $LANG->includeLLFile('EXT:lang/locallang_alt_doc.xml');
41
42 require_once(t3lib_extMgm::extPath('opendocs') . 'class.tx_opendocs.php');
43
44 /**
45 * Script Class for the "No-doc" display; This shows most recently edited records.
46 *
47 * @author Kasper Skårhøj <kasperYYYY@typo3.com>
48 * @package TYPO3
49 * @subpackage core
50 */
51 class SC_alt_doc_nodoc {
52
53 // Internal:
54 // Content accumulation
55 var $content;
56
57 /**
58 * Document template object
59 *
60 * @var mediumDoc
61 */
62 var $doc;
63
64 /**
65 * Object for backend modules.
66 *
67 * @var t3lib_loadModules
68 */
69 var $loadModules;
70
71 /**
72 * Constructor, initialize.
73 *
74 * @return void
75 */
76 function init() {
77 // Start the template object:
78 $this->doc = t3lib_div::makeInstance('mediumDoc');
79 $this->doc->bodyTagMargins['x'] = 5;
80 $this->doc->bodyTagMargins['y'] = 5;
81 $this->doc->backPath = $GLOBALS['BACK_PATH'];
82
83 // Add JS
84 $this->doc->JScode = $this->doc->wrapScriptTags('
85 function jump(url, modName, mainModName) {
86 // clear information about which entry in nav. tree that might have been highlighted.
87 top.fsMod.navFrameHighlightedID = [];
88
89 if (top.content && top.content.nav_frame && top.content.nav_frame.refresh_nav) {
90 top.content.nav_frame.refresh_nav();
91 }
92
93 top.nextLoadModuleUrl = url;
94 top.goToModule(modName);
95 }
96 ');
97
98 // Start the page:
99 $this->content = '';
100 $this->content .= $this->doc->startPage('TYPO3 Edit Document');
101
102 // Loads the backend modules available for the logged in user.
103 $this->loadModules = t3lib_div::makeInstance('t3lib_loadModules');
104 $this->loadModules->load($GLOBALS['TBE_MODULES']);
105 }
106
107 /**
108 * Rendering the content.
109 *
110 * @return void
111 */
112 function main() {
113 $msg = array();
114
115 // Add a message, telling that no documents were open...
116 $msg[] = '<p>' . $GLOBALS['LANG']->getLL('noDocuments_msg', 1) . '</p><br />';
117
118 // If another page module was specified, replace the default Page module with the new one
119 $newPageModule = trim($GLOBALS['BE_USER']->getTSConfigVal('options.overridePageModule'));
120 $pageModule = t3lib_BEfunc::isModuleSetInTBE_MODULES($newPageModule) ? $newPageModule : 'web_layout';
121
122 // Perform some acccess checks:
123 $a_wl = $GLOBALS['BE_USER']->check('modules', 'web_list');
124 $a_wp = t3lib_extMgm::isLoaded('cms') && $GLOBALS['BE_USER']->check('modules', $pageModule);
125
126
127 // Finding module images: PAGE
128 $imgFile = $GLOBALS['LANG']->moduleLabels['tabs_images']['web_layout_tab'];
129 $imgInfo = @getimagesize($imgFile);
130 $img_web_layout = is_array($imgInfo) ? '<img src="../'.substr($imgFile, strlen(PATH_site)).'" '.$imgInfo[3].' alt="" />' : '';
131
132 // Finding module images: LIST
133 $imgFile = $GLOBALS['LANG']->moduleLabels['tabs_images']['web_list_tab'];
134 $imgInfo = @getimagesize($imgFile);
135 $img_web_list = is_array($imgInfo) ? '<img src="../'.substr($imgFile, strlen(PATH_site)).'" '.$imgInfo[3].' alt="" />' : '';
136
137 // If either the Web>List OR Web>Page module are active, show the little message with links to those modules:
138 if ($a_wl || $a_wp) {
139 $msg_2 = array();
140 // Web>Page:
141 if ($a_wp) {
142 $msg_2[] = '<strong><a href="#" onclick="top.goToModule(\'' . $pageModule . '\'); return false;">' . $GLOBALS['LANG']->getLL('noDocuments_pagemodule', 1) . $img_web_layout . '</a></strong>';
143 if ($a_wl) {
144 $msg_2[] = $GLOBALS['LANG']->getLL('noDocuments_OR');
145 }
146 }
147 // Web>List
148 if ($a_wl) {
149 $msg_2[] = '<strong><a href="#" onclick="top.goToModule(\'web_list\'); return false;">' . $GLOBALS['LANG']->getLL('noDocuments_listmodule', 1) . $img_web_list . '</a></strong>';
150 }
151 $msg[] = '<p>' . sprintf($GLOBALS['LANG']->getLL('noDocuments_msg2', 1), implode(' ', $msg_2)) . '</p><br />';
152 }
153
154 // Display the list of the most recently edited documents:
155 $modObj = t3lib_div::makeInstance('tx_opendocs');
156 $msg[] = '<p>' . $GLOBALS['LANG']->getLL('noDocuments_msg3', TRUE) . '</p><br />' . $modObj->renderMenu();
157
158 // Adding the content:
159 $this->content .= $this->doc->section($GLOBALS['LANG']->getLL('noDocuments'), implode(' ', $msg), 0, 1);
160 }
161
162 /**
163 * Printing the content.
164 *
165 * @return void
166 */
167 function printContent() {
168 $this->content .= $this->doc->endPage();
169 $this->content = $this->doc->insertStylesAndJS($this->content);
170 echo $this->content;
171 }
172 }
173
174 // Make instance:
175 $SOBE = t3lib_div::makeInstance('SC_alt_doc_nodoc');
176 $SOBE->init();
177 $SOBE->main();
178 $SOBE->printContent();
179
180 ?>