GridFieldBulkEditingTools/docs/en/BULK_MANAGER.md

41 lines
1.7 KiB
Markdown
Raw Permalink Normal View History

2013-12-05 18:42:17 +01:00
# Bulk Manager
2014-05-04 17:13:03 +02:00
Perform actions on multiple records straight from the GridField. Comes with *unlink*, *delete* and bulk *editing*. You can also easily create/add your own.
2013-12-05 18:42:17 +01:00
## Usage
2014-05-04 17:13:03 +02:00
Simply add component to your `GridFieldConfig`
```php
$config->addComponent(new \Colymba\BulkManager\BulkManager());
```
2013-12-05 18:42:17 +01:00
## Configuration
2014-05-04 17:13:03 +02:00
The component's options can be configurated individually or in bulk through the 'config' functions like this:
2013-12-05 18:42:17 +01:00
```php
$config->getComponentByType('Colymba\\BulkManager\\BulkManager')->setConfig($reference, $value);
```
2013-12-05 18:42:17 +01:00
### $config overview
The available configuration options are:
* 'editableFields' : array of string referencing specific CMS fields available for editing
## Custom actions
You can remove or add individual action or replace them all via `addBulkAction()` and `removeBulkAction()`
### Adding a custom action
To add a custom bulk action to the list use:
```php
$config
->getComponentByType('Colymba\\BulkManager\\BulkManager')
2018-02-12 14:32:28 +01:00
->addBulkAction('Namespace\\ClassName')
```
2013-12-05 18:42:17 +01:00
#### Custom action handler
When creating your own bulk action `RequestHandler`, you should extend `Colymba\BulkManager\BulkAction\Handler` which will expose 2 useful functions `getRecordIDList()` and `getRecords()` returning either an array with the selected records IDs or a `DataList` of the selected records.
2013-12-05 18:42:17 +01:00
2018-02-12 14:32:28 +01:00
Make sure to define the handler's `$url_segment`, from which the handler will be called and its relating `$allowed_actions` and `$url_handlers`. See `Handler`, `DeleteHandler` and `UnlinkHandler` for examples.
2013-12-05 18:42:17 +01:00
#### Front-end config
2018-02-12 14:32:28 +01:00
Bulk action handler's front-end configuration is set via class properties `label`, `icon`, `buttonClasses`, `xhr` and `destructive`. See `Handler`, `DeleteHandler` and `UnlinkHandler` for reference and examples.