Updated locallang-XML files with most recent translations.
[Packages/TYPO3.CMS.git] / typo3 / alt_db_navframe.php
index 5a96489..fd65d40 100755 (executable)
@@ -1,19 +1,19 @@
 <?php
 /***************************************************************
 *  Copyright notice
-*  
-*  (c) 1999-2004 Kasper Skaarhoj (kasper@typo3.com)
+*
+*  (c) 1999-2004 Kasper Skaarhoj (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.
 *
 *
  * Revised for TYPO3 3.6 2/2003 by Kasper Skaarhoj
  * XHTML compliant
  *
- * @author     Kasper Skaarhoj <kasper@typo3.com>
+ * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
  */
 /**
  * [CLASS/FUNCTION INDEX of SCRIPT]
  *
  *
  *
- *   72: class localPageTree extends t3lib_browseTree 
- *   79:     function localPageTree() 
- *   90:     function wrapIcon($icon,&$row)    
+ *   77: class localPageTree extends t3lib_browseTree
+ *   87:     function localPageTree()
+ *   98:     function wrapIcon($icon,&$row)
+ *  136:     function wrapStop($str,$row)
  *
  *
- *  131: class SC_alt_db_navframe 
- *  147:     function init()   
- *  237:     function main()   
- *  265:     function printContent()   
+ *  162: class SC_alt_db_navframe
+ *  180:     function init()
+ *  276:     function main()
+ *  327:     function printContent()
  *
- * TOTAL FUNCTIONS: 5
+ *              SECTION: Temporary DB mounts
+ *  354:     function initializeTemporaryDBmount()
+ *  383:     function settingTemporaryMountPoint($pageId)
+ *
+ * TOTAL FUNCTIONS: 8
  * (This index is automatically created/updated by the extension "extdeveval")
  *
  */
 
 
 $BACK_PATH='';
-require ('init.php');
-require ('template.php');
-require_once (PATH_t3lib.'class.t3lib_browsetree.php');
+require('init.php');
+require('template.php');
+require_once(PATH_t3lib.'class.t3lib_browsetree.php');
 
 
 
 /**
  * Extension class for the t3lib_browsetree class, specially made for browsing pages in the Web module
- * 
- * @author     Kasper Skaarhoj <kasper@typo3.com>
+ *
+ * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
  * @package TYPO3
  * @subpackage core
  * @see class t3lib_browseTree
  */
 class localPageTree extends t3lib_browseTree {
 
+       var $ext_showPageId;
+       var $ext_IconMode;
+
        /**
         * Calls init functions
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function localPageTree() {
                $this->init();
@@ -82,7 +90,7 @@ class localPageTree extends t3lib_browseTree {
 
        /**
         * Wrapping icon in browse tree
-        * 
+        *
         * @param       string          Icon IMG code
         * @param       array           Data row for element.
         * @return      string          Page icon
@@ -94,19 +102,42 @@ class localPageTree extends t3lib_browseTree {
                        $lockIcon='<a href="#" onclick="'.htmlspecialchars($aOnClick).'">'.
                                '<img'.t3lib_iconWorks::skinImg('','gfx/recordlock_warning3.gif','width="17" height="12"').' title="'.htmlspecialchars($lockInfo['msg']).'" alt="" />'.
                                '</a>';
-               } else $lockIcon="";
+               } else $lockIcon = '';
 
                        // Add title attribute to input icon tag
                $thePageIcon = $this->addTagAttributes($icon, $this->titleAttrib.'="'.$this->getTitleAttrib($row).'"');
 
                        // Wrap icon in click-menu link.
                if (!$this->ext_IconMode)       {
-                       $thePageIcon = $GLOBALS['TBE_TEMPLATE']->wrapClickMenuOnIcon($thePageIcon,'pages',$row['uid'],0);
+                       $thePageIcon = $GLOBALS['TBE_TEMPLATE']->wrapClickMenuOnIcon($thePageIcon,'pages',$row['uid'],0,'&bank='.$this->bank);
                } elseif (!strcmp($this->ext_IconMode,'titlelink'))     {
-                       $aOnClick = 'return jumpTo('.$this->getJumpToParm($row).',this,\''.$this->treeName.'\');';
+                       $aOnClick = 'return jumpTo(\''.$this->getJumpToParam($row).'\',this,\''.$this->treeName.'\');';
                        $thePageIcon='<a href="#" onclick="'.htmlspecialchars($aOnClick).'">'.$thePageIcon.'</a>';
                }
-               return $thePageIcon.$lockIcon;
+
+                       // Add Page ID:
+               if ($this->ext_showPageId)      {
+                       $pageIdStr = '['.$row['uid'].']&nbsp;';
+               } else {
+                       $pageIdStr = '';
+               }
+
+               return $thePageIcon.$lockIcon.$pageIdStr;
+       }
+
+       /**
+        * Adds a red "+" to the input string, $str, if the field "php_tree_stop" in the $row (pages) is set
+        *
+        * @param       string          Input string, like a page title for the tree
+        * @param       array           record row with "php_tree_stop" field
+        * @return      string          Modified string
+        * @access private
+        */
+       function wrapStop($str,$row)    {
+               if ($row['php_tree_stop'])      {
+                       $str.='<a href="'.htmlspecialchars(t3lib_div::linkThisScript(array('setTempDBmount' => $row['uid']))).'" class="typo3-red">+</a> ';
+               }
+               return $str;
        }
 }
 
