[TASK] Use external Core Project DBAL as Git submodule
[Packages/TYPO3.CMS.git] / typo3 / show_item.php
index 0f7031a..4268987 100644 (file)
@@ -2,7 +2,7 @@
 /***************************************************************
 *  Copyright notice
 *
 /***************************************************************
 *  Copyright notice
 *
-*  (c) 1999-2010 Kasper Skaarhoj (kasperYYYY@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
 *  All rights reserved
 *
 *  This script is part of the TYPO3 project. The TYPO3 project is
 /**
  * Shows information about a database or file item
  *
 /**
  * Shows information about a database or file item
  *
- * $Id$
- * Revised for TYPO3 3.7 May/2004 by Kasper Skaarhoj
+ * Revised for TYPO3 3.7 May/2004 by Kasper Skårhøj
  *
  *
- * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
  */
 /**
  * [CLASS/FUNCTION INDEX of SCRIPT]
  */
 /**
  * [CLASS/FUNCTION INDEX of SCRIPT]
@@ -74,7 +73,7 @@ require($BACK_PATH.'template.php');
 /**
  * Extension of transfer data class
  *
 /**
  * Extension of transfer data class
  *
- * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
  * @package TYPO3
  * @subpackage core
  */
  * @package TYPO3
  * @subpackage core
  */
