2012-07-16 23:39:01 +03:00
< ? php
2012-07-18 15:23:51 +03:00
/**
2015-12-16 01:08:57 +13:00
* GridField component for uploading images in bulk .
2012-08-07 23:51:54 +03:00
*
* @ author colymba
2012-07-18 15:23:51 +03:00
*/
2014-05-04 17:12:05 +03:00
class GridFieldBulkUpload implements GridField_HTMLProvider , GridField_URLHandler
2015-12-16 01:08:57 +13:00
{
/**
2016-01-18 16:49:00 +02:00
* Component configuration .
*
2015-12-16 01:08:57 +13:00
* 'fileRelationName' => field name of the $has_one File / Image relation
2016-01-18 16:49:00 +02:00
* 'objectClassName' => overrides the automatic DataObject class detection from gridfield -> dataClass with a custom class name
2015-12-16 01:08:57 +13:00
*
* @ var array
*/
protected $config = array (
'fileRelationName' => null ,
2016-01-18 16:49:00 +02:00
'objectClassName' => null
2015-12-16 01:08:57 +13:00
);
/**
* UploadField configuration .
* These options are passed on directly to the UploadField
* via { @ link UploadField :: setConfig ()} api .
*
2016-01-18 16:49:00 +02:00
* Defaults are : *
2015-12-16 01:08:57 +13:00
* 'sequentialUploads' => false : process uploads 1 after the other rather than all at once
* 'canAttachExisting' => true : displays " From files " button in the UploadField
* 'canPreviewFolder' => true : displays the upload location in the UploadField
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ var array
*/
protected $ufConfig = array (
'sequentialUploads' => false ,
2014-06-17 10:48:47 +01:00
'canAttachExisting' => true ,
2015-12-16 01:08:57 +13:00
'canPreviewFolder' => true ,
);
/**
* UploadField setup function calls .
* List of setup functions to call on { @ link UploadField } with the value to pass .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* e . g . array ( 'setFolderName' => 'bulkUpload' ) will result in :
* $uploadField -> setFolderName ( 'bulkUpload' )
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ var array
*/
protected $ufSetup = array (
'setFolderName' => 'bulkUpload' ,
);
/**
* UploadField Validator setup function calls .
* List of setup functions to call on { @ link Upload :: validator } with the value to pass .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* e . g . array ( 'setAllowedMaxFileSize' => 10 ) will result in :
* $uploadField -> getValidator () -> setAllowedMaxFileSize ( 10 )
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ var array
*/
protected $ufValidatorSetup = array (
'setAllowedMaxFileSize' => null ,
);
/**
* Component constructor .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $fileRelationName
*/
2016-01-18 16:49:00 +02:00
public function __construct ( $fileRelationName = null , $objectClassName = null )
2015-12-16 01:08:57 +13:00
{
if ( $fileRelationName != null ) {
$this -> setConfig ( 'fileRelationName' , $fileRelationName );
}
2016-01-18 16:49:00 +02:00
if ( $objectClassName != null ) {
$this -> setConfig ( 'objectClassName' , $objectClassName );
}
2015-12-16 01:08:57 +13:00
}
2014-04-05 19:54:50 +03:00
2015-12-16 01:08:57 +13:00
/* **********************************************************************
* Components settings and custom methodes
* */
/**
* Set a component configuration parameter .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference
* @ param mixed $value
*/
public function setConfig ( $reference , $value )
2014-09-06 13:39:39 +03:00
{
2015-12-16 01:08:57 +13:00
if ( in_array ( $reference , array ( 'folderName' , 'maxFileSize' , 'sequentialUploads' , 'canAttachExisting' , 'canPreviewFolder' ))) {
Deprecation :: notice ( '2.1.0' , " GridFieldBulkUpload 'setConfig()' doesn't support ' $reference ' anymore. Please use 'setUfConfig()', 'setUfSetup()' or 'setUfValidatorSetup()' instead. " );
if ( $reference === 'folderName' ) {
$this -> setUfSetup ( 'setFolderName' , $value );
} elseif ( $reference === 'maxFileSize' ) {
$this -> setUfValidatorSetup ( 'setAllowedMaxFileSize' , $value );
} else {
$this -> setUfConfig ( $reference , $value );
}
} elseif ( ! array_key_exists ( $reference , $this -> config )) {
user_error ( " Unknown option reference: $reference " , E_USER_ERROR );
}
$this -> config [ $reference ] = $value ;
return $this ;
2014-09-06 13:39:39 +03:00
}
2014-04-05 19:54:50 +03:00
2015-12-16 01:08:57 +13:00
/**
* Set an UploadField configuration parameter .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference
* @ param mixed $value
*/
public function setUfConfig ( $reference , $value )
2014-09-06 13:39:39 +03:00
{
2015-12-16 01:08:57 +13:00
$this -> ufConfig [ $reference ] = $value ;
return $this ;
2014-09-06 13:39:39 +03:00
}
2014-04-05 19:54:50 +03:00
2015-12-16 01:08:57 +13:00
/**
* Set an UploadField setup function call .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $function
* @ param mixed $param
*/
public function setUfSetup ( $function , $param )
{
$this -> ufSetup [ $function ] = $param ;
return $this ;
}
/**
* Set an UploadField Validator setup function call .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $function
* @ param mixed $param
*/
public function setUfValidatorSetup ( $function , $param )
{
$this -> ufValidatorSetup [ $function ] = $param ;
return $this ;
}
/**
* Returns one $config reference or the full $config .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference $congif parameter to return
*
* @ return mixed
*/
public function getConfig ( $reference = false )
{
if ( $reference ) {
return $this -> config [ $reference ];
} else {
return $this -> config ;
}
}
/**
* Returns one $ufConfig reference or the full config .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference $ufConfig parameter to return
*
* @ return mixed
*/
public function getUfConfig ( $reference = false )
{
if ( $reference ) {
return $this -> ufConfig [ $reference ];
} else {
return $this -> ufConfig ;
}
}
/**
* Returns one $ufSetup reference or the full config .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference $ufSetup parameter to return
*
* @ return mixed
*/
public function getUfSetup ( $reference = false )
{
if ( $reference ) {
return $this -> ufSetup [ $reference ];
} else {
return $this -> ufSetup ;
}
}
/**
* Returns one $ufValidatorSetup reference or the full config .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param string $reference $ufValidatorSetup parameter to return
*
* @ return mixed
*/
public function getUfValidatorSetup ( $reference = false )
{
if ( $reference ) {
return $this -> ufValidatorSetup [ $reference ];
} else {
return $this -> ufValidatorSetup ;
}
}
/**
* Get the first has_one Image / File relation from the GridField managed DataObject
* i . e . 'MyImage' => 'Image' will return 'MyImage' .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ return string Name of the $has_one relation
*/
public function getDefaultFileRelationName ( $gridField )
{
$recordClass = $gridField -> list -> dataClass ;
$hasOneFields = Config :: inst () -> get ( $recordClass , 'has_one' , Config :: INHERITED );
$imageField = null ;
foreach ( $hasOneFields as $field => $type ) {
if ( $type === 'Image' || $type === 'File' || is_subclass_of ( $type , 'File' )) {
$imageField = $field ;
break ;
}
}
return $imageField ;
}
/**
* Returns the name of the Image / File field name from the managed record
* Either as set in the component config or the default one .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ return string
*/
public function getFileRelationName ( $gridField )
{
$configFileRelationName = $this -> getConfig ( 'fileRelationName' );
return $configFileRelationName ? $configFileRelationName : $this -> getDefaultFileRelationName ( $gridField );
}
/**
* Return the ClassName of the fileRelation
* i . e . 'MyImage' => 'Image' will return 'Image'
* i . e . 'MyImage' => 'File' will return 'File' .
*
* @ return string file relation className
*/
public function getFileRelationClassName ( $gridField )
{
$recordClass = $gridField -> list -> dataClass ;
$hasOneFields = Config :: inst () -> get ( $recordClass , 'has_one' , Config :: INHERITED );
$fieldName = $this -> getFileRelationName ( $gridField );
if ( $fieldName ) {
return $hasOneFields [ $fieldName ];
} else {
return 'File' ;
}
}
/**
* Returned a configured UploadField instance
* embedded in the gridfield heard .
*
* @ param GridField $gridField Current GridField
*
* @ return UploadField Configured UploadField instance
*/
public function bulkUploadField ( $gridField )
2014-09-06 13:39:39 +03:00
{
2015-12-16 01:08:57 +13:00
$fileRelationName = $this -> getFileRelationName ( $gridField );
$uploadField = UploadField :: create ( $fileRelationName , '' )
-> setForm ( $gridField -> getForm ())
-> setConfig ( 'previewMaxWidth' , 20 )
-> setConfig ( 'previewMaxHeight' , 20 )
-> setConfig ( 'changeDetection' , false )
-> setRecord ( DataObject :: create ()) // avoid UploadField to get auto-config from the Page (e.g fix allowedMaxFileNumber)
-> setTemplate ( 'GridFieldBulkUploadField' )
-> setDownloadTemplateName ( 'colymba-bulkuploaddownloadtemplate' )
-> setConfig ( 'url' , $gridField -> Link ( 'bulkupload/upload' ))
-> setConfig ( 'urlSelectDialog' , $gridField -> Link ( 'bulkupload/select' ))
-> setConfig ( 'urlAttach' , $gridField -> Link ( 'bulkupload/attach' ))
-> setConfig ( 'urlFileExists' , $gridField -> Link ( 'bulkupload/fileexists' ))
;
//set UploadField config
foreach ( $this -> ufConfig as $key => $val ) {
$uploadField -> setConfig ( $key , $val );
}
//UploadField setup
foreach ( $this -> ufSetup as $fn => $param ) {
$uploadField -> { $fn }( $param );
2014-09-06 13:39:39 +03:00
}
2015-12-16 01:08:57 +13:00
//UploadField Validator setup
foreach ( $this -> ufValidatorSetup as $fn => $param ) {
$uploadField -> getValidator () -> { $fn }( $param );
}
return $uploadField ;
}
/* **********************************************************************
* GridField_HTMLProvider
* */
/**
* HTML to be embedded into the GridField .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param GridField $gridField
*
* @ return array
*/
public function getHTMLFragments ( $gridField )
{
// permission check
if ( ! singleton ( $gridField -> getModelClass ()) -> canEdit ()) {
return array ();
}
// check BulkManager exists
$bulkManager = $gridField -> getConfig () -> getComponentsByType ( 'GridFieldBulkManager' );
// upload management buttons
$finishButton = FormAction :: create ( 'Finish' , _t ( 'GRIDFIELD_BULK_UPLOAD.FINISH_BTN_LABEL' , 'Finish' ))
-> addExtraClass ( 'bulkUploadFinishButton' )
-> setAttribute ( 'data-icon' , 'accept' )
-> setUseButtonTag ( true );
$clearErrorButton = FormAction :: create ( 'ClearError' , _t ( 'GRIDFIELD_BULK_UPLOAD.CLEAR_ERROR_BTN_LABEL' , 'Clear errors' ))
-> addExtraClass ( 'bulkUploadClearErrorButton' )
-> setAttribute ( 'data-icon' , 'arrow-circle-double' )
-> setUseButtonTag ( true );
if ( count ( $bulkManager )) {
$cancelButton = FormAction :: create ( 'Cancel' , _t ( 'GRIDFIELD_BULK_UPLOAD.CANCEL_BTN_LABEL' , 'Cancel' ))
-> addExtraClass ( 'bulkUploadCancelButton ss-ui-action-destructive' )
-> setAttribute ( 'data-icon' , 'decline' )
-> setAttribute ( 'data-url' , $gridField -> Link ( 'bulkupload/cancel' ))
-> setUseButtonTag ( true );
$bulkManager_config = $bulkManager -> first () -> getConfig ();
$bulkManager_actions = $bulkManager_config [ 'actions' ];
if ( array_key_exists ( 'bulkedit' , $bulkManager_actions )) {
$editAllButton = FormAction :: create ( 'EditAll' , _t ( 'GRIDFIELD_BULK_UPLOAD.EDIT_ALL_BTN_LABEL' , 'Edit all' ))
2014-05-22 15:57:09 +02:00
-> addExtraClass ( 'bulkUploadEditButton' )
-> setAttribute ( 'data-icon' , 'pencil' )
-> setAttribute ( 'data-url' , $gridField -> Link ( 'bulkupload/edit' ))
-> setUseButtonTag ( true );
2015-12-16 01:08:57 +13:00
} else {
$editAllButton = '' ;
}
} else {
$cancelButton = '' ;
$editAllButton = '' ;
}
// get uploadField + inject extra buttons
$uploadField = $this -> bulkUploadField ( $gridField );
$uploadField -> FinishButton = $finishButton ;
$uploadField -> CancelButton = $cancelButton ;
$uploadField -> EditAllButton = $editAllButton ;
$uploadField -> ClearErrorButton = $clearErrorButton ;
$data = ArrayData :: create ( array (
'Colspan' => count ( $gridField -> getColumns ()),
'UploadField' => $uploadField -> Field (), // call ->Field() to get requirements in right order
));
Requirements :: css ( BULKEDITTOOLS_UPLOAD_PATH . '/css/GridFieldBulkUpload.css' );
Requirements :: javascript ( BULKEDITTOOLS_UPLOAD_PATH . '/javascript/GridFieldBulkUpload.js' );
Requirements :: javascript ( BULKEDITTOOLS_UPLOAD_PATH . '/javascript/GridFieldBulkUpload_downloadtemplate.js' );
Requirements :: add_i18n_javascript ( BULKEDITTOOLS_PATH . '/lang/js' );
return array (
'header' => $data -> renderWith ( 'GridFieldBulkUpload' ),
);
}
/* **********************************************************************
* GridField_URLHandler
* */
/**
* Component URL handlers .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param GridField $gridField
*
* @ return array
*/
public function getURLHandlers ( $gridField )
{
return array (
'bulkupload' => 'handleBulkUpload' ,
);
}
/**
* Pass control over to the RequestHandler .
2016-01-18 16:49:00 +02:00
*
2015-12-16 01:08:57 +13:00
* @ param GridField $gridField
* @ param SS_HTTPRequest $request
*
* @ return mixed
*/
public function handleBulkUpload ( $gridField , $request )
{
$controller = $gridField -> getForm () -> Controller ();
$handler = new GridFieldBulkUpload_Request ( $gridField , $this , $controller );
return $handler -> handleRequest ( $request , DataModel :: inst ());
}
2014-05-22 15:57:09 +02:00
}