@@ -123,8 +154,8 @@ class localPageTree extends t3lib_browseTree {
 
 /**
  * Main script class for the page tree navigation frame
- * 
- * @author     Kasper Skaarhoj <kasper@typo3.com>
+ *
+ * @author     Kasper Skaarhoj <kasperYYYY@typo3.com>
  * @package TYPO3
  * @subpackage core
  */
@@ -133,16 +164,18 @@ class SC_alt_db_navframe {
                // Internal:
        var $content;
        var $pagetree;
-       var $doc;       
-       
+       var $doc;
+       var $active_tempMountPoint = 0;         // Temporary mount point (record), if any
+
                // Internal, static: GPvar:
        var $currentSubScript;
        var $cMR;
+       var $setTempDBmount;                    // If not '' (blank) then it will clear (0) or set (>0) Temporary DB mount.
 
        /**
         * Initialiation of the class
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function init() {
                global $BE_USER,$BACK_PATH;
@@ -150,17 +183,25 @@ class SC_alt_db_navframe {
                        // Setting GPvars:
                $this->currentSubScript = t3lib_div::_GP('currentSubScript');
                $this->cMR = t3lib_div::_GP('cMR');
-               
+               $this->setTempDBmount = t3lib_div::_GP('setTempDBmount');
+
                        // Create page tree object:
                $this->pagetree = t3lib_div::makeInstance('localPageTree');
                $this->pagetree->ext_IconMode = $BE_USER->getTSConfigVal('options.pageTree.disableIconLinkToContextmenu');
+               $this->pagetree->ext_showPageId = $BE_USER->getTSConfigVal('options.pageTree.showPageIdWithTitle');
                $this->pagetree->thisScript = 'alt_db_navframe.php';
                $this->pagetree->addField('alias');
                $this->pagetree->addField('shortcut');
                $this->pagetree->addField('shortcut_mode');
                $this->pagetree->addField('mount_pid');
+               $this->pagetree->addField('mount_pid_ol');
+               $this->pagetree->addField('nav_hide');
                $this->pagetree->addField('url');
 
+#              $this->settingTemporaryMountPoint(11);
+                       // Temporary DB mounts:
+               $this->initializeTemporaryDBmount();
+
                        // Setting highlight mode:
                $this->doHighlight = !$BE_USER->getTSConfigVal('options.pageTree.disableTitleHighlight');
 
@@ -174,7 +215,7 @@ class SC_alt_db_navframe {
                        // Setting JavaScript for menu.
                $this->doc->JScode=$this->doc->wrapScriptTags(
        ($this->currentSubScript?'top.currentSubScript=unescape("'.rawurlencode($this->currentSubScript).'");':'').'
-       
+
                // Function, loading the list frame from navigation tree:
        function jumpTo(id,linkObj,highLightID) {       //
                var theUrl = top.TS.PATH_typo3+top.currentSubScript+"?id="+id;
@@ -184,13 +225,13 @@ class SC_alt_db_navframe {
                } else {
                        parent.list_frame.document.location=theUrl;
                }
-               
+
                '.($this->doHighlight?'hilight_row("web",highLightID);':'').'
-               
+
                '.(!$GLOBALS['CLIENT']['FORMSTYLE'] ? '' : 'if (linkObj) {linkObj.blur();}').'
                return false;
        }
-       
+
                // Call this function, refresh_nav(), from another script in the backend if you want to refresh the navigation frame (eg. after having changed a page title or moved pages etc.)
                // See t3lib_BEfunc::getSetUpdateSignal()
        function refresh_nav()  {       //
@@ -199,7 +240,7 @@ class SC_alt_db_navframe {
        function _refresh_nav() {       //
                document.location="'.$this->pagetree->thisScript.'?unique='.time().'";
        }
-       
+
                // Highlighting rows in the page tree:
        function hilight_row(frameSetModule,highLightID) {      //
 
@@ -208,7 +249,7 @@ class SC_alt_db_navframe {
                if (theObj)     {
                        theObj.style.backgroundColor="";
                }
-               
+
                        // Set new:
                top.fsMod.navFrameHighlightedID[frameSetModule] = highLightID;
                theObj = document.getElementById(highLightID);
@@ -216,21 +257,21 @@ class SC_alt_db_navframe {
                        theObj.style.backgroundColor="'.t3lib_div::modifyHTMLColorAll($this->doc->bgColor,-20).'";
                }
        }
-       
+
        '.($this->cMR?"jumpTo(top.fsMod.recentIds['web'],'');":'').';
                ');
 
                        // Click menu code is added:
                $CMparts=$this->doc->getContextMenuCode();
                $this->doc->bodyTagAdditions = $CMparts[1];
-               $this->doc->JScode.=$CMparts[0];
+               $this->doc->JScode.= $CMparts[0];
                $this->doc->postCode.= $CMparts[2];
        }
 
        /**
         * Main function, rendering the browsable page tree
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function main() {
                global $LANG,$CLIENT;
@@ -238,17 +279,40 @@ class SC_alt_db_navframe {
                        // Produce browse-tree:
                $tree = $this->pagetree->getBrowsableTree();
 
-               $this->content='';
-               $this->content.=$this->doc->startPage('Page tree');
-               $this->content.=$tree;
-               $this->content.='
+                       // Start page:
+               $this->content = '';
+               $this->content.= $this->doc->startPage('Page tree');
+
+                       // Outputting Temporary DB mount notice:
+               if ($this->active_tempMountPoint)       {
+                       $this->content.= '
+                               <div class="bgColor4 c-notice">
+                                       <img'.t3lib_iconWorks::skinImg('','gfx/icon_note.gif','width="18" height="16"').' align="top" alt="" />'.
+                                       '<a href="'.htmlspecialchars(t3lib_div::linkThisScript(array('setTempDBmount' => 0))).'">'.
+                                       $LANG->sl('LLL:EXT:lang/locallang_core.php:labels.temporaryDBmount',1).
+                                       '</a><br/>
+                                       '.$LANG->sl('LLL:EXT:lang/locallang_core.php:labels.path',1).': <span title="'.htmlspecialchars($this->active_tempMountPoint['_thePathFull']).'">'.htmlspecialchars(t3lib_div::fixed_lgd_cs($this->active_tempMountPoint['_thePath'],-50)).'</span>
+                               </div>
+                       ';
+               }
+
+                       // Outputting page tree:
+               $this->content.= $tree;
+
+                       // Outputting refresh-link
+               $refreshUrl = t3lib_div::getIndpEnv('REQUEST_URI');
+               $this->content.= '
                        <p class="c-refresh">
-                               <a href="'.htmlspecialchars(t3lib_div::getIndpEnv('REQUEST_URI')).'">'.
+                               <a href="'.htmlspecialchars($refreshUrl).'">'.
                                '<img'.t3lib_iconWorks::skinImg('','gfx/refresh_n.gif','width="14" height="14"').' title="'.$LANG->sL('LLL:EXT:lang/locallang_core.php:labels.refresh',1).'" alt="" />'.
+                               '</a><a href="'.htmlspecialchars($refreshUrl).'">'.
                                $LANG->sL('LLL:EXT:lang/locallang_core.php:labels.refresh',1).'</a>
                        </p>
                        <br />';
 
+                       // CSH icon:
+               $this->content.= t3lib_BEfunc::cshItem('xMOD_csh_corebe', 'pagetree', $GLOBALS['BACK_PATH']);
+
                        // Adding highlight - JavaScript
                if ($this->doHighlight) $this->content .=$this->doc->wrapScriptTags('
                        hilight_row("",top.fsMod.navFrameHighlightedID["web"]);
@@ -257,13 +321,71 @@ class SC_alt_db_navframe {
 
        /**
         * Outputting the accumulated content to screen
-        * 
-        * @return      void            
+        *
+        * @return      void
         */
        function printContent() {
                $this->content.= $this->doc->endPage();
                echo $this->content;
        }
+
+
+
+
+
+
+
+
+
+
+
+
+       /**********************************
+        *
+        * Temporary DB mounts
+        *
+        **********************************/
+
+       /**
+        * Getting temporary DB mount
+        *
+        * @return      void
+        */
+       function initializeTemporaryDBmount(){
+               global $BE_USER;
+
+                       // Set/Cancel Temporary DB Mount:
+               if (strlen($this->setTempDBmount))      {
+                       $set = t3lib_div::intInRange($this->setTempDBmount,0);
+                       if ($set>0 && $BE_USER->isInWebMount($set))     {       // Setting...:
+                               $this->settingTemporaryMountPoint($set);
+                       } else {        // Clear:
+                               $this->settingTemporaryMountPoint(0);
+                       }
+               }
+
+                       // Getting temporary mount point ID:
+               $temporaryMountPoint = intval($BE_USER->getSessionData('pageTree_temporaryMountPoint'));
+
+                       // If mount point ID existed and is within users real mount points, then set it temporarily:
+               if ($temporaryMountPoint > 0 && $BE_USER->isInWebMount($temporaryMountPoint))   {
+                       $this->pagetree->MOUNTS = array($temporaryMountPoint);
+                       $this->active_tempMountPoint = t3lib_BEfunc::readPageAccess($temporaryMountPoint, $BE_USER->getPagePermsClause(1));
+               }
+       }
+
+       /**
+        * Setting temporary page id as DB mount
+        *
+        * @param       integer         The page id to set as DB mount
+        * @return      void
+        */
+       function settingTemporaryMountPoint($pageId)    {
+               global $BE_USER;
+
+                       // Setting temporary mount point ID:
+               $BE_USER->setAndSaveSessionData('pageTree_temporaryMountPoint',intval($pageId));
+       }
 }
 
 // Include extension?
@@ -288,4 +410,4 @@ $SOBE->init();
 $SOBE->main();
 $SOBE->printContent();
 
-?>
+?>
\ No newline at end of file