X-Git-Url: http://git.typo3.org/Packages/TYPO3.CMS.git/blobdiff_plain/2b9f0c517792ec9df7ff48fcda6ebe79dbdbae56..7cea94c8edbe92d117fdcc08a3a958caf6abc6ae:/typo3/class.browse_links.php diff --git a/typo3/class.browse_links.php b/typo3/class.browse_links.php index bd32af16360..3734d3d311b 100755 --- a/typo3/class.browse_links.php +++ b/typo3/class.browse_links.php @@ -2,7 +2,7 @@ /*************************************************************** * Copyright notice * -* (c) 1999-2005 Kasper Skaarhoj (kasperYYYY@typo3.com) +* (c) 1999-2007 Kasper Skaarhoj (kasperYYYY@typo3.com) * All rights reserved * * This script is part of the TYPO3 project. The TYPO3 project is @@ -663,6 +663,7 @@ class browse_links { var $setTarget; // Target (RTE specific) var $setTitle; // title (RTE specific) var $doc; // Backend template object + var $elements = array(); // Holds information about files // GPvars: (Input variables from outside) /** @@ -1057,15 +1058,14 @@ class browse_links { } } function focusOpenerAndClose(close) { // - if (close) { - parent.window.opener.focus(); - parent.close(); - } + BrowseLinks.focusOpenerAndClose(close); } '; // Finally, add the accumulated JavaScript to the template object: - $this->doc->JScode = $this->doc->wrapScriptTags($JScode); + $this->doc->JScode = ''."\n"; + $this->doc->JScode.= ''."\n"; + $this->doc->JScode.= $this->doc->wrapScriptTags($JScode); // Debugging: if (FALSE) debug(array( @@ -1559,6 +1559,8 @@ class browse_links { // Add some space $content.='

'; + // Setup indexed elements: + $this->doc->JScode.= $this->doc->wrapScriptTags('BrowseLinks.addElements('.t3lib_div::array2json($this->elements).');'); // Ending page, returning content: $content.= $this->doc->endPage(); $content = $this->doc->insertStylesAndJS($content); @@ -1875,7 +1877,9 @@ class browse_links { if (is_array($files)) { // Create headline (showing number of files): - $out.=$this->barheader(sprintf($GLOBALS['LANG']->getLL('files').' (%s):',count($files))); + $filesCount = count($files); + $out.=$this->barheader(sprintf($GLOBALS['LANG']->getLL('files').' (%s):', $filesCount)); + $out.=$this->getBulkSelector($filesCount); $titleLen=intval($GLOBALS['BE_USER']->uc['titleLen']); @@ -1898,7 +1902,7 @@ class browse_links { $fI=pathinfo($filepath); // Thumbnail/size generation: - if (t3lib_div::inList($GLOBALS['TYPO3_CONF_VARS']['GFX']['imagefile_ext'],$fI['extension']) && !$noThumbs) { + if (t3lib_div::inList(strtolower($GLOBALS['TYPO3_CONF_VARS']['GFX']['imagefile_ext']),strtolower($fI['extension'])) && !$noThumbs) { $imgInfo = $imgObj->getImageDimensions($filepath); $pDim = $imgInfo[0].'x'.$imgInfo[1].' pixels'; $clickIcon = t3lib_BEfunc::getThumbNail($BACK_PATH.'thumbs.php',$filepath,'hspace="5" vspace="5" border="1"'); @@ -1916,9 +1920,20 @@ class browse_links { if (strstr($filepath,',') || strstr($filepath,'|')) { // In case an invalid character is in the filepath, display error message: $eMsg = $LANG->JScharCode(sprintf($LANG->getLL('invalidChar'),', |')); $ATag = $ATag_alt = ""; + $bulkCheckBox = ''; } else { // If filename is OK, just add it: - $ATag = ""; - $ATag_alt = substr($ATag,0,-4).",'',1);\">"; + $filesIndex = count($this->elements); + $this->elements['file_'.$filesIndex] = array( + 'md5' => t3lib_div::shortMD5($filepath), + 'type' => 'file', + 'fileName' => $fI['basename'], + 'filePath' => $filepath, + 'fileExt' => $fI['extension'], + 'fileIcon' => $ficon, + ); + $ATag = ""; + $ATag_alt = substr($ATag,0,-4).",1);\">"; + $bulkCheckBox = ' '; } $ATag_e=''; @@ -1928,7 +1943,7 @@ class browse_links { $ATag2_e=''; // Combine the stuff: - $filenameAndIcon=$ATag_alt.$icon.htmlspecialchars(t3lib_div::fixed_lgd_cs(basename($filepath),$titleLen)).$ATag_e; + $filenameAndIcon=$bulkCheckBox.$ATag_alt.$icon.htmlspecialchars(t3lib_div::fixed_lgd_cs(basename($filepath),$titleLen)).$ATag_e; // Show element: if ($pDim) { // Image... @@ -1970,7 +1985,6 @@ class browse_links { '.implode('',$lines).' '; } - // Return accumulated content for filelisting: return $out; } @@ -2012,13 +2026,13 @@ class browse_links { // Fraverse files: while(list(,$filepath)=each($files)) { - $fI=pathinfo($filepath); + $fI = pathinfo($filepath); // URL of image: $iurl = $this->siteURL.t3lib_div::rawurlencodeFP(substr($filepath,strlen(PATH_site))); // Show only web-images - if (t3lib_div::inList('gif,jpeg,jpg,png',$fI['extension'])) { + if (t3lib_div::inList('gif,jpeg,jpg,png',strtolower($fI['extension']))) { $imgInfo = @getimagesize($filepath); $pDim = $imgInfo[0].'x'.$imgInfo[1].' pixels'; @@ -2347,6 +2361,29 @@ class browse_links { return $code; } + + /** + * Get the HTML data required for a bulk selection of files of the TYPO3 Element Browser. + * + * @param integer $filesCount: Number of files currently displayed + * @return string HTML data required for a bulk selection of files - if $filesCount is 0, nothing is returned + */ + function getBulkSelector($filesCount) { + if ($filesCount) { + $labelToggleSelection = $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_browse_links.php:toggleSelection',1); + $labelImportSelection = $GLOBALS['LANG']->sL('LLL:EXT:lang/locallang_browse_links.php:importSelection',1); + + $out = $this->doc->spacer(15).'
' . + '' . + ' ' . + $labelToggleSelection.''.$this->doc->spacer(5) . + '' . + ' ' . + $labelImportSelection.'' . + '
'.$this->doc->spacer(15); + } + return $out; + } } // Include extension? @@ -2355,4 +2392,4 @@ if (defined('TYPO3_MODE') && $TYPO3_CONF_VARS[TYPO3_MODE]['XCLASS']['typo3/class } -?> \ No newline at end of file +?>