[TASK] Remove old login labels
[Packages/TYPO3.CMS.git] / typo3 / view_help.php
old mode 100755 (executable)
new mode 100644 (file)
index 105fc01..777cb57
@@ -1,22 +1,22 @@
 <?php
 /***************************************************************
 *  Copyright notice
-*  
-*  (c) 1999-2003 Kasper Skaarhoj (kasper@typo3.com)
+*
+*  (c) 1999-2011 Kasper Skårhøj (kasperYYYY@typo3.com)
 *  All rights reserved
 *
-*  This script is part of the TYPO3 project. The TYPO3 project is 
+*  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 2 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.
-*  A copy is found in the textfile GPL.txt and important notices to the license 
+*  A copy is found in the textfile GPL.txt and important notices to the license
 *  from the author is found in LICENSE.txt distributed with these scripts.
 *
-* 
+*
 *  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
 *
 *  This copyright notice MUST APPEAR in all copies of the script!
 ***************************************************************/
-/** 
+/**
  * Document for viewing the online help texts, also known as TCA_DESCR.
  * See Inside TYPO3 for details.
  *
- * $Id$
- * Revised for TYPO3 3.6 2/2003 by Kasper Skaarhoj
+ * Revised for TYPO3 3.7 5/2004 by Kasper Skårhøj
  * XHTML-trans compliant
  *
- * @author     Kasper Skaarhoj <kasper@typo3.com>
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
  */
+
+require('init.php');
+require('template.php');
+$GLOBALS['LANG']->includeLLFile('EXT:lang/locallang_view_help.xml');
+
+
 /**
- * [CLASS/FUNCTION INDEX of SCRIPT]
- *
- *
- *
- *   78: class SC_view_help 
- *   97:     function init()   
- *  119:     function main()   
- *  173:     function printContent()   
- *  184:     function make_seeAlso($value,$anchorTable='')     
- *  222:     function printImage($image,$descr)        
- *  244:     function headerLine($str,$type=0) 
- *  265:     function prepareContent($str)     
- *  280:     function printItem($table,$field,$anchors=0)      
- *  316:     function getTableFieldNames($table,$field)        
- *
- * TOTAL FUNCTIONS: 9
- * (This index is automatically created/updated by the extension "extdeveval")
+ * Extension of the parse_html class.
  *
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
+ * @package TYPO3
+ * @subpackage core
  */
+class local_t3lib_parsehtml extends t3lib_parsehtml {
 
-require ('init.php');
-require ('template.php');
-include ('sysext/lang/locallang_view_help.php');
-
-
+       /**
+        * Processing content between tags for HTML_cleaner
+        *
+        * @param       string          The value
+        * @param       integer         Direction, either -1 or +1. 0 (zero) means no change to input value.
+        * @param       mixed           Not used, ignore.
+        * @return      string          The processed value.
+        * @access private
+        */
+       function processContent($value,$dir,$conf)      {
+               $value = $this->pObj->substituteGlossaryWords_htmlcleaner_callback($value);
 
+               return $value;
+       }
+}
 
 
 