@@ -100,8 +99,13 @@ class transferData extends t3lib_transferData       {
                $config = $GLOBALS['TCA'][$table]['columns'][$field]['config'];
                switch($config['type']) {
                        case 'input':
                $config = $GLOBALS['TCA'][$table]['columns'][$field]['config'];
                switch($config['type']) {
                        case 'input':
-                               if (isset($config['checkbox']) && $content==$config['checkbox'])        {$content=''; break;}
-                               if (t3lib_div::inList($config['eval'],'date'))  {$content = Date($GLOBALS['TYPO3_CONF_VARS']['SYS']['ddmmyy'],$content); }
+                               if (isset($config['checkbox']) && $content == $config['checkbox']) {
+                                       $content = '';
+                                       break;
+                               }
+                               if (t3lib_div::inList($config['eval'],'date')) {
+                                       $content = Date($GLOBALS['TYPO3_CONF_VARS']['SYS']['ddmmyy'], $content);
+                               }
                        break;
                        case 'group':
                        break;
                        break;
                        case 'group':
                        break;
@@ -125,7 +129,7 @@ class transferData extends t3lib_transferData       {
 /**
  * Script Class for showing information about an item.
  *
 /**
  * Script Class for showing information about an item.
  *
- * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
+ * @author     Kasper Skårhøj <kasperYYYY@typo3.com>
  * @package TYPO3
  * @subpackage core
  */
  * @package TYPO3
  * @subpackage core
  */
@@ -137,7 +141,7 @@ class SC_show_item {
 
                // Internal, static:
        var $perms_clause;      // Page select clause
 
                // Internal, static:
        var $perms_clause;      // Page select clause
-       var $access;            // If true, access to element is granted
+       var $access;            // If TRUE, access to element is granted
        var $type;                      // Which type of element: "file" or "db"
        var $doc;                       // Document Template Object
 
        var $type;                      // Which type of element: "file" or "db"
        var $doc;                       // Document Template Object
 
@@ -155,31 +159,31 @@ class SC_show_item {
         * @return      void
         */
        function init() {
         * @return      void
         */
        function init() {
-               global $BE_USER,$BACK_PATH,$TCA;
+               global $BACK_PATH;
 
                        // Setting input variables.
                $this->table = t3lib_div::_GET('table');
                $this->uid = t3lib_div::_GET('uid');
 
                        // Initialize:
 
                        // Setting input variables.
                $this->table = t3lib_div::_GET('table');
                $this->uid = t3lib_div::_GET('uid');
 
                        // Initialize:
-               $this->perms_clause = $BE_USER->getPagePermsClause(1);
-               $this->access = 0;      // Set to true if there is access to the record / file.
+               $this->perms_clause = $GLOBALS['BE_USER']->getPagePermsClause(1);
+               $this->access = 0;      // Set to TRUE if there is access to the record / file.
                $this->type = '';       // Sets the type, "db" or "file". If blank, nothing can be shown.
 
                        // Checking if the $table value is really a table and if the user has access to it.
                $this->type = '';       // Sets the type, "db" or "file". If blank, nothing can be shown.
 
                        // Checking if the $table value is really a table and if the user has access to it.
-               if (isset($TCA[$this->table]))  {
+               if (isset($GLOBALS['TCA'][$this->table])) {
                        t3lib_div::loadTCA($this->table);
                        $this->type = 'db';
                        $this->uid = intval($this->uid);
 
                                // Check permissions and uid value:
                        t3lib_div::loadTCA($this->table);
                        $this->type = 'db';
                        $this->uid = intval($this->uid);
 
                                // Check permissions and uid value:
-                       if ($this->uid && $BE_USER->check('tables_select',$this->table))        {
+                       if ($this->uid && $GLOBALS['BE_USER']->check('tables_select',$this->table)) {
                                if ((string)$this->table=='pages')      {
                                        $this->pageinfo = t3lib_BEfunc::readPageAccess($this->uid,$this->perms_clause);
                                        $this->access = is_array($this->pageinfo) ? 1 : 0;
                                        $this->row = $this->pageinfo;
                                } else {
                                if ((string)$this->table=='pages')      {
                                        $this->pageinfo = t3lib_BEfunc::readPageAccess($this->uid,$this->perms_clause);
                                        $this->access = is_array($this->pageinfo) ? 1 : 0;
                                        $this->row = $this->pageinfo;
                                } else {
-                                       $this->row = t3lib_BEfunc::getRecord($this->table,$this->uid);
+                                       $this->row = t3lib_BEfunc::getRecordWSOL($this->table, $this->uid);
                                        if ($this->row) {
                                                $this->pageinfo = t3lib_BEfunc::readPageAccess($this->row['pid'],$this->perms_clause);
                                                $this->access = is_array($this->pageinfo) ? 1 : 0;
                                        if ($this->row) {
                                                $this->pageinfo = t3lib_BEfunc::readPageAccess($this->row['pid'],$this->perms_clause);
                                                $this->access = is_array($this->pageinfo) ? 1 : 0;
@@ -225,14 +229,14 @@ class SC_show_item {
                        $returnLinkTag = $returnLink ? '<a href="' . $returnLink . '" class="typo3-goBack">' : '<a href="#" onclick="window.close();">';
 
                                // render type by user func
                        $returnLinkTag = $returnLink ? '<a href="' . $returnLink . '" class="typo3-goBack">' : '<a href="#" onclick="window.close();">';
 
                                // render type by user func
-                       $typeRendered = false;
+                       $typeRendered = FALSE;
                        if (is_array ($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['typo3/show_item.php']['typeRendering'])) {
                                foreach ($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['typo3/show_item.php']['typeRendering'] as $classRef) {
                                        $typeRenderObj = t3lib_div::getUserObj($classRef);
                                        if(is_object($typeRenderObj) && method_exists($typeRenderObj, 'isValid') && method_exists($typeRenderObj, 'render'))    {
                                                if ($typeRenderObj->isValid($this->type, $this)) {
                                                        $this->content .=  $typeRenderObj->render($this->type, $this);
                        if (is_array ($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['typo3/show_item.php']['typeRendering'])) {
                                foreach ($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['typo3/show_item.php']['typeRendering'] as $classRef) {
                                        $typeRenderObj = t3lib_div::getUserObj($classRef);
                                        if(is_object($typeRenderObj) && method_exists($typeRenderObj, 'isValid') && method_exists($typeRenderObj, 'render'))    {
                                                if ($typeRenderObj->isValid($this->type, $this)) {
                                                        $this->content .=  $typeRenderObj->render($this->type, $this);
-                                                       $typeRendered = true;
+                                                       $typeRendered = TRUE;
                                                        break;
                                                }
                                        }
                                                        break;
                                                }
                                        }
@@ -267,7 +271,6 @@ class SC_show_item {
         * @return      void
         */
        function renderDBInfo() {
         * @return      void
         */
        function renderDBInfo() {
-               global $TCA;
 
                        // Print header, path etc:
                $code = $this->doc->getHeader($this->table,$this->row,$this->pageinfo['_thePath'],1).'<br />';
 
                        // Print header, path etc:
                $code = $this->doc->getHeader($this->table,$this->row,$this->pageinfo['_thePath'],1).'<br />';
@@ -278,11 +281,11 @@ class SC_show_item {
                $i = 0;
 
                        // Traverse the list of fields to display for the record:
                $i = 0;
 
                        // Traverse the list of fields to display for the record:
-               $fieldList = t3lib_div::trimExplode(',', $TCA[$this->table]['interface']['showRecordFieldList'], 1);
+               $fieldList = t3lib_div::trimExplode(',', $GLOBALS['TCA'][$this->table]['interface']['showRecordFieldList'], 1);
                foreach ($fieldList as $name) {
                        $name = trim($name);
                foreach ($fieldList as $name) {
                        $name = trim($name);
-                       if ($TCA[$this->table]['columns'][$name])       {
-                               if (!$TCA[$this->table]['columns'][$name]['exclude'] || $GLOBALS['BE_USER']->check('non_exclude_fields', $this->table . ':' . $name)) {
+                       if ($GLOBALS['TCA'][$this->table]['columns'][$name]) {
+                               if (!$GLOBALS['TCA'][$this->table]['columns'][$name]['exclude'] || $GLOBALS['BE_USER']->check('non_exclude_fields', $this->table . ':' . $name)) {
                                        $i++;
                                        $tableRows[] = '
                                                <tr>
                                        $i++;
                                        $tableRows[] = '
                                                <tr>
@@ -302,8 +305,8 @@ class SC_show_item {
 
                        // Add path and table information in the bottom:
                $code = '';
 
                        // Add path and table information in the bottom:
                $code = '';
-               $code.= $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:labels.path').': '.t3lib_div::fixed_lgd_cs($this->pageinfo['_thePath'],-48).'<br />';
-               $code.= $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:labels.table').': '.$GLOBALS['LANG']->sL($TCA[$this->table]['ctrl']['title']).' ('.$this->table.') - UID: '.$this->uid.'<br />';
+               $code .= $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:labels.path') . ': ' . t3lib_div::fixed_lgd_cs($this->pageinfo['_thePath'], -48) . '<br />';
+               $code .= $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:labels.table') . ': ' . $GLOBALS['LANG']->sL($GLOBALS['TCA'][$this->table]['ctrl']['title']) . ' (' . $this->table . ') - UID: ' . $this->uid . '<br />';
                $this->content.= $this->doc->section('', $code);
 
                        // References:
                $this->content.= $this->doc->section('', $code);
 
                        // References:
@@ -327,7 +330,7 @@ class SC_show_item {
                $imgObj->mayScaleUp = 0;
                $imgObj->absPrefix = PATH_site;
 
                $imgObj->mayScaleUp = 0;
                $imgObj->absPrefix = PATH_site;
 
-                       // Read Image Dimensions (returns false if file was not an image type, otherwise dimensions in an array)
+                       // Read Image Dimensions (returns FALSE if file was not an image type, otherwise dimensions in an array)
                $imgInfo = '';
                $imgInfo = $imgObj->getImageDimensions($this->file);
 
                $imgInfo = '';
                $imgInfo = $imgObj->getImageDimensions($this->file);
 
@@ -338,9 +341,7 @@ class SC_show_item {
                $code = '';
 
                        // Setting header:
                $code = '';
 
                        // Setting header:
-               $icon = t3lib_BEfunc::getFileIcon($ext);
-               $url = 'gfx/fileicons/'.$icon;
-               $fileName = '<img src="'.$url.'" width="18" height="16" align="top" alt="" /><strong>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.file', 1).':</strong> '.$fI['file'];
+               $fileName = t3lib_iconWorks::getSpriteIconForFile($ext) . '<strong>' . $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.file', TRUE) . ':</strong> ' . $fI['file'];
                if (t3lib_div::isFirstPartOfStr($this->file,PATH_site)) {
                        $code.= '<a href="../'.substr($this->file,strlen(PATH_site)).'" target="_blank">'.$fileName.'</a>';
                } else {
                if (t3lib_div::isFirstPartOfStr($this->file,PATH_site)) {
                        $code.= '<a href="../'.substr($this->file,strlen(PATH_site)).'" target="_blank">'.$fileName.'</a>';
                } else {
@@ -371,7 +372,7 @@ class SC_show_item {
                                if ($ext=='zip')        {
                                        $code = '';
                                        $t = array();
                                if ($ext=='zip')        {
                                        $code = '';
                                        $t = array();
-                                       exec('unzip -l '.$this->file, $t);
+                                       t3lib_utility_Command::exec('unzip -l ' . $this->file, $t);
                                        if (is_array($t))       {
                                                reset($t);
                                                next($t);
                                        if (is_array($t))       {
                                                reset($t);
                                                next($t);
@@ -396,7 +397,7 @@ class SC_show_item {
                                                $compr = 'z';
                                        }
                                        $t = array();
                                                $compr = 'z';
                                        }
                                        $t = array();
-                                       exec('tar t'.$compr.'f '.$this->file, $t);
+                                       t3lib_utility_Command::exec('tar t' . $compr . 'f ' . $this->file, $t);
                                        if (is_array($t))       {
                                                foreach($t as $val)     {
                                                        $code.='
                                        if (is_array($t))       {
                                                foreach($t as $val)     {
                                                        $code.='
@@ -486,7 +487,7 @@ class SC_show_item {
                        // Compile information for title tag:
                $infoData = array();
                if (count($rows))       {
                        // Compile information for title tag:
                $infoData = array();
                if (count($rows))       {
-                       $infoData[] = '<tr class="bgColor5 tableheader">' .
+                       $infoData[] = '<tr class="t3-row-header">' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.table').'</td>' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.uid').'</td>' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.field').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.table').'</td>' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.uid').'</td>' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.field').'</td>'.
@@ -506,7 +507,7 @@ class SC_show_item {
                                        '</tr>';
                }
 
                                        '</tr>';
                }
 
-               return count($infoData) ? '<table border="0" cellpadding="1" cellspacing="1">'.implode('',$infoData).'</table>' : '';
+               return count($infoData) ? '<table border="0" cellpadding="0" cellspacing="0" class="typo3-dblist">' . implode('', $infoData) . '</table>' : '';
        }
 
        /**
        }
 
        /**
@@ -529,7 +530,7 @@ class SC_show_item {
                        // Compile information for title tag:
                $infoData = array();
                if (count($rows))       {
                        // Compile information for title tag:
                $infoData = array();
                if (count($rows))       {
-                       $infoData[] = '<tr class="bgColor5 tableheader">' .
+                       $infoData[] = '<tr class="t3-row-header">' .
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.field').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.flexpointer').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.softrefKey').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.field').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.flexpointer').'</td>'.
                                        '<td>'.$GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_core.xml:show_item.php.softrefKey').'</td>'.
@@ -551,13 +552,13 @@ class SC_show_item {
                                        '</tr>';
                }
 
                                        '</tr>';
                }
 
-               return count($infoData) ? '<table border="0" cellpadding="1" cellspacing="1">'.implode('',$infoData).'</table>' : '';
+               return count($infoData) ? '<table border="0" cellpadding="0" cellspacing="0" class="typo3-dblist">' . implode('', $infoData) . '</table>' : '';
        }
 }
 
 
        }
 }
 
 
-if (defined('TYPO3_MODE') && $TYPO3_CONF_VARS[TYPO3_MODE]['XCLASS']['typo3/show_item.php'])    {
-       include_once($TYPO3_CONF_VARS[TYPO3_MODE]['XCLASS']['typo3/show_item.php']);
+if (defined('TYPO3_MODE') && isset($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['typo3/show_item.php'])) {
+       include_once($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['typo3/show_item.php']);
 }
 
 
 }