2012-05-09 10:13:49 -07:00
|
|
|
SortableGridField
|
|
|
|
=================
|
2017-11-29 14:05:37 +00:00
|
|
|
|
2019-01-08 12:23:14 -04:00
|
|
|
[![Build Status](https://travis-ci.org/UndefinedOffset/SortableGridField.png)](https://travis-ci.org/UndefinedOffset/SortableGridField)
|
2012-05-09 10:13:49 -07:00
|
|
|
|
2017-05-27 14:45:28 +10:00
|
|
|
Adds drag and drop functionality to SilverStripe 4's GridField
|
2012-05-09 14:31:28 -03:00
|
|
|
|
2012-11-24 14:17:54 -04:00
|
|
|
## Requirements
|
2017-11-29 14:05:37 +00:00
|
|
|
|
2017-05-27 14:45:28 +10:00
|
|
|
* SilverStripe 4.x
|
2012-06-18 20:21:42 -03:00
|
|
|
|
2012-06-26 16:13:23 -03:00
|
|
|
## Installation
|
2017-05-27 14:45:28 +10:00
|
|
|
|
|
|
|
Installation is supported via composer only
|
|
|
|
|
|
|
|
```sh
|
2015-09-18 15:30:26 -03:00
|
|
|
composer require undefinedoffset/sortablegridfield
|
|
|
|
```
|
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
* Run `dev/build?flush=all` to regenerate the manifest
|
|
|
|
* Upon entering the cms and using `GridFieldSortableRows` component for the first time you make need to add `?flush=all`
|
|
|
|
to the end of the address to force the templates to regenerate
|
2012-06-26 16:13:23 -03:00
|
|
|
|
2012-05-09 14:31:28 -03:00
|
|
|
## Usage
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
To enable sorting on a `has_many` relationship set up an integer field on your data object. Also for `has_many`
|
|
|
|
relationships make sure to set the `$default_sort` on the `DataObject` to this new integer field to ensure that the sort
|
|
|
|
order is applied when the relationship is requested. For `many_many` relationships you must add a
|
|
|
|
`$many_many_extraFields` static to the `DataObject` defining the relationship, see the
|
|
|
|
[SilverStripe documentation](https://docs.silverstripe.org/en/3/developer_guides/model/relations/#many-many)
|
|
|
|
for more information on this. If you are using a `many_many` relationship you will need to do a custom getter to set the
|
|
|
|
sort order of this relationship for use on the front end see below for an example. As well for `many_many` relationships
|
|
|
|
the name of the GridField *must* be the same as the relationship name other wise error's will occur. For new
|
|
|
|
`DataObject`s you do not need to increment the sort order yourself in your `DataObject`, `GridFieldSortableRows` will
|
|
|
|
automatically do this the next time the grid is displayed.
|
2012-07-10 11:36:54 -03:00
|
|
|
|
2012-10-10 10:38:21 -03:00
|
|
|
```php
|
|
|
|
public function getMyManyManyRelationship() {
|
|
|
|
return $this->getManyManyComponents('MyManyManyRelationship')->sort('SortColumn');
|
|
|
|
}
|
|
|
|
```
|
2012-07-10 11:28:38 -03:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
To enable drag and drop sorting on the `GridField` add the following to your `GridField`'s config, also make sure you add
|
|
|
|
the namespace `UndefinedOffset\SortableGridField\Forms` to your file.
|
2012-05-09 14:39:14 -03:00
|
|
|
|
2012-10-10 10:38:21 -03:00
|
|
|
```php
|
2017-11-29 14:05:37 +00:00
|
|
|
//Namespace imports should be added to the top of your file
|
|
|
|
use UndefinedOffset\SortableGridField\Forms\GridFieldSortableRows;
|
2017-09-11 11:37:22 -03:00
|
|
|
|
2012-10-10 10:38:21 -03:00
|
|
|
$myGridConfig->addComponent(new GridFieldSortableRows('{Column to store sort}'));
|
|
|
|
```
|
2012-05-16 22:41:14 -03:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
To move an item to another page drag the row over the respective move to page button which appear on the left and right
|
|
|
|
of the GridField and release.
|
2012-05-16 22:41:14 -03:00
|
|
|
|
2012-11-24 14:17:54 -04:00
|
|
|
#### Full code Examples
|
2017-11-29 14:05:37 +00:00
|
|
|
|
2017-09-11 11:37:22 -03:00
|
|
|
* [has_many relationship](https://github.com/UndefinedOffset/SortableGridField/blob/master/docs/HasManyExample.md)
|
|
|
|
* [many_many relationship](https://github.com/UndefinedOffset/SortableGridField/blob/master/docs/ManyManyExample.md)
|
|
|
|
* [ModelAdmin implementation](https://github.com/UndefinedOffset/SortableGridField/blob/master/docs/ModelAdminExample.md)
|
2012-11-24 14:17:54 -04:00
|
|
|
|
2013-08-04 12:15:37 -03:00
|
|
|
#### Events
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
`GridFieldSortableRows` provides 4 "events" `onBeforeGridFieldRowSort()`, `onAfterGridFieldRowSort()`,
|
|
|
|
`onBeforeGridFieldPageSort()` and `onAfterGridFieldPageSort()`. These "events" are passed a clone of the `DataList`
|
|
|
|
used in `GridFieldSortableRows`, in the case of page sorting this list has a limit that shows you the current page
|
|
|
|
plus/minus one object. For `GridFieldSortableRows` that are on `ModelAdmin` descendants these events are called on the
|
|
|
|
`ModelAdmin` if they do not have an owner `DataObject`, if you are using `GridFieldSortableRows` on a `GridField` for a
|
|
|
|
`DataObject`'s relationship the events are called on that `DataObject`.
|
2013-08-04 12:15:37 -03:00
|
|
|
|
2013-10-19 14:43:26 -03:00
|
|
|
#### Appending to the top instead of the bottom
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
By default `GridFieldSortableRows` appends to the bottom of the list for performance on large data sets, however you can
|
|
|
|
set new records to append new records to the top by calling `setAppendToTop(true)` on your `GridFieldSortableRows`
|
|
|
|
instance.
|
|
|
|
|
2013-10-19 14:43:26 -03:00
|
|
|
```php
|
2017-11-29 14:05:37 +00:00
|
|
|
//Namespace imports should be added to the top of your file
|
|
|
|
use UndefinedOffset\SortableGridField\Forms\GridFieldSortableRows;
|
2017-09-11 11:37:22 -03:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
$myGridConfig->addComponent($sortable = new GridFieldSortableRows('SortOrder'));
|
2014-02-24 16:03:50 -04:00
|
|
|
$sortable->setAppendToTop(true);
|
2013-10-19 14:43:26 -03:00
|
|
|
```
|
|
|
|
|
2016-02-06 17:00:23 -04:00
|
|
|
#### Working with versioned records
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
By default `GridFieldSortableRows` does not update any other stage for versioned than the base stage. However you can
|
|
|
|
enable this by calling `setUpdateVersionedStage()` and passing in the name of the stage you want to update along with
|
|
|
|
the base stage. For example passing in "Live" will also update the "Live" stage when any sort happens.
|
|
|
|
|
2016-02-06 17:00:23 -04:00
|
|
|
```php
|
2017-11-29 14:05:37 +00:00
|
|
|
//Namespace imports should be added to the top of your file
|
|
|
|
use UndefinedOffset\SortableGridField\Forms\GridFieldSortableRows;
|
2017-09-11 11:37:22 -03:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
$myGridConfig->addComponent($sortable = new GridFieldSortableRows('SortOrder'));
|
2016-02-06 17:00:23 -04:00
|
|
|
$sortable->setUpdateVersionedStage('Live');
|
|
|
|
```
|
|
|
|
|
2016-02-09 13:26:34 -04:00
|
|
|
#### Overriding the default relationship name
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
By default the relationship name comes from the name of the `GridField`, however you can override this lookup by
|
|
|
|
calling `setCustomRelationName()` and passing in the name of the relationship. This allows for you to have multiple
|
|
|
|
`GridFields` on the same form interacting with the same `many_many` list maybe filtered slightly differently.
|
|
|
|
|
2016-02-09 13:26:34 -04:00
|
|
|
```php
|
2017-11-29 14:05:37 +00:00
|
|
|
//Namespace imports should be added to the top of your file
|
|
|
|
use UndefinedOffset\SortableGridField\Forms\GridFieldSortableRows;
|
2017-09-11 11:37:22 -03:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
$myGridConfig->addComponent($sortable = new GridFieldSortableRows('SortOrder'));
|
2016-02-09 13:26:34 -04:00
|
|
|
$sortable->setCustomRelationName('MyRelationship');
|
|
|
|
```
|
|
|
|
|
2013-07-24 20:45:49 -03:00
|
|
|
## Reporting an issue
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
When you're reporting an issue please ensure you specify what version of SilverStripe you are using i.e. 3.0.5,
|
|
|
|
3.1beta3, 3.0-master etc. Also be sure to include any JavaScript or PHP errors you receive, for PHP errors please ensure
|
|
|
|
you include the full stack trace. Also please include your implementation code (where your setting up your grid field)
|
|
|
|
as well as how you produced the issue. You may also be asked to provide some of the classes to aid in re-producing the
|
|
|
|
issue. Stick with the issue, remember that you seen the issue not the maintainer of the module so it may take a lot of
|
|
|
|
questions to arrive at a fix or answer.
|
2013-08-04 12:23:28 -03:00
|
|
|
|
|
|
|
### Notes
|
2017-11-29 14:05:37 +00:00
|
|
|
|
|
|
|
* When using with GridFieldManyRelationHandler make sure that you add GridFieldSortableRows to your config before for
|
|
|
|
example `GridFieldManyRelationHandler`:
|
|
|
|
|
2017-05-27 14:45:28 +10:00
|
|
|
```php
|
2017-11-29 14:05:37 +00:00
|
|
|
//Namespace imports should be added to the top of your file
|
|
|
|
use UndefinedOffset\SortableGridField\Forms\GridFieldSortableRows;
|
2017-09-11 11:37:22 -03:00
|
|
|
|
2017-05-27 14:45:28 +10:00
|
|
|
$config->addComponent(new GridFieldSortableRows('SortOrder'), 'GridFieldManyRelationHandler');
|
|
|
|
```
|
2013-10-24 23:13:29 +02:00
|
|
|
|
|
|
|
## Contributing
|
|
|
|
|
|
|
|
### Translations
|
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
Translations of the natural language strings are managed through a third party translation interface, transifex.com.
|
|
|
|
Newly added strings will be periodically uploaded there for translation, and any new translations will be merged back to
|
|
|
|
the project source code.
|
2013-10-24 23:13:29 +02:00
|
|
|
|
2017-11-29 14:05:37 +00:00
|
|
|
Please use [https://www.transifex.com/projects/p/silverstripe-sortablegridfield](https://www.transifex.com/projects/p/silverstripe-sortablegridfield)
|
|
|
|
to contribute translations, rather than sending pull requests with YAML files.
|