mirror of
https://github.com/colymba/GridFieldBulkEditingTools.git
synced 2024-10-22 11:05:57 +02:00
155 lines
6.0 KiB
Markdown
155 lines
6.0 KiB
Markdown
GridField Bulk Editing Tools
|
|
============================
|
|
SilverStripe 3 GridField component set to facilitate bulk image upload, bulk record editing, unlinking and deleting.
|
|
Included are:
|
|
* [Bulk Image Upload](#bulk-image-upload): Bulk images upload and on the fly fields editing
|
|
* [Bulk Manager](#bulk-manager): Delete and unlink multiple records at once as well as editing records in bulk
|
|
|
|
Take a look at the [Notes](#notes) and [TODOs](#todo).
|
|
|
|
## Requirements
|
|
* SilverStripe 3.1 (version 1.+)
|
|
* Silverstripe 3.0 (version [0.5](https://github.com/colymba/GridFieldBulkEditingTools/tree/0.5))
|
|
|
|
## Preview
|
|
![preview](screenshots/preview.png)
|
|
[More screenshots here.](screenshots)
|
|
|
|
## Installation
|
|
* Download and copy module in SilverStripe root directory and name it whatever you want
|
|
* Run dev/build?flush=all to regenerate the manifest
|
|
* run ?flush=all in CMS to force the templates to regenerate
|
|
|
|
## Bulk Image Upload
|
|
A component for uploading images in bulk into the managed Model relation, with option to edit fields on the fly.
|
|
|
|
### Usage 1
|
|
Simplest usage, add the component to your GridField as below. The component will find the first Image has_one relation on the managed Model and the record's editable CMS fields
|
|
|
|
$config->addComponent(new GridFieldBulkImageUpload());
|
|
|
|
### Usage 2
|
|
You can specify which Image field to use and which fields are editable from the managed Model
|
|
$imageField (string): The name of the image field to use (should have 'ID' at the end: If your relation is set has 'MyImage' => 'Image', the parameter should be 'MyImageID')
|
|
$editableFields (array): list of db fields name as string that will be editable like: array('myTextField', 'myVarcharField', 'myEnumField')
|
|
|
|
$config->addComponent(new GridFieldBulkImageUpload( $imageField, $editableFields ));
|
|
|
|
### Configuration
|
|
The component's option can be configurated individually or in bulk through the 'config' functions like this:
|
|
|
|
$config->getComponentByType('GridFieldBulkImageUpload')->setConfig( $reference, $value );
|
|
|
|
#### $config overview
|
|
The available configuration options are:
|
|
* 'imageFieldName' : sets the name of the Image field of the managed Model (i.e. 'MyImageID')
|
|
* 'editableFields' : array of string referencing specific CMS fields available for editing
|
|
* 'fieldsClassBlacklist' : array of string referencing types (ClassName) of fields that wont be available for editing
|
|
* 'fieldsNameBlacklist' : array of string referencing the names of fields that wont be available for editing
|
|
* 'folderName' : name of the folder where the images should be uploaded
|
|
* 'sequentialUploads' : boolean, if true files will be uploaded one by one
|
|
* 'maxFileSize' : integer, maximum upload file size in bytes
|
|
|
|
Each option can be set through the component's method setConfig( $reference, $value )
|
|
In addition, some configuration option can be set more specifically via individual methods:
|
|
* addFieldNameToBlacklist( $fieldName )
|
|
* addClassToBlacklist( $className )
|
|
* removeFieldNameFromBlacklist( $fieldName )
|
|
* removeClassFromBlacklist( $className )
|
|
|
|
### Sample Files
|
|
|
|
#### Page Model
|
|
|
|
class Page extends SiteTree {
|
|
|
|
public static $db = array(
|
|
);
|
|
|
|
public static $has_many = array(
|
|
'Visuals' => 'Visual'
|
|
);
|
|
|
|
public function getCMSFields() {
|
|
$fields = parent::getCMSFields();
|
|
|
|
$config = GridFieldConfig_RelationEditor::create();
|
|
$config->addComponent(new GridFieldBulkImageUpload());
|
|
$f = new GridField('Visuals', 'Case Study Visuals', $this->Visuals(), $config);
|
|
$fields->addFieldToTab('Root.Visuals', $f);
|
|
|
|
return $fields;
|
|
}
|
|
|
|
}
|
|
|
|
#### Visual Model
|
|
('Image', 'Type', 'Title' and 'Embed' Fields will be picked up automatically by the component)
|
|
|
|
class Visual extends DataObject
|
|
{
|
|
public static $db = array(
|
|
'Type' => "Enum('Image,Embed','Image')",
|
|
'Title' => 'Text',
|
|
'Embed' => 'HTMLText'
|
|
);
|
|
|
|
public static $has_one = array(
|
|
'Page' => 'Page',
|
|
'Image' => 'Image'
|
|
);
|
|
|
|
public function getCMSFields() {
|
|
$fields = new FieldList();
|
|
|
|
$fields->push( new DropdownField(
|
|
'Type',
|
|
'Type of visual',
|
|
singleton('Visual')->dbObject('Type')->enumValues()
|
|
));
|
|
|
|
$fields->push( new TextField('Title', 'Title and Caption for images (useful for SEO)') );
|
|
$fields->push( new TextareaField('Embed', 'HTML Embed code') );
|
|
|
|
$f = new UploadField('Image', 'Image file');
|
|
$fields->push($f);
|
|
|
|
return $fields;
|
|
}
|
|
}
|
|
|
|
## Bulk Manager
|
|
A component for Editing, deleting and unlinking records on the fly
|
|
|
|
### Usage
|
|
Add GridFieldBulkEditingTools component if not done already and simply add GridFieldBulkImageUpload
|
|
|
|
$config->addComponent(new GridFieldBulkManager());
|
|
|
|
### Configuration
|
|
The component's option can be configurated individually or in bulk through the 'config' functions like this:
|
|
|
|
$config->getComponentByType('GridFieldBulkManager')->setConfig( $reference, $value );
|
|
|
|
#### $config overview
|
|
The available configuration options are:
|
|
* 'editableFields' : array of string referencing specific CMS fields available for editing
|
|
* 'fieldsClassBlacklist' : array of string referencing types (ClassName) of fields that wont be available for editing
|
|
* 'fieldsNameBlacklist' : array of string referencing the names of fields that wont be available for editing
|
|
|
|
## Notes
|
|
* The HTML form fields for each editable fields are taken from the Model's getCMSFields() method
|
|
* This is still pretty experimental and probably needs a bit more in depth testing
|
|
* The code could probably be written better and/or cleaned up
|
|
* The Components take bit and pieces around from CMSFileAddController, GridFieldDetailForm_ItemRequest, UploadField, overrides and adds some behaviors, templates and styles...
|
|
|
|
## @TODO
|
|
|
|
### Common bug
|
|
* When editing fields, if the last field of the edit form is a drop down or similar, the drop down menu is cropped off
|
|
* Some 'minor' things just don't work
|
|
|
|
### Bulk Image Upload
|
|
* Add individual actions for each upload (update + cancel)
|
|
* Handle and display errors better for: creation, update, cancel
|
|
* Make it work not only for images -> might need to rename this component then? -> should be handled by another component |