"fixed filemanger bug: actions dont work for filenames containing commas

--> allow to enclose comma-separated checkbox and radio-button option values in quotes (\"), so they can contain commas
eg. file-names containing commas in the filemanager"
This commit is contained in:
Ralf Becker 2009-04-09 11:49:16 +00:00
parent 5291d0ac39
commit 592488908e
2 changed files with 48 additions and 4 deletions

View File

@ -166,7 +166,7 @@ class boetemplate extends soetemplate
$row_cont = $cont[$row]; $row_cont = $cont[$row];
$col_row_cont = $cont[$col.$row]; $col_row_cont = $cont[$col.$row];
eval('$name = "'.$name.'";'); eval('$name = "'.addslashes($name).'";');
} }
if ($is_index_in_content) if ($is_index_in_content)
{ {
@ -684,6 +684,50 @@ class boetemplate extends soetemplate
return $extra['widgets']; return $extra['widgets'];
} }
/**
* Split a $delimiter-separated options string, which can contain parts with delimiters enclosed in $enclosure
*
* Examples:
* - csv_split('"1,2,3",2,3') === array('1,2,3','2','3')
* - csv_split('1,2,3',2) === array('1','2,3')
* - csv_split('"1,2,3",2,3',2) === array('1,2,3','2,3')
*
* @param string $str
* @param int $num=null in how many parts to split maximal, parts over this number end up (unseparated) in the last part
* @param string $delimiter=','
* @param string $enclosure='"'
* @return array
*/
static function csv_split($str,$num=null,$delimiter=',',$enclosure='"')
{
if (strpos($str,$enclosure) === false)
{
return explode($delimiter,$str,$num); // no need to run this more expensive code
}
$parts = explode($delimiter,$str);
for($n = 0; isset($parts[$n]); ++$n)
{
$part =& $parts[$n];
if ($part[0] === $enclosure)
{
while (isset($parts[$n+1]) && substr($part,-1) !== $enclosure)
{
$part .= $delimiter.$parts[++$n];
unset($parts[$n]);
}
$part = substr($part,1,-1);
}
}
$parts = array_values($parts); // renumber the parts (in case we had to concat them)
if ($num > 0 && count($parts) > $num)
{
$parts[$num-1] = implode($delimiter,array_slice($parts,$num-1,count($parts)-$num+1));
$parts = array_slice($parts,0,$num);
}
return $parts;
}
/** /**
* generated a file-name from an eTemplates, name, template(-set) and lang * generated a file-name from an eTemplates, name, template(-set) and lang
* *
@ -926,4 +970,4 @@ if (!function_exists('set_cell_attribute_helper'))
} }
} }
// just in case someone still uses the old var // just in case someone still uses the old var
$GLOBALS['egw_info']['flags']['etemplate']['loop'] =& boetemplate::$loop; $GLOBALS['egw_info']['flags']['etemplate']['loop'] =& boetemplate::$loop;

View File

@ -1176,7 +1176,7 @@ class etemplate extends boetemplate
$set_val = 1; $unset_val = 0; $set_val = 1; $unset_val = 0;
if (!empty($cell_options)) if (!empty($cell_options))
{ {
list($set_val,$unset_val,$ro_true,$ro_false) = explode(',',$cell_options); list($set_val,$unset_val,$ro_true,$ro_false) = self::csv_split($cell_options);
if (!$set_val && !$unset_val) $set_val = 1; if (!$set_val && !$unset_val) $set_val = 1;
$value = $value == $set_val; $value = $value == $set_val;
} }
@ -1216,7 +1216,7 @@ class etemplate extends boetemplate
} }
break; break;
case 'radio': // size: value if checked, readonly set, readonly unset case 'radio': // size: value if checked, readonly set, readonly unset
list($set_val,$ro_true,$ro_false) = explode(',',$cell_options); list($set_val,$ro_true,$ro_false) = self::csv_split($cell_options);
$set_val = $this->expand_name($set_val,$show_c,$show_row,$content['.c'],$content['.row'],$content); $set_val = $this->expand_name($set_val,$show_c,$show_row,$content['.c'],$content['.row'],$content);
if ($value == $set_val) if ($value == $set_val)