GridFieldExportReportButton
class GridFieldExportReportButton extends GridFieldExportButton (View source)
An extension to GridFieldExportButton to support downloading a custom Report as a CSV file
This code was adapted from a solution posted in SilverStripe.org forums: http://www.silverstripe.org/customising-the-cms/show/38202
Traits
A class that can be instantiated or replaced via DI
Properties
protected | array | $exportColumns | from GridFieldExportButton | |
protected | string | $csvSeparator | from GridFieldExportButton | |
protected | string | $csvEnclosure | from GridFieldExportButton | |
protected | bool | $csvHasHeader | from GridFieldExportButton | |
protected | $targetFragment | Fragment to write the button to |
from GridFieldExportButton |
Methods
An implementation of the factory method, allows you to create an instance of a class
Creates a class instance by the "singleton" design pattern.
Handle an action on the given GridField.
Handle the export, for both the action button and the URL
Details
static Injectable
create(mixed ...$args)
An implementation of the factory method, allows you to create an instance of a class
This method will defer class substitution to the Injector API, which can be customised via the Config API to declare substitution classes.
This can be called in one of two ways - either calling via the class directly, or calling on Object and passing the class name as the first parameter. The following are equivalent: $list = DataList::create(SiteTree::class); $list = SiteTree::get();
static Injectable
singleton(string $class = null)
Creates a class instance by the "singleton" design pattern.
It will always return the same instance for this class, which can be used for performance reasons and as a simple way to access instance methods which don't rely on instance data (e.g. the custom SilverStripe static handling).
__construct(string $targetFragment = "after", array $exportColumns = null)
No description
array
getHTMLFragments(GridField $gridField)
Place the export button in a
tag below the field
array
getActions(GridField $gridField)
export is an action button
handleAction(GridField $gridField, string $actionName, array $arguments, array $data)
Handle an action on the given GridField.
Calls ALL components for every action handled, so the component needs to ensure it only accepts actions it is actually supposed to handle.
array
getURLHandlers(GridField $gridField)
it is also a URL
HTTPResponse
handleExport(GridField $gridField, HTTPRequest $request = null)
Handle the export, for both the action button and the URL
protected array
getExportColumnsForGridField(GridField $gridField)
Return the columns to export
string
generateExportFileData(GridField $gridField)
Generate export fields for CSV.
Replaces the definition in GridFieldExportButton, this is the same as original except it sources the List from $gridField->getList() instead of $gridField->getManipulatedList()
array
getExportColumns()
No description
$this
setExportColumns(array $cols)
No description
string
getCsvSeparator()
No description
$this
setCsvSeparator(string $separator)
No description
string
getCsvEnclosure()
No description
$this
setCsvEnclosure(string $enclosure)
No description
bool
getCsvHasHeader()
No description
$this
setCsvHasHeader(bool $bool)
No description