2012-08-09 23:52:46 +02:00
GridField Bulk Editing Tools
============================
SilverStripe 3 GridField component set to facilitate bulk editing, adding and deletion of records.
The Components take bit and pieces around from CMSFileAddController, GridFieldDetailForm_ItemRequest, UploadField, overrides and adds some behaviors, templates and styles...
2012-07-16 22:31:51 +02:00
2012-07-18 01:27:28 +02:00
## Requirments
* SilverStripe 3.0
## Installation
2012-08-09 23:52:46 +02:00
* Download and copy module in SilverStripe root directory and name it whatever you want
2012-07-18 01:27:28 +02:00
* Run dev/build?flush=all to regenerate the manifest
* run ?flush=all in CMS to force the templates to regenerate
2012-08-09 23:55:01 +02:00
# 1/ Bulk Image Upload
2012-08-09 23:52:46 +02:00
A component for uploading images in bulk into the managed Model relation, with option to edit fields on the fly.
2012-07-19 14:00:11 +02:00
## Usage
### Usage 1
2012-08-09 23:52:46 +02:00
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 it's editable CMS fields
$config->addComponent(new GridFieldBulkEditingTools());
2012-07-18 01:27:28 +02:00
$config->addComponent(new GridFieldBulkImageUpload());
2012-07-19 14:00:11 +02:00
### 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')
2012-08-09 23:52:46 +02:00
$config->addComponent(new GridFieldBulkEditingTools());
2012-07-18 01:27:28 +02:00
$config->addComponent(new GridFieldBulkImageUpload( $imageField, $editableFields ));
2012-08-09 23:52:46 +02:00
### Configuration
The component's option can be configurated individually or in bulk through the 'config' functions
#### $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
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 )
2012-07-19 14:00:11 +02:00
### Sample Files
2012-07-19 14:03:50 +02:00
#### Page Model
2012-07-19 14:00:11 +02:00
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();
2012-08-09 23:52:46 +02:00
$config->addComponent(new GridFieldBulkEditingTools());
2012-07-19 14:00:11 +02:00
$config->addComponent(new GridFieldBulkImageUpload());
$f = new GridField('Visuals', 'Case Study Visuals', $this->Visuals(), $config);
$fields->addFieldToTab('Root.Visuals', $f);
return $fields;
}
}
2012-07-19 14:03:50 +02:00
#### Visual Model
2012-07-19 14:00:11 +02:00
('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;
}
}
2012-07-18 01:27:28 +02:00
## Notes
2012-07-19 14:03:50 +02:00
* The HTML form fields for each editable fields are taken from the Model's getCMSFields() method
2012-07-18 01:27:28 +02:00
2012-08-09 23:52:46 +02:00
# @TODO
## Bulk Editing Tools
* Create the rest of the Components...
## Bulk Image Upload
2012-07-19 14:00:11 +02:00
* Add individual actions for each upload (update + cancel)
2012-07-18 14:23:51 +02:00
* Handle and display errors better for: creation, update, cancel
2012-08-09 23:52:46 +02:00
* Make it work not only for images -> might need to rename this component then? -> should be handled by another component