@@ -70,173 +72,519 @@ include ('sysext/lang/locallang_view_help.php');
 
 /**
  * Script Class for rendering the Context Sensitive Help documents, either the single display in the small pop-up window or the full-table view in the larger window.
- * 
- * @author     Kasper Skaarhoj <kasper@typo3.com>
+ *
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
  * @package TYPO3
  * @subpackage core
  */
 class SC_view_help {
        var $allowedHTML = '<strong><em><b><i>';
 
-       var $content;   // Content accumulation.
-
                // For these vars, see init()
-       var $limitAccess;       // If set access to fields and tables is checked. Should be done for true database tables.
+       var $limitAccess;       // If set access to fields and tables is checked. Should be done for TRUE database tables.
        var $table;                     // The "table" key
        var $field;                     // The "field" key
-       
+               /**
+                * Key used to point to the right CSH resource
+                * In simple cases, is equal to $table
+                *
+                * @var string
+                */
+       protected $mainKey;
+
                // Internal, static: GPvar:
        var $tfID;                      // Table/FIeld id.
+       var $ffID;                      // Flexform file/field information
        var $back;                      // Back (previous tfID)
-       
+       var $renderALL;         // If set, then in TOC mode the FULL manual will be printed as well!
+
+               // Internal, dynamic:
+       var $content;   // Content accumulation.
+       var $glossaryWords;             // Glossary words
+
+
+
        /**
         * Initialize the class for various input etc.
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function init() {
-               global $LANG;
-               
+
                        // Setting GPvars:
-               $this->tfID = t3lib_div::GPvar('tfID');
-               $this->back = t3lib_div::GPvar('back');
+               $this->tfID = t3lib_div::_GP('tfID');
+                       // Sanitizes the tfID using whitelisting.
+               if (!preg_match('/^[a-zA-Z0-9_\-\.\*]*$/', $this->tfID)) {
+                       $this->tfID = '';
+               }
+               if (!$this->tfID) {
+                       if (($this->ffID = t3lib_div::_GP('ffID'))) {
+                               $this->ffID = unserialize(base64_decode($this->ffID));
+                       }
+               }
+               $this->back = t3lib_div::_GP('back');
+               $this->renderALL = t3lib_div::_GP('renderALL');
 
                        // Set internal table/field to the parts of "tfID" incoming var.
-               list($this->table,$this->field)=explode('.',$this->tfID);
+               $identifierParts = explode('.', $this->tfID);
+                       // The table is the first item
+               $this->table = array_shift($identifierParts);
+               $this->mainKey = $this->table;
+                       // The field is the second one
+               $this->field = array_shift($identifierParts);
+                       // There may be extra parts for FlexForms
+               if (count($identifierParts) > 0) {
+                               // There's at least one extra part
+                       $extraIdentifierInformation = array();
+                       $extraIdentifierInformation[] = array_shift($identifierParts);
+                               // Load the TCA details of the table
+                       t3lib_div::loadTCA($this->table);
+                               // If the ds_pointerField contains a comma, it means the choice of FlexForm DS
+                               // is determined by 2 parameters. In this case we have an extra identifier part
+                       if (strpos($GLOBALS['TCA'][$this->table]['columns'][$this->field]['config']['ds_pointerField'], ',') !== FALSE) {
+                               $extraIdentifierInformation[] = array_shift($identifierParts);
+                       }
+                               // The remaining parts make up the FlexForm field name itself
+                               // (reassembled with dots)
+                       $flexFormField = implode('.', $identifierParts);
+                               // Assemble a different main key and switch field to use FlexForm field name
+                       $this->mainKey .= '.' . $this->field;
+                       foreach ($extraIdentifierInformation as $extraKey) {
+                               $this->mainKey .= '.' . $extraKey;
+                       }
+                       $this->field = $flexFormField;
+               }
 
-                       // Load descriptions for table $this->table
-               $LANG->loadSingleTableDescription($this->table);
-               
-                       // limitAccess is checked if the $this->table really IS a table.
-               $this->limitAccess = !isset($TCA[$this->table]) ? 0 : 1;
+                       // limitAccess is checked if the $this->table really IS a table (and if the user is NOT a translator who should see all!)
+               $showAllToUser = t3lib_BEfunc::isModuleSetInTBE_MODULES('txllxmltranslateM1') && $GLOBALS['BE_USER']->check('modules','txllxmltranslateM1');
+               $this->limitAccess = isset($GLOBALS['TCA'][$this->table]) ? !$showAllToUser : FALSE;
        }
-       
+
        /**
         * Main function, rendering the display
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function main() {
-               global $BE_USER,$LANG,$TCA_DESCR,$TCA,$TBE_TEMPLATE;
-               
+
                        // Start HTML output accumulation:
-               $TBE_TEMPLATE->docType='xhtml_trans';
-               $TBE_TEMPLATE->divClass='typo3-view-help';
-               $this->content.=$TBE_TEMPLATE->startPage($LANG->getLL('title'));
+               $GLOBALS['TBE_TEMPLATE']->divClass = 'typo3-view-help';
+               $this->content .= $GLOBALS['TBE_TEMPLATE']->startPage($GLOBALS['LANG']->getLL('title'));
 
-                       // If ALL fields is supposed to be shown:               
-               if ($this->field=='*')  {
-                               // Load table TCA
-                       t3lib_div::loadTCA($this->table);
+               if ($this->field == '*') {
+                                // If ALL fields is supposed to be shown:
+                       $this->createGlossaryIndex();
+                       $this->content .= $this->render_Table($this->mainKey);
 
-                       if (is_array($TCA_DESCR[$this->table]['columns']) && (!$this->limitAccess || $BE_USER->check('tables_select',$this->table)))    {
-                                       // Traverse table columns as listed in TCA_DESCR
-                               $parts=array();
-                               $parts[0]='';   // Reserved for header of table
-                               reset($TCA_DESCR[$this->table]['columns']);
-                               while(list($this->field)=each($TCA_DESCR[$this->table]['columns']))     {
-                                       $fieldValue = isset($TCA[$this->table]) && strcmp($this->field,"") ? $TCA[$this->table]['columns'][$this->field] : array();
-
-                                       if (is_array($fieldValue) && (!$this->limitAccess || !$fieldValue['exclude'] || $BE_USER->check('non_exclude_fields',$this->table.':'.$this->field)))   {
-                                               if (!$this->field)      {
-                                                       $parts[0]=$this->printItem($this->table,'',1);
-                                               } else {
-                                                       $parts[]=$this->printItem($this->table,$this->field,1);
-                                               }
-                                       }
-                               }
-                               
-                               if (!strcmp($parts,"")) unset($parts[0]);
-                               $this->content.= implode('<br />',$parts);
-                       }
-               } else {        
-                               // ... otherwise show only single field:
-                       $this->content.=$this->printItem($this->table,$this->field);
+               } elseif ($this->tfID) {
+                                // ... otherwise show only single field:
+                       $this->createGlossaryIndex();
+                       $this->content .= $this->render_Single($this->mainKey, $this->field);
+
+               } elseif (is_array($this->ffID)) {
+                       $this->content .= $this->render_Single($this->mainKey, $this->field);
 
-                               // Link to Full table description:
-                       $onClick = 'vHWin=window.open(\'view_help.php?tfID='.rawurlencode($this->table.'.*').'&ONLY='.$LANG->lang.'\',\'fullHelpWindow\',\'width=600,scrollbars=1,status=1,menubar=1,location=1,resizable=1,toolbar=1\');vHWin.focus();return false;';
-                       $this->content.='<br /><p><a href="#" onclick="'.htmlspecialchars($onClick).'">'.htmlspecialchars($LANG->getLL('fullDescription')).'</a></p>';
+               } else {
+                               // Render Table Of Contents if nothing else:
+                       $this->content.= $this->render_TOC();
                }
 
                        // Print close-button:
-               $this->content.='<br /><form action=""><input type="submit" value="'.htmlspecialchars($LANG->getLL('close')).'" onclick="self.close(); return false;" /></form>';
+#              $this->content.='<br /><form action=""><input type="submit" value="'.htmlspecialchars($GLOBALS['LANG']->getLL('close')).'" onclick="self.close(); return false;" /></form><br/>';
 
                        // End page:
-               $this->content.=$TBE_TEMPLATE->endPage();
+               $this->content.= '<br/>';
+               $this->content .= $GLOBALS['TBE_TEMPLATE']->endPage();
        }
-       
+
        /**
         * Outputting the accumulated content to screen
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function printContent() {
                echo $this->content;
        }
-       
+
+
+
+
+
+
+
+
+
+       /************************************
+        *
+        * Rendering main modes
+        *
+        ************************************/
+
+       /**
+        * Creates Table Of Contents and possibly "Full Manual" mode if selected.
+        *
+        * @return      string          HTML content
+        */
+       function render_TOC()   {
+                       // Initialize:
+               $CSHkeys = array_flip(array_keys($GLOBALS['TCA_DESCR']));
+               $TCAkeys = array_keys($GLOBALS['TCA']);
+
+               $outputSections = array();
+               $tocArray = array();
+
+
+                       // TYPO3 Core Features:
+               $GLOBALS['LANG']->loadSingleTableDescription('xMOD_csh_corebe');
+               $this->render_TOC_el('xMOD_csh_corebe', 'core', $outputSections, $tocArray, $CSHkeys);
+
+                       // Backend Modules:
+               $loadModules = t3lib_div::makeInstance('t3lib_loadModules');
+               $loadModules->load($GLOBALS['TBE_MODULES']);
+               foreach($loadModules->modules as $mainMod => $info)     {
+                       $cshKey = '_MOD_'.$mainMod;
+                       if ($CSHkeys[$cshKey])  {
+                               $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+                               $this->render_TOC_el($cshKey, 'modules', $outputSections, $tocArray, $CSHkeys);
+                       }
+
+                       if (is_array($info['sub']))     {
+                               foreach($info['sub'] as $subMod => $subInfo)    {
+                                       $cshKey = '_MOD_'.$mainMod.'_'.$subMod;
+                                       if ($CSHkeys[$cshKey])  {
+                                               $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+                                               $this->render_TOC_el($cshKey, 'modules', $outputSections, $tocArray, $CSHkeys);
+                                       }
+                               }
+                       }
+               }
+
+                       // Database Tables:
+               foreach($TCAkeys as $table)     {
+                               // Load descriptions for table $table
+                       $GLOBALS['LANG']->loadSingleTableDescription($table);
+                       if (is_array($GLOBALS['TCA_DESCR'][$table]['columns']) && $GLOBALS['BE_USER']->check('tables_select',$table)) {
+                               $this->render_TOC_el($table, 'tables', $outputSections, $tocArray, $CSHkeys);
+                       }
+               }
+
+                       // Extensions
+               foreach($CSHkeys as $cshKey => $value)  {
+                       if (t3lib_div::isFirstPartOfStr($cshKey, 'xEXT_') && !isset($GLOBALS['TCA'][$cshKey])) {
+                               $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+                               $this->render_TOC_el($cshKey, 'extensions', $outputSections, $tocArray, $CSHkeys);
+                       }
+               }
+
+                       // Glossary
+               foreach($CSHkeys as $cshKey => $value)  {
+                       if (t3lib_div::isFirstPartOfStr($cshKey, 'xGLOSSARY_') && !isset($GLOBALS['TCA'][$cshKey])) {
+                               $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+                               $this->render_TOC_el($cshKey, 'glossary', $outputSections, $tocArray, $CSHkeys);
+                       }
+               }
+
+                       // Other:
+               foreach($CSHkeys as $cshKey => $value)  {
+                       if (!t3lib_div::isFirstPartOfStr($cshKey, '_MOD_') && !isset($GLOBALS['TCA'][$cshKey])) {
+                               $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+                               $this->render_TOC_el($cshKey, 'other', $outputSections, $tocArray, $CSHkeys);
+                       }
+               }
+
+
+                       // COMPILE output:
+               $output = '';
+               $output.= '
+
+                       <h1>'.$GLOBALS['LANG']->getLL('manual_title',1).'</h1>';
+
+               $output.= '
+
+                       <h2>'.$GLOBALS['LANG']->getLL('introduction',1).'</h2>
+                       <p>'.$GLOBALS['LANG']->getLL('description',1).'</p>';
+
+               $output.= '
+
+                       <h2>'.$GLOBALS['LANG']->getLL('TOC',1).'</h2>'.
+                       $this->render_TOC_makeTocList($tocArray);
+
+               if (!$this->renderALL)  {
+                       $output.= '
+                               <br/>
+                               <p class="c-nav"><a href="view_help.php?renderALL=1">'.$GLOBALS['LANG']->getLL('full_manual',1).'</a></p>';
+               }
+
+               if ($this->renderALL)   {
+                       $output.= '
+
+                               <h2>'.$GLOBALS['LANG']->getLL('full_manual_chapters',1).'</h2>'.
+                               implode('
+
+
+                               <!-- NEW SECTION: -->
+                               ',$outputSections);
+               }
+
+               $output .= '<hr /><p class="manual-title">'.t3lib_BEfunc::TYPO3_copyRightNotice().'</p>';
+
+               return $output;
+       }
+
+       /**
+        * Creates a TOC list element and renders corresponding HELP content if "renderALL" mode is set.
+        *
+        * @param       string          CSH key / Table name
+        * @param       string          TOC category keyword: "core", "modules", "tables", "other"
+        * @param       array           Array for accumulation of rendered HELP Content (in "renderALL" mode). Passed by reference!
+        * @param       array           TOC array; Here TOC index elements are created. Passed by reference!
+        * @param       array           CSH keys array. Every item rendered will be unset in this array so finally we can see what CSH keys are not processed yet. Passed by reference!
+        * @return      void
+        */
+       function render_TOC_el($table, $tocCat, &$outputSections, &$tocArray, &$CSHkeys)        {
+               if ($this->renderALL)   {       // Render full manual right here!
+                       $outputSections[$table] = $this->render_Table($table);
+
+                       if ($outputSections[$table])    {
+                               $outputSections[$table] = '
+
+               <!-- New CSHkey/Table: '.$table.' -->
+               <p class="c-nav"><a name="ANCHOR_'.$table.'" href="#">'.$GLOBALS['LANG']->getLL('to_top',1).'</a></p>
+               <h2>'.$this->getTableFieldLabel($table).'</h2>
+
+               '.$outputSections[$table];
+                               $tocArray[$tocCat][$table] = '<a href="#ANCHOR_'.$table.'">'.$this->getTableFieldLabel($table).'</a>';
+                       } else {
+                               unset($outputSections[$table]);
+                       }
+               } else {        // Only TOC:
+                       $tocArray[$tocCat][$table] = '<p><a href="view_help.php?tfID='.rawurlencode($table.'.*').'">'.$this->getTableFieldLabel($table).'</a></p>';
+               }
+
+                       // Unset CSH key:
+               unset($CSHkeys[$table]);
+       }
+
+       /**
+        * Renders the TOC index as a HTML bullet list from TOC array
+        *
+        * @param       array           ToC Array.
+        * @return      string          HTML bullet list for index.
+        */
+       function render_TOC_makeTocList($tocArray)      {
+                       // The Various manual sections:
+               $keys = explode(',', 'core,modules,tables,extensions,glossary,other');
+
+                       // Create TOC bullet list:
+               $output = '';
+               foreach($keys as $tocKey)       {
+                       if (is_array($tocArray[$tocKey]))       {
+                               $output.='
+                                       <li>'.$GLOBALS['LANG']->getLL('TOC_'.$tocKey,1).'
+                                               <ul>
+                                                       <li>'.implode('</li>
+                                                       <li>',$tocArray[$tocKey]).'</li>
+                                               </ul>
+                                       </li>';
+                       }
+               }
+
+                       // Compile TOC:
+               $output = '
+
+                       <!-- TOC: -->
+                       <div class="c-toc">
+                               <ul>
+                               '.$output.'
+                               </ul>
+                       </div>';
+
+               return $output;
+       }
+
+       /**
+        * Render CSH for a full cshKey/table
+        *
+        * @param string $key Full CSH key (may be different from table name)
+        * @param string $table CSH key / table name
+        * @return string HTML output
+        */
+       function render_Table($key, $table = NULL) {
+               $output = '';
+
+                       // take default key if not explicitly specified
+               if ($table === NULL) {
+                       $table = $key;
+               }
+
+                       // Load table TCA
+               t3lib_div::loadTCA($key);
+
+                       // Load descriptions for table $table
+               $GLOBALS['LANG']->loadSingleTableDescription($key);
+
+               if (is_array($GLOBALS['TCA_DESCR'][$key]['columns']) && (!$this->limitAccess || $GLOBALS['BE_USER']->check('tables_select', $table))) {
+                               // Initialize variables:
+                       $parts = array();
+                       $parts[0] = ''; // Reserved for header of table
+
+                               // Traverse table columns as listed in TCA_DESCR
+                       foreach ($GLOBALS['TCA_DESCR'][$key]['columns'] as $field => $_) {
+
+                               $fieldValue = isset($GLOBALS['TCA'][$key]) && strcmp($field, '') ? $GLOBALS['TCA'][$key]['columns'][$field] : array();
+
+                               if (is_array($fieldValue) && (!$this->limitAccess || !$fieldValue['exclude'] || $GLOBALS['BE_USER']->check('non_exclude_fields', $table . ':' . $field))) {
+                                       if (!$field)    {
+                                               $parts[0] = $this->printItem($key, '', 1);      // Header
+                                       } else {
+                                               $parts[] = $this->printItem($key, $field, 1);   // Field
+                                       }
+                               }
+                       }
+
+                       if (!$parts[0]) {
+                               unset($parts[0]);
+                       }
+                       $output .= implode('<br />', $parts);
+               }
+
+                       // Substitute glossary words:
+               $output = $this->substituteGlossaryWords($output);
+
+                       // TOC link:
+               if (!$this->renderALL) {
+                       $tocLink = '<p class="c-nav"><a href="view_help.php">' . $GLOBALS['LANG']->getLL('goToToc', 1) . '</a></p>';
+
+                       $output =
+                               $tocLink.'
+                               <br/>'.
+                               $output.'
+                               <br />'.
+                               $tocLink;
+               }
+
+               return $output;
+       }
+
+       /**
+        * Renders CSH for a single field.
+        *
+        * @param string $key CSH key / table name
+        * @param string $field Sub key / field name
+        * @return string HTML output
+        */
+       function render_Single($key, $field) {
+               $output = '';
+
+                       // Load the description field
+               $GLOBALS['LANG']->loadSingleTableDescription($key);
+
+                       // Render single item
+               $output.= $this->printItem($key, $field);
+
+                       // Substitute glossary words:
+               $output = $this->substituteGlossaryWords($output);
+
+                       // Link to Full table description and TOC:
+               $getLLKey = $this->limitAccess ? 'fullDescription' : 'fullDescription_module';
+               $output.= '<br />
+                       <p class="c-nav"><a href="view_help.php?tfID=' . rawurlencode($key . '.*') . '">' . $GLOBALS['LANG']->getLL($getLLKey, 1) . '</a></p>
+                       <p class="c-nav"><a href="view_help.php">' . $GLOBALS['LANG']->getLL('goToToc', 1) . '</a></p>';
+
+               return $output;
+       }
+
+       /************************************
+        *
+        * Rendering CSH items
+        *
+        ************************************/
+
        /**
         * Make seeAlso links from $value
-        * 
+        *
         * @param       string          See-also input codes
         * @param       string          If $anchorTable is set to a tablename, then references to this table will be made as anchors, not URLs.
         * @return      string          See-also links HTML
         */
        function make_seeAlso($value,$anchorTable='')   {
-               global $TCA,$BE_USER;
-                       // Split references by comma, vert.line or linebreak
-               $items = split(',|'.chr(10),$value);
-               reset($items);
-               $lines=array();
-               while(list(,$val)=each($items)) {
+                       // Split references by comma or linebreak
+               $items = preg_split('/[,' . LF . ']/', $value);
+               $lines = array();
+
+               foreach($items as $val) {
                        $val = trim($val);
                        if ($val)       {
                                $iP = explode(':',$val);
                                $iPUrl = t3lib_div::trimExplode('|',$val);
                                        // URL reference:
                                if (substr($iPUrl[1],0,4)=='http')      {
-                                       $lines[]='<a href="'.htmlspecialchars($iPUrl[1]).'" target="_blank"><em>'.htmlspecialchars($iPUrl[0]).'</em></a>';
+                                       $lines[] = '<a href="'.htmlspecialchars($iPUrl[1]).'" target="_blank"><em>'.htmlspecialchars($iPUrl[0]).'</em></a>';
+                               } elseif (substr($iPUrl[1],0,5)=='FILE:')       {
+                                       $fileName = t3lib_div::getFileAbsFileName(substr($iPUrl[1],5),1,1);
+                                       if ($fileName && @is_file($fileName))   {
+                                               $fileName = '../'.substr($fileName,strlen(PATH_site));
+                                               $lines[] = '<a href="'.htmlspecialchars($fileName).'" target="_blank"><em>'.htmlspecialchars($iPUrl[0]).'</em></a>';
+                                       }
                                } else {
-                                       // "table" reference    
+                                       // "table" reference
                                        t3lib_div::loadTCA($iP[0]);
-                                       if (!isset($TCA[$iP[0]]) || (is_array($TCA[$iP[0]]['columns'][$iP[1]]) && (!$this->limitAccess || ($BE_USER->check('tables_select',$iP[0]) && (!$TCA[$iP[0]]['columns'][$iP[1]]['exclude'] || $BE_USER->check('non_exclude_fields',$iP[0].':'.$iP[1]))))))      {       // Checking read access:
-                                               list($tableName,$fieldName) = $this->getTableFieldNames($iP[0],$iP[1]);
 
-                                                       // Make see-also link:
-                                               $href = ($anchorTable&&$iP[0]==$anchorTable ? '#'.implode('.',$iP) : 'view_help.php?tfID='.rawurlencode(implode('.',$iP)).'&back='.$this->tfID);
-                                               $label = $GLOBALS['LANG']->sL($tableName).($iP[1]?' / '.ereg_replace(':$','',$GLOBALS['LANG']->sL($fieldName)):'');
-                                               $lines[]='<a href="'.htmlspecialchars($href).'">'.htmlspecialchars($label).'</a>';
+                                       if (!isset($GLOBALS['TCA'][$iP[0]]) || ((!$iP[1] || is_array($GLOBALS['TCA'][$iP[0]]['columns'][$iP[1]])) && (!$this->limitAccess || ($GLOBALS['BE_USER']->check('tables_select',$iP[0]) && (!$iP[1] || !$GLOBALS['TCA'][$iP[0]]['columns'][$iP[1]]['exclude'] || $GLOBALS['BE_USER']->check('non_exclude_fields',$iP[0].':'.$iP[1]))))))       {       // Checking read access:
+
+                                                       // Load table descriptions:
+                                               #$GLOBALS['LANG']->loadSingleTableDescription($iP[0]);
+                                               if (isset($GLOBALS['TCA_DESCR'][$iP[0]]))       {
+                                                               // Make see-also link:
+                                                       $href = ($this->renderALL || ($anchorTable && $iP[0]==$anchorTable) ? '#'.implode('.',$iP) : 'view_help.php?tfID='.rawurlencode(implode('.',$iP)).'&back='.$this->tfID);
+                                                       $label = $this->getTableFieldLabel($iP[0],$iP[1],' / ');
+                                                       $lines[] = '<a href="'.htmlspecialchars($href).'">'.htmlspecialchars($label).'</a>';
+                                               }
                                        }
                                }
                        }
                }
                return implode('<br />',$lines);
        }
-       
+
        /**
         * Will return an image tag with description in italics.
-        * 
-        * @param       string          Image file reference
-        * @param       string          Description string
+        *
+        * @param       string          Image file reference (list of)
+        * @param       string          Description string (divided for each image by line break)
         * @return      string          Image HTML codes
         */
-       function printImage($image,$descr)      {
-               $absImagePath = t3lib_div::getFileAbsFileName($image,1,1);
-               if ($absImagePath && @is_file($absImagePath))   {
-                       $imgFile = substr($absImagePath,strlen(PATH_site));
-                       $imgInfo=@getimagesize($absImagePath);
-                       if (is_array($imgInfo)) {
-                               $code = '<br /><img src="../'.$imgFile.'" '.$imgInfo[3].' alt="" /><br />
-                               ';
-                               $code.= '<p><em>'.$GLOBALS['LANG']->hscAndCharConv($descr,0).'</em></p>
-                               ';
-                               return $code;
+       function printImage($images,$descr)     {
+               $code = '';
+                       // Splitting:
+               $imgArray = t3lib_div::trimExplode(',', $images, 1);
+               if (count($imgArray))   {
+                       $descrArray = explode(LF,$descr,count($imgArray));
+
+                       foreach($imgArray as $k => $image)      {
+                               $descr = $descrArray[$k];
+
+                               $absImagePath = t3lib_div::getFileAbsFileName($image,1,1);
+                               if ($absImagePath && @is_file($absImagePath))   {
+                                       $imgFile = substr($absImagePath,strlen(PATH_site));
+                                       $imgInfo = @getimagesize($absImagePath);
+                                       if (is_array($imgInfo)) {
+                                               $imgFile = '../'.$imgFile;
+                                               $code.= '<br /><img src="'.$imgFile.'" '.$imgInfo[3].' class="c-inlineimg" alt="" /><br />
+                                               ';
+                                               $code.= '<p><em>' . htmlspecialchars($descr) . '</em></p>
+                                               ';
+                                       } else $code.= '<div style="background-color: red; border: 1px solid black; color: white;">NOT AN IMAGE: '.$imgFile.'</div>';
+                               } else $code.= '<div style="background-color: red; border: 1px solid black; color: white;">IMAGE FILE NOT FOUND: '.$image.'</div>';
                        }
                }
+
+               return $code;
        }
 
        /**
         * Returns header HTML content
-        * 
+        *
         * @param       string          Header text
         * @param       string          Header type (1, 0)
         * @return      string          The HTML for the header.
@@ -244,95 +592,243 @@ class SC_view_help {
        function headerLine($str,$type=0)       {
                switch($type)   {
                        case 1:
-                               $str='<h3>'.htmlspecialchars($str).'</h3>
+                               $str = '<h2 class="t3-row-header">' . htmlspecialchars($str) . '</h2>
                                ';
                        break;
                        case 0:
-                               $str='<h4 class="uppercase">'.htmlspecialchars($str).'</h4>
+                               $str = '<h3 class="divider">' . htmlspecialchars($str) . '</h3>
                                ';
                        break;
                }
-               
+
                return $str;
        }
-       
+
        /**
         * Returns prepared content
-        * 
+        *
         * @param       string          Content to format.
         * @return      string          Formatted content.
         */
        function prepareContent($str)   {
-               $str = $GLOBALS['LANG']->hscAndCharConv($str,0);
                return '<p>'.nl2br(trim(strip_tags($str,$this->allowedHTML))).'</p>
                ';
        }
-       
+
        /**
         * Prints a single $table/$field information piece
         * If $anchors is set, then seeAlso references to the same table will be page-anchors, not links.
-        * 
-        * @param       string          Table name
-        * @param       string          Field name
-        * @param       boolean         If anchors is to be shown.
-        * @return      string          HTML content
+        *
+        * @param string $key CSH key / table name
+        * @param string $field Sub key / field name
+        * @param boolean $anchors If anchors is to be shown.
+        * @return string HTML content
         */
-       function printItem($table,$field,$anchors=0)    {
-               global $TCA_DESCR, $LANG, $TCA, $BE_USER;
+       function printItem($key, $field, $anchors = FALSE) {
+               $out = '';
 
-                       // Load full table definition in $TCA
-               t3lib_div::loadTCA($table);
+                       // Load full table definition in $GLOBALS['TCA']
+               t3lib_div::loadTCA($key);
 
-               if ($table && (!$field || is_array($TCA_DESCR[$table]['columns'][$field])))     {
+               if ($key && (!$field || is_array($GLOBALS['TCA_DESCR'][$key]['columns'][$field])))      {
                                // Make seeAlso references.
-                       $seeAlsoRes = $this->make_seeAlso($TCA_DESCR[$table]['columns'][$field]['seeAlso'],$anchors?$table:'');
-                       
-                               // Get Human Readable table and field labels
-                       list($tableName,$fieldName) = $this->getTableFieldNames($table,$field);
+                       $seeAlsoRes = $this->make_seeAlso($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['seeAlso'], $anchors ? $key : '');
 
                                // Making item:
-                       $out= '<a name="'.$table.'.'.$field.'"></a>
-                                       '.
-                                       $this->headerLine($LANG->sL($tableName).': '.($field?ereg_replace(':$','',stripslashes(trim($LANG->sL($fieldName)))):''),1).
-                                       $this->prepareContent($TCA_DESCR[$table]['columns'][$field]['description']).
-                                       ($TCA_DESCR[$table]['columns'][$field]['details'] ? $this->headerLine($LANG->getLL('details').':').$this->prepareContent($TCA_DESCR[$table]['columns'][$field]['details']) : '').
-                                       ($TCA_DESCR[$table]['columns'][$field]['syntax'] ? $this->headerLine($LANG->getLL('syntax').':').$this->prepareContent($TCA_DESCR[$table]['columns'][$field]['syntax']) : '').
-                                       ($TCA_DESCR[$table]['columns'][$field]['image'] ? $this->printImage($TCA_DESCR[$table]['columns'][$field]['image'],$TCA_DESCR[$table]['columns'][$field]['image_descr']) : '').
-                                       ($TCA_DESCR[$table]['columns'][$field]['seeAlso'] && $seeAlsoRes ? $this->headerLine($LANG->getLL('seeAlso').':').'<p>'.$seeAlsoRes.'</p>' : '').
-                                       ($this->back ? '<br /><p><a href="'.htmlspecialchars('view_help.php?tfID='.rawurlencode($this->back)).'" class="typo3-goBack">'.htmlspecialchars($LANG->getLL('goBack')).'</a></p>' : '').
-                       '<br />';
+                       $out = '<a name="' . $key . '.' . $field . '"></a>' .
+                                       $this->headerLine($this->getTableFieldLabel($key, $field), 1) .
+                                       $this->prepareContent($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['description']) .
+                                       ($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['details'] ? $this->headerLine($GLOBALS['LANG']->getLL('details').':').$this->prepareContent($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['details']) : '') .
+                                       ($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['syntax'] ? $this->headerLine($GLOBALS['LANG']->getLL('syntax').':').$this->prepareContent($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['syntax']) : '') .
+                                       ($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['image'] ? $this->printImage($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['image'],$GLOBALS['TCA_DESCR'][$key]['columns'][$field]['image_descr']) : '') .
+                                       ($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['seeAlso'] && $seeAlsoRes ? $this->headerLine($GLOBALS['LANG']->getLL('seeAlso').':').'<p>'.$seeAlsoRes.'</p>' : '') .
+                                       ($this->back ? '<br /><p><a href="' . htmlspecialchars('view_help.php?tfID=' . rawurlencode($this->back)) . '" class="typo3-goBack">' . htmlspecialchars($GLOBALS['LANG']->getLL('goBack')) . '</a></p>' : '') .
+                                       '<br />';
                }
                return $out;
        }
-       
+
        /**
-        * Returns labels for $table and $field.
-        * If $table is "_MOD_" prefixed, the part after "_MOD_" is returned (non-tables, fx. modules)
-        * 
-        * @param       string          Table name
-        * @param       string          Field name
-        * @return      array           Table and field labels in a numeric array
+        * Returns labels for a given field in a given structure
+        *
+        * @param string $key CSH key / table name
+        * @param string $field Sub key / field name
+        * @return array Table and field labels in a numeric array
         */
-       function getTableFieldNames($table,$field)      {
-               global $TCA, $TCA_DESCR;
-                       $tableName = is_array($TCA_DESCR[$table]['columns']['']) && $TCA_DESCR[$table]['columns']['']['alttitle'] ? 
-                                                       $TCA_DESCR[$table]['columns']['']['alttitle'] : 
-                                                       (isset($TCA[$table]) ? $TCA[$table]['ctrl']['title'] : ereg_replace('^_MOD_','',$table));
-                       $fieldName = is_array($TCA_DESCR[$table]['columns'][$field]) && $TCA_DESCR[$table]['columns'][$field]['alttitle'] ? 
-                                                       $TCA_DESCR[$table]['columns'][$field]['alttitle'] : 
-                                                       (isset($TCA[$table])&&isset($TCA[$table]['columns'][$field]) ? $TCA[$table]['columns'][$field]['label'] : $field);
-               return array($tableName,$fieldName);
+       function getTableFieldNames($key, $field) {
+               $GLOBALS['LANG']->loadSingleTableDescription($key);
+
+                       // Define the label for the key
+               $keyName = $key;
+               if (is_array($GLOBALS['TCA_DESCR'][$key]['columns']['']) && isset($GLOBALS['TCA_DESCR'][$key]['columns']['']['alttitle'])) {
+                               // If there's an alternative title, use it
+                       $keyName = $GLOBALS['TCA_DESCR'][$key]['columns']['']['alttitle'];
+               } elseif (isset($GLOBALS['TCA'][$key])) {
+                               // Otherwise, if it's a table, use its title
+                       $keyName = $GLOBALS['TCA'][$key]['ctrl']['title'];
+               } else {
+                               // If no title was found, make sure to remove any "_MOD_"
+                       $keyName = preg_replace('/^_MOD_/', '', $key);
+               }
+                       // Define the label for the field
+               $fieldName = $field;
+               if (is_array($GLOBALS['TCA_DESCR'][$key]['columns'][$field]) && isset($GLOBALS['TCA_DESCR'][$key]['columns'][$field]['alttitle'])) {
+                               // If there's an alternative title, use it
+                       $fieldName = $GLOBALS['TCA_DESCR'][$key]['columns'][$field]['alttitle'];
+               } elseif (isset($GLOBALS['TCA'][$key]) && isset($GLOBALS['TCA'][$key]['columns'][$field])) {
+                               // Otherwise, if it's a table, use its title
+                       $fieldName = $GLOBALS['TCA'][$key]['columns'][$field]['label'];
+               }
+               return array($keyName, $fieldName);
        }
-}
 
+       /**
+        * Returns composite label for table/field
+        *
+        * @param string $key CSH key / table name
+        * @param string $field Sub key / field name
+        * @param string $mergeToken Token to merge the two strings with
+        * @return string Labels joined with merge token
+        * @see getTableFieldNames()
+        */
+       function getTableFieldLabel($key, $field = '', $mergeToken = ': ') {
+               $tableName = '';
+               $fieldName = '';
+
+                       // Get table / field parts:
+               list($tableName, $fieldName) = $this->getTableFieldNames($key, $field);
+
+                       // Create label:
+               $labelString = $GLOBALS['LANG']->sL($tableName) .
+                                       ($field ? $mergeToken . rtrim(trim($GLOBALS['LANG']->sL($fieldName)), ':') : '');
+
+               return $labelString;
+       }
+
+
+
+
+
+
+
+
+
+
+
+       /******************************
+        *
+        * Glossary related
+        *
+        ******************************/
+
+       /**
+        * Creates glossary index in $this->glossaryWords
+        * Glossary is cached in cache_hash cache and so will be updated only when cache is cleared.
+        *
+        * @return      void
+        */
+       function createGlossaryIndex()  {
+                       // Create hash string and try to retrieve glossary array:
+               $hash = md5('typo3/view_help.php:glossary');
+               list($this->glossaryWords,$this->substWords) = unserialize(t3lib_BEfunc::getHash($hash));
+
+                       // Generate glossary words if not found:
+               if (!is_array($this->glossaryWords)) {
+
+                               // Initialize:
+                       $this->glossaryWords = array();
+                       $this->substWords = array();
+                       $CSHkeys = array_flip(array_keys($GLOBALS['TCA_DESCR']));
+
+                               // Glossary
+                       foreach($CSHkeys as $cshKey => $value)  {
+                               if (t3lib_div::isFirstPartOfStr($cshKey, 'xGLOSSARY_') && !isset($GLOBALS['TCA'][$cshKey])) {
+                                       $GLOBALS['LANG']->loadSingleTableDescription($cshKey);
+
+                                       if (is_array($GLOBALS['TCA_DESCR'][$cshKey]['columns']))        {
+
+                                                       // Traverse table columns as listed in TCA_DESCR
+                                               foreach ($GLOBALS['TCA_DESCR'][$cshKey]['columns'] as $field => $data) {
+                                                       if ($field)     {
+                                                               $this->glossaryWords[$cshKey.'.'.$field] = array(
+                                                                       'title' => trim($data['alttitle'] ? $data['alttitle'] : $cshKey),
+                                                                       'description' =>  str_replace('%22','%23%23%23', rawurlencode($data['description'])),
+                                                               );
+                                                       }
+                                               }
+                                       }
+                               }
+                       }
+
+                               // First, create unique list of words:
+                       foreach($this->glossaryWords as $key => $value) {
+                               $word = strtolower($value['title']);    // Making word lowercase in order to filter out same words in different cases.
+
+                               if ($word!=='') {
+                                       $this->substWords[$word] = $value;
+                                       $this->substWords[$word]['key'] = $key;
+                               }
+                       }
+
+                       krsort($this->substWords);
+
+                       t3lib_BEfunc::storeHash($hash,serialize(array($this->glossaryWords,$this->substWords)),'Glossary');
+               }
+       }
+
+       /**
+        * Processing of all non-HTML content in the output
+        * Will be done by a call-back to ->substituteGlossaryWords_htmlcleaner_callback()
+        *
+        * @param       string          Input HTML code
+        * @return      string          Output HTML code
+        */
+       function substituteGlossaryWords($code) {
+               $htmlParser = t3lib_div::makeInstance('local_t3lib_parsehtml');
+               $htmlParser->pObj = $this;
+               $code = $htmlParser->HTMLcleaner($code, array(), 1);
+
+               return $code;
+       }
+
+       /**
+        * Substituting glossary words in the CSH
+        * (This is a call-back function from "class local_t3lib_parsehtml extends t3lib_parsehtml", see top of this script)
+        *
+        * @param       string          Input HTML string
+        * @return      string          HTML with substituted words in.
+        * @coauthor    alex widschwendter, media.res kommunikationsloesungen
+        */
+       function substituteGlossaryWords_htmlcleaner_callback($code)    {
+               if (is_array($this->substWords) && count($this->substWords) && strlen(trim($code)))     {
+
+                               // Substitute words:
+                       foreach($this->substWords as $wordKey => $wordSet)      {
+                                       // quoteMeta used so special chars (which should not occur though) in words will not break the regex. Seemed to work (- kasper)
+                               $parts = preg_split('/( |[\(])('.quoteMeta($wordSet['title']).')([\.\!\)\?\:\,]+| )/i', ' '.$code.' ', 2, PREG_SPLIT_DELIM_CAPTURE);
+                               if (count($parts) == 5) {
+                                       $parts[2] = '<a class="glossary-term" href="'.htmlspecialchars('view_help.php?tfID='.rawurlencode($wordSet['key']).'&back='.$this->tfID).'" title="'.rawurlencode(htmlspecialchars(t3lib_div::fixed_lgd_cs(rawurldecode($wordSet['description']),80))).'">'.
+                                                               htmlspecialchars($parts[2]).
+                                                               '</a>';
+                                       $code = substr(implode('',$parts),1,-1);
+
+                                               // Disable entry so it doesn't get used next time:
+                                       unset($this->substWords[$wordKey]);
+                               }
+                       }
+                       $code = str_replace('###', '&quot;',rawurldecode($code));
+               }
+
+               return $code;
+       }
 
-// Include extension?
-if (defined('TYPO3_MODE') && $TYPO3_CONF_VARS[TYPO3_MODE]['XCLASS']['typo3/view_help.php'])    {
-       include_once($TYPO3_CONF_VARS[TYPO3_MODE]['XCLASS']['typo3/view_help.php']);
 }
 
 
 
+if (defined('TYPO3_MODE') && isset($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['typo3/view_help.php'])) {
+       include_once($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['typo3/view_help.php']);
+}
 
 
 
@@ -341,4 +837,5 @@ $SOBE = t3lib_div::makeInstance('SC_view_help');
 $SOBE->init();
 $SOBE->main();
 $SOBE->printContent();
+
 ?>
\ No newline at end of file