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).'