(merged from branches/roa. use "svn log -c <changeset> -g <module-svn-path>" for detailed commit message)

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@60268 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Ingo Schommer 2008-08-10 23:53:56 +00:00
parent 935ee6d1bc
commit 124a6e3934
4 changed files with 64 additions and 16 deletions

View File

@ -2625,6 +2625,12 @@ class DataObject extends ViewableData implements DataObjectInterface {
* view of this object. * view of this object.
*/ */
public static $summary_fields = null; public static $summary_fields = null;
/**
* User defined permissions for search result table by ModelAdmin to act on.
* Such as print search
*/
public static $results_permissions = null;
} }

View File

@ -165,6 +165,14 @@ class TableListField extends FormField {
*/ */
public $fieldFormatting = array(); public $fieldFormatting = array();
/**
* @var array Specify custom escape for the fields, e.g. to escape all accurance of "\r", "\r\n" and "\n" of the field
* value, we need to set this field as array("\r"=>"", "\r\n"=>"", "\n"=>"") ;
* Example: setFieldEscape(array("\""=>"\"\"","\r"=>"", "\r\n"=>"", "\n"=>"") is needed for exporting the table to a .csv
* file
*/
public $fieldEscape = array();
/** /**
* @var string * @var string
*/ */
@ -312,7 +320,7 @@ JS
// get query // get query
$dataQuery = $this->getQuery(); $dataQuery = $this->getQuery();
// we don't limit when doing certain actions // we don't limit when doing certain actions T
if(!isset($_REQUEST['methodName']) || !in_array($_REQUEST['methodName'],array('printall','export'))) { if(!isset($_REQUEST['methodName']) || !in_array($_REQUEST['methodName'],array('printall','export'))) {
$dataQuery->limit(array( $dataQuery->limit(array(
'limit' => $SQL_limit, 'limit' => $SQL_limit,
@ -335,9 +343,9 @@ JS
function Items() { function Items() {
$fieldItems = new DataObjectSet(); $fieldItems = new DataObjectSet();
if($items = $this->sourceItems()) foreach($items as $item) { if($items = $this->sourceItems()) foreach($items as $item) {
$fieldItem = new TableListField_Item($item, $this);
if($item) $fieldItems->push(new TableListField_Item($item, $this)); if($item) $fieldItems->push(new TableListField_Item($item, $this));
} }
return $fieldItems; return $fieldItems;
} }
@ -740,7 +748,6 @@ JS
$record = $records->nextRecord(); $record = $records->nextRecord();
$this->totalCount = $record['TotalCount']; $this->totalCount = $record['TotalCount'];
} }
return $this->totalCount; return $this->totalCount;
} }
@ -782,6 +789,13 @@ JS
$this->csvSeparator = $csvSeparator; $this->csvSeparator = $csvSeparator;
} }
/**
* Get the CSV separator character. Defaults to ,
*/
function getCsvSeparator() {
return $this->csvSeparator;
}
/** /**
* Remove the header row from the CSV export * Remove the header row from the CSV export
*/ */
@ -812,21 +826,32 @@ JS
// get data // get data
$dataQuery = $this->getCsvQuery(); $dataQuery = $this->getCsvQuery();
$records = $dataQuery->execute(); $records = $dataQuery->execute();
$sourceClass = $this->sourceClass; $sourceClass = $this->sourceClass;
$dataobject = new $sourceClass(); $dataobject = new $sourceClass();
$items = $dataobject->buildDataObjectSet($records, 'DataObjectSet'); $items = $dataobject->buildDataObjectSet($records, 'DataObjectSet');
if($items) { $fieldItems = new DataObjectSet();
foreach($items as $item) {
$columnData = array(); if($items&&$items->count()) foreach($items as $item) {
foreach($csvColumns as $columnName => $columnTitle) { $fieldItem = new TableListField_Item($item, $this);
$tmpColumnData = "\"" . str_replace("\"", "\"\"", $item->$columnName) . "\""; if($item) $fieldItems->push(new TableListField_Item($item, $this));
$tmpColumnData = str_replace(array("\r", "\n"), "", $tmpColumnData); }
$columnData[] = $tmpColumnData;
} $this->setFieldFormatting(array());
$fileData .= implode($separator, $columnData); $this->setFieldEscape(array(
$fileData .= "\n"; "\""=>"\"\"",
"\r\n"=>"",
"\r"=>"",
"\n"=>"",
));
if($fieldItems) {
foreach($fieldItems as $fieldItem) {
$fileData .= $fieldItem->renderwith("TableListField_Item_export");
} }
HTTP::sendFileToBrowser($fileData, $fileName); HTTP::sendFileToBrowser($fileData, $fileName);
} else { } else {
user_error("No records found", E_USER_ERROR); user_error("No records found", E_USER_ERROR);
@ -838,7 +863,9 @@ JS
* We need to instanciate this button manually as a normal button has no means of adding inline onclick-behaviour. * We need to instanciate this button manually as a normal button has no means of adding inline onclick-behaviour.
*/ */
function ExportLink() { function ExportLink() {
return Controller::join_links($this->Link(), 'export'); $exportLink = Controller::join_links($this->Link(), 'export');
if($this->extraLinkParams) $exportLink .= "?" . http_build_query($this->extraLinkParams);
return $exportLink;
} }
function printall() { function printall() {
@ -904,6 +931,10 @@ JS
$this->fieldFormatting = $formatting; $this->fieldFormatting = $formatting;
} }
function setFieldEscape($escape){
$this->fieldEscape = $escape;
}
/** /**
* @return String * @return String
*/ */
@ -1057,14 +1088,21 @@ class TableListField_Item extends ViewableData {
$format = str_replace('__VAL__', '$value', $format); $format = str_replace('__VAL__', '$value', $format);
eval('$value = "' . $format . '";'); eval('$value = "' . $format . '";');
} }
//escape
if($escape = $this->parent->fieldEscape){
foreach($escape as $search => $replace){
$value = str_replace($search, $replace, $value);
}
}
$fields[] = new ArrayData(array( $fields[] = new ArrayData(array(
"Name" => $fieldName, "Name" => $fieldName,
"Title" => $fieldTitle, "Title" => $fieldTitle,
"Value" => $value, "Value" => $value,
"CsvSeparator" => $this->parent->getCsvSeparator(),
)); ));
} }
return new DataObjectSet($fields); return new DataObjectSet($fields);
} }

View File

@ -114,7 +114,10 @@ class SearchContext extends Object {
$SQL_sort = (!empty($sort)) ? Convert::raw2sql($sort) : singleton($this->modelClass)->stat('default_sort'); $SQL_sort = (!empty($sort)) ? Convert::raw2sql($sort) : singleton($this->modelClass)->stat('default_sort');
$query->orderby($SQL_sort); $query->orderby($SQL_sort);
foreach($searchParams as $key => $value) { foreach($searchParams as $key => $value) {
//if ($value != '0') { /*We add $value!='' here to not include a filter like this: $fieldname like '%%', which abviously filter out some
records with the $fieldname set to null. and this is not the search intention.
*/
if ($value != '0'&&$value!='') {
$key = str_replace('__', '.', $key); $key = str_replace('__', '.', $key);
$filter = $this->getFilter($key); $filter = $this->getFilter($key);
if ($filter) { if ($filter) {

View File

@ -0,0 +1 @@
<% control Fields %>"$Value"<% if Last %>\n<% else %>$CsvSeparator<% end_if %><% end_control %>