SortableColumns has been included into the core repository.
SortableColumns is a Zikula component to help manage data table column headings that can be clicked to sort the data.
The collection is an Doctrine\Common\Collections\ArrayCollection
of Zikula\Component\SortableColumns\Column
objects.
Use SortableColumns::generateSortableColumns
to create an array of attributes (url, css class) indexed by column name
which can be used in the generation of table headings/links.
use Zikula\Component\SortableColumns\SortableColumns;
// in controller method
$orderBy = $request->query->get('orderby', 'pageid');
$currentSortDirection = $request->query->get('sdir', Column::DIRECTION_DESCENDING);
$sortableColumns = new SortableColumns($this->get('router'), 'zikulapagesmodule_admin_index', 'orderby', 'sdir');
$sortableColumns->addColumn(new Column('pageid')); // first added is automatically the default
$sortableColumns->addColumn(new Column('title'));
$sortableColumns->addColumn(new Column('cr_date'));
$sortableColumns->setOrderBy($sortableColumns->getColumn($orderBy), $currentSortDirection);
$sortableColumns->setAdditionalUrlParameters(array(
'language' => isset($filterData['language']) ? $filterData['language'] : null,
));
$templateParameters['sort'] = $sortableColumns->generateSortableColumns();
<tr>
<th><a class='{{ sort.pageid.class }}' href='{{ sort.pageid.url }}'>{% trans %}ID{% endtrans %}</a></th>
<th><a class='{{ sort.title.class }}' href='{{ sort.title.url }}'>{% trans %}Title{% endtrans %}</a></th>
<th><a class='{{ sort.cr_date.class }}' href='{{ sort.cr_date.url }}'>{% trans %}Created{% endtrans %}</a></th>
</tr>
Additional shortcut methods are available:
$sortableColumns->addColumns()
$sortableColumns->setOrderByFromRequest()
$sortableColumns->addColumns([new Column('pageid'), new Column('title'), new Column('cr_date')]);
$sortableColumns->setOrderByFromRequest($request);
If needed, you can obtain the values of the orderByFields (e.g. for a DB query) using:
$sortableColumns->getSortColumn()->getName()
$sortableColumns->getSortDirection()