mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
(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:
parent
935ee6d1bc
commit
124a6e3934
@ -2626,6 +2626,12 @@ class DataObject extends ViewableData implements DataObjectInterface {
|
|||||||
*/
|
*/
|
||||||
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;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
@ -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;
|
|
||||||
}
|
}
|
||||||
$fileData .= implode($separator, $columnData);
|
|
||||||
$fileData .= "\n";
|
$this->setFieldFormatting(array());
|
||||||
|
$this->setFieldEscape(array(
|
||||||
|
"\""=>"\"\"",
|
||||||
|
"\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
|
||||||
*/
|
*/
|
||||||
@ -1058,13 +1089,20 @@ class TableListField_Item extends ViewableData {
|
|||||||
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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) {
|
||||||
|
1
templates/Includes/TableListField_Item_export.ss
Executable file
1
templates/Includes/TableListField_Item_export.ss
Executable file
@ -0,0 +1 @@
|
|||||||
|
<% control Fields %>"$Value"<% if Last %>\n<% else %>$CsvSeparator<% end_if %><% end_control %>
|
Loading…
Reference in New Issue
Block a user