class GridFieldSortableHeader implements GridField_HTMLProvider, GridField_DataManipulator, GridField_ActionProvider (View source)

GridFieldSortableHeader adds column headers to a {@link GridField} that can also sort the columns.

Properties

array $fieldSorting

Methods

setThrowExceptionOnBadDataType($throwExceptionOnBadDataType)

Determine what happens when this component is used with a list that isn't {@link SS_Filterable}.

getThrowExceptionOnBadDataType()

See {@link setThrowExceptionOnBadDataType()}

$this
setFieldSorting(array $sorting)

Specify sortings with fieldname as the key, and actual fieldname to sort as value.

array
getFieldSorting()

No description

array
getHTMLFragments($gridField)

Returns the header row providing titles with sort buttons

array
getActions($gridField)

No description

handleAction(GridField $gridField, $actionName, $arguments, $data)

Handle an action on the given {@link GridField}.

getManipulatedData(GridField $gridField, SS_List $dataList)

Returns the manipulated (sorted) DataList. Field names will simply add an 'ORDER BY' clause, relation names will add appropriate joins to the {@link DataQuery} first.

Details

setThrowExceptionOnBadDataType($throwExceptionOnBadDataType)

Determine what happens when this component is used with a list that isn't {@link SS_Filterable}.

  • true: An exception is thrown
    • false: This component will be ignored - it won't make any changes to the GridField.

By default, this is set to true so that it's clearer what's happening, but the predefined {@link GridFieldConfig} subclasses set this to false for flexibility.

Parameters

$throwExceptionOnBadDataType

getThrowExceptionOnBadDataType()

See {@link setThrowExceptionOnBadDataType()}

$this setFieldSorting(array $sorting)

Specify sortings with fieldname as the key, and actual fieldname to sort as value.

Example: array("MyCustomTitle"=>"Title", "MyCustomBooleanField" => "ActualBooleanField")

Parameters

array $sorting

Return Value

$this

array getFieldSorting()

Return Value

array

array getHTMLFragments($gridField)

Returns the header row providing titles with sort buttons

Parameters

$gridField

Return Value

array

array getActions($gridField)

Parameters

$gridField

Return Value

array

with action identifier strings.

handleAction(GridField $gridField, $actionName, $arguments, $data)

Handle an action on the given {@link GridField}.

Calls ALL components for every action handled, so the component needs to ensure it only accepts actions it is actually supposed to handle.

Parameters

GridField $gridField
$actionName
$arguments
$data

DataList getManipulatedData(GridField $gridField, SS_List $dataList)

Returns the manipulated (sorted) DataList. Field names will simply add an 'ORDER BY' clause, relation names will add appropriate joins to the {@link DataQuery} first.

Parameters

GridField $gridField
SS_List $dataList

Return Value

DataList