2012-04-03 16:56:43 +12:00
|
|
|
<?php
|
2013-05-20 22:18:07 +12:00
|
|
|
|
2015-08-30 17:02:55 +12:00
|
|
|
use SilverStripe\Model\FieldType\DBDatetime;
|
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
/**
|
2013-03-05 10:29:27 +13:00
|
|
|
* Adds an "Print" button to the bottom or top of a GridField.
|
|
|
|
*
|
2013-11-29 17:12:47 +13:00
|
|
|
* @package forms
|
2013-05-20 22:18:07 +12:00
|
|
|
* @subpackage fields-gridfield
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
|
|
|
class GridFieldPrintButton implements GridField_HTMLProvider, GridField_ActionProvider, GridField_URLHandler {
|
|
|
|
|
|
|
|
/**
|
2014-08-15 18:53:05 +12:00
|
|
|
* @var array Map of a property name on the printed objects, with values
|
2013-03-05 10:29:27 +13:00
|
|
|
* being the column title in the CSV file.
|
|
|
|
*
|
|
|
|
* Note that titles are only used when {@link $csvHasHeader} is set to TRUE
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
|
|
|
protected $printColumns;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected $printHasHeader = true;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
/**
|
2013-03-05 10:29:27 +13:00
|
|
|
* Fragment to write the button to.
|
|
|
|
*
|
|
|
|
* @var string
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
|
|
|
protected $targetFragment;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $targetFragment The HTML fragment to write the button into
|
|
|
|
* @param array $printColumns The columns to include in the print view
|
|
|
|
*/
|
|
|
|
public function __construct($targetFragment = "after", $printColumns = null) {
|
|
|
|
$this->targetFragment = $targetFragment;
|
|
|
|
$this->printColumns = $printColumns;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Place the print button in a <p> tag below the field
|
2013-03-05 10:29:27 +13:00
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
*
|
|
|
|
* @return array
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
|
|
|
public function getHTMLFragments($gridField) {
|
|
|
|
$button = new GridField_FormAction(
|
2014-08-15 18:53:05 +12:00
|
|
|
$gridField,
|
|
|
|
'print',
|
2012-04-03 16:56:43 +12:00
|
|
|
_t('TableListField.Print', 'Print'),
|
2014-08-15 18:53:05 +12:00
|
|
|
'print',
|
2012-04-03 16:56:43 +12:00
|
|
|
null
|
|
|
|
);
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
$button->setAttribute('data-icon', 'grid_print');
|
|
|
|
$button->addExtraClass('gridfield-button-print');
|
2016-02-22 10:03:03 +13:00
|
|
|
$button->addExtraClass('font-icon-print');
|
2016-03-09 09:50:18 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
return array(
|
2014-08-15 18:53:05 +12:00
|
|
|
$this->targetFragment => '<p class="grid-print-button">' . $button->Field() . '</p>',
|
2012-04-03 16:56:43 +12:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-03-05 10:29:27 +13:00
|
|
|
* Print is an action button.
|
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
*
|
|
|
|
* @return array
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
|
|
|
public function getActions($gridField) {
|
|
|
|
return array('print');
|
|
|
|
}
|
|
|
|
|
2013-03-05 10:29:27 +13:00
|
|
|
/**
|
|
|
|
* Handle the print action.
|
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
* @param string
|
|
|
|
* @param array
|
|
|
|
* @param array
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function handleAction(GridField $gridField, $actionName, $arguments, $data) {
|
2012-04-03 16:56:43 +12:00
|
|
|
if($actionName == 'print') {
|
|
|
|
return $this->handlePrint($gridField);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-03-05 10:29:27 +13:00
|
|
|
* Print is accessible via the url
|
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
* @return array
|
2012-04-03 16:56:43 +12:00
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getURLHandlers($gridField) {
|
2012-04-03 16:56:43 +12:00
|
|
|
return array(
|
|
|
|
'print' => 'handlePrint',
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle the print, for both the action button and the URL
|
|
|
|
*/
|
|
|
|
public function handlePrint($gridField, $request = null) {
|
|
|
|
set_time_limit(60);
|
|
|
|
Requirements::clear();
|
2012-03-24 16:38:57 +13:00
|
|
|
Requirements::css(FRAMEWORK_DIR . '/css/GridField_print.css');
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
if($data = $this->generatePrintData($gridField)){
|
|
|
|
return $data->renderWith("GridField_print");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-03-05 10:29:27 +13:00
|
|
|
* Return the columns to print
|
|
|
|
*
|
|
|
|
* @param GridField
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2013-03-05 10:29:27 +13:00
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function getPrintColumnsForGridField(GridField $gridField) {
|
2013-01-14 16:32:31 +01:00
|
|
|
if($this->printColumns) {
|
|
|
|
$printColumns = $this->printColumns;
|
|
|
|
} else if($dataCols = $gridField->getConfig()->getComponentByType('GridFieldDataColumns')) {
|
|
|
|
$printColumns = $dataCols->getDisplayFields($gridField);
|
|
|
|
} else {
|
|
|
|
$printColumns = singleton($gridField->getModelClass())->summaryFields();
|
|
|
|
}
|
2013-03-05 10:29:27 +13:00
|
|
|
|
|
|
|
return $printColumns;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the title of the printed page
|
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getTitle(GridField $gridField) {
|
|
|
|
$form = $gridField->getForm();
|
2014-06-12 15:31:03 +12:00
|
|
|
$currentController = $gridField->getForm()->getController();
|
2013-03-05 10:29:27 +13:00
|
|
|
$title = '';
|
|
|
|
|
|
|
|
if(method_exists($currentController, 'Title')) {
|
|
|
|
$title = $currentController->Title();
|
|
|
|
} else {
|
|
|
|
if ($currentController->Title) {
|
|
|
|
$title = $currentController->Title;
|
2014-12-18 15:00:09 +02:00
|
|
|
} elseif ($form->getName()) {
|
|
|
|
$title = $form->getName();
|
2013-03-05 10:29:27 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if($fieldTitle = $gridField->Title()) {
|
|
|
|
if($title) {
|
|
|
|
$title .= " - ";
|
|
|
|
}
|
|
|
|
|
|
|
|
$title .= $fieldTitle;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $title;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Export core.
|
|
|
|
*
|
|
|
|
* @param GridField
|
|
|
|
*/
|
|
|
|
public function generatePrintData(GridField $gridField) {
|
|
|
|
$printColumns = $this->getPrintColumnsForGridField($gridField);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-04-10 11:13:39 +12:00
|
|
|
$header = null;
|
2013-03-05 10:29:27 +13:00
|
|
|
|
|
|
|
if($this->printHasHeader) {
|
2012-04-03 16:56:43 +12:00
|
|
|
$header = new ArrayList();
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
foreach($printColumns as $field => $label){
|
2013-03-05 10:29:27 +13:00
|
|
|
$header->push(new ArrayData(array(
|
|
|
|
"CellString" => $label,
|
|
|
|
)));
|
2012-04-03 17:04:19 +12:00
|
|
|
}
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2013-03-05 10:27:15 +13:00
|
|
|
$items = $gridField->getManipulatedList();
|
2012-04-03 16:56:43 +12:00
|
|
|
$itemRows = new ArrayList();
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2015-11-12 14:59:08 +13:00
|
|
|
foreach($items->limit(null) as $item) {
|
2012-04-03 16:56:43 +12:00
|
|
|
$itemRow = new ArrayList();
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
foreach($printColumns as $field => $label) {
|
2012-05-29 10:06:30 +12:00
|
|
|
$value = $gridField->getDataFieldValue($item, $field);
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2015-02-10 18:01:19 +13:00
|
|
|
if($item->escapeTypeForField($field) != 'xml') {
|
2015-02-07 23:00:36 +00:00
|
|
|
$value = Convert::raw2xml($value);
|
|
|
|
}
|
|
|
|
|
2013-03-05 10:29:27 +13:00
|
|
|
$itemRow->push(new ArrayData(array(
|
|
|
|
"CellString" => $value,
|
|
|
|
)));
|
2012-04-03 16:56:43 +12:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2013-03-05 10:29:27 +13:00
|
|
|
$itemRows->push(new ArrayData(array(
|
|
|
|
"ItemRow" => $itemRow
|
|
|
|
)));
|
2015-04-01 21:55:24 +13:00
|
|
|
if ($item->hasMethod('destroy')) {
|
|
|
|
$item->destroy();
|
|
|
|
}
|
2012-04-03 16:56:43 +12:00
|
|
|
}
|
2013-03-05 10:29:27 +13:00
|
|
|
|
|
|
|
$ret = new ArrayData(array(
|
|
|
|
"Title" => $this->getTitle($gridField),
|
|
|
|
"Header" => $header,
|
|
|
|
"ItemRows" => $itemRows,
|
2015-08-30 17:02:55 +12:00
|
|
|
"Datetime" => DBDatetime::now(),
|
2013-03-05 10:29:27 +13:00
|
|
|
"Member" => Member::currentUser(),
|
|
|
|
));
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getPrintColumns() {
|
2012-04-03 16:56:43 +12:00
|
|
|
return $this->printColumns;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function setPrintColumns($cols) {
|
2012-04-03 16:56:43 +12:00
|
|
|
$this->printColumns = $cols;
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return boolean
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getPrintHasHeader() {
|
2012-04-03 16:56:43 +12:00
|
|
|
return $this->printHasHeader;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param boolean
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function setPrintHasHeader($bool) {
|
2012-04-03 16:56:43 +12:00
|
|
|
$this->printHasHeader = $bool;
|
2013-03-05 10:29:27 +13:00
|
|
|
|
2012-04-03 16:56:43 +12:00
|
|
|
return $this;
|
|
|
|
}
|
2014-06-12 15:31:03 +12:00
|
|
|
}
|