mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
NEW: Added canAttachExisting config option for UploadField.
This is the companion setting to canUpload, letting you control whether existing files from the asset store can be referenced. It's particularly useful when using UploadField on the front-end.
This commit is contained in:
parent
2fdd9a3b13
commit
cc7318fde4
@ -5,6 +5,7 @@ UploadField:
|
|||||||
autoUpload: true
|
autoUpload: true
|
||||||
allowedMaxFileNumber:
|
allowedMaxFileNumber:
|
||||||
canUpload: true
|
canUpload: true
|
||||||
|
canAttachExisting: 'CMS_ACCESS_AssetAdmin'
|
||||||
previewMaxWidth: 80
|
previewMaxWidth: 80
|
||||||
previewMaxHeight: 60
|
previewMaxHeight: 60
|
||||||
uploadTemplateName: 'ss-uploadfield-uploadtemplate'
|
uploadTemplateName: 'ss-uploadfield-uploadtemplate'
|
||||||
|
@ -89,6 +89,10 @@ class UploadField extends FileField {
|
|||||||
*/
|
*/
|
||||||
'canUpload' => true,
|
'canUpload' => true,
|
||||||
/**
|
/**
|
||||||
|
* @var boolean|string Can the user attach files from the assets archive on the site?
|
||||||
|
* String values are interpreted as permission codes.
|
||||||
|
*/
|
||||||
|
'canAttachExisting' => "CMS_ACCESS_AssetAdmin",
|
||||||
* @var int
|
* @var int
|
||||||
*/
|
*/
|
||||||
'previewMaxWidth' => 80,
|
'previewMaxWidth' => 80,
|
||||||
@ -553,6 +557,7 @@ class UploadField extends FileField {
|
|||||||
public function attach($request) {
|
public function attach($request) {
|
||||||
if(!$request->isPOST()) return $this->httpError(403);
|
if(!$request->isPOST()) return $this->httpError(403);
|
||||||
if(!$this->managesRelation()) return $this->httpError(403);
|
if(!$this->managesRelation()) return $this->httpError(403);
|
||||||
|
if(!$this->canAttachExisting()) return $this->httpError(403);
|
||||||
|
|
||||||
$return = array();
|
$return = array();
|
||||||
|
|
||||||
@ -646,6 +651,11 @@ class UploadField extends FileField {
|
|||||||
return (is_bool($can)) ? $can : Permission::check($can);
|
return (is_bool($can)) ? $can : Permission::check($can);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canAttachExisting() {
|
||||||
|
$can = $this->getConfig('canAttachExisting');
|
||||||
|
return (is_bool($can)) ? $can : Permission::check($can);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -59,7 +59,10 @@
|
|||||||
<% else %>
|
<% else %>
|
||||||
<input style="display: none" id="$id" name="$getName" class="$extraClass ss-uploadfield-fromcomputer-fileinput" data-config="$configString" type="file"<% if $multiple %> multiple="multiple"<% end_if %> />
|
<input style="display: none" id="$id" name="$getName" class="$extraClass ss-uploadfield-fromcomputer-fileinput" data-config="$configString" type="file"<% if $multiple %> multiple="multiple"<% end_if %> />
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
|
||||||
|
<% if canAttachExisting %>
|
||||||
<button class="ss-uploadfield-fromfiles ss-ui-button ui-corner-all" title="<% _t('UploadField.FROMCOMPUTERINFO', 'Select from files') %>" data-icon="network-cloud"><% _t('UploadField.FROMFILES', 'From files') %></button>
|
<button class="ss-uploadfield-fromfiles ss-ui-button ui-corner-all" title="<% _t('UploadField.FROMCOMPUTERINFO', 'Select from files') %>" data-icon="network-cloud"><% _t('UploadField.FROMFILES', 'From files') %></button>
|
||||||
|
<% end_if %>
|
||||||
<% if not $autoUpload %>
|
<% if not $autoUpload %>
|
||||||
<button class="ss-uploadfield-startall ss-ui-button ui-corner-all" title="<% _t('UploadField.STARTALLINFO', 'Start all uploads') %>" data-icon="navigation"><% _t('UploadField.STARTALL', 'Start all') %></button>
|
<button class="ss-uploadfield-startall ss-ui-button ui-corner-all" title="<% _t('UploadField.STARTALLINFO', 'Start all uploads') %>" data-icon="navigation"><% _t('UploadField.STARTALL', 'Start all') %></button>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
@ -512,6 +512,22 @@ class UploadFieldTest extends FunctionalTest {
|
|||||||
$this->assertTrue($field->canUpload());
|
$this->assertTrue($field->canUpload());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCanAttachExisting() {
|
||||||
|
$this->loginWithPermission('ADMIN');
|
||||||
|
$response = $this->get('UploadFieldTest_Controller');
|
||||||
|
$this->assertFalse($response->isError());
|
||||||
|
|
||||||
|
$parser = new CSSContentParser($response->getBody());
|
||||||
|
$this->assertTrue(
|
||||||
|
(bool)$parser->getBySelector('#CanAttachExistingFalseField .ss-uploadfield-fromcomputer-fileinput'),
|
||||||
|
'Keeps input file control'
|
||||||
|
);
|
||||||
|
$this->assertFalse(
|
||||||
|
(bool)$parser->getBySelector('#CanAttachExistingFalseField .ss-uploadfield-fromfiles'),
|
||||||
|
'Removes "From files" button'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public function testIsSaveable() {
|
public function testIsSaveable() {
|
||||||
$form = $this->getMockForm();
|
$form = $this->getMockForm();
|
||||||
|
|
||||||
@ -815,6 +831,10 @@ class UploadFieldTest_Controller extends Controller implements TestOnly {
|
|||||||
$fieldCanUploadFalse->setConfig('canUpload', false);
|
$fieldCanUploadFalse->setConfig('canUpload', false);
|
||||||
$fieldCanUploadFalse->setRecord($record);
|
$fieldCanUploadFalse->setRecord($record);
|
||||||
|
|
||||||
|
$fieldCanAttachExisting = new UploadField('CanAttachExistingFalseField');
|
||||||
|
$fieldCanAttachExisting->setConfig('canAttachExisting', false);
|
||||||
|
$fieldCanAttachExisting->setRecord($record);
|
||||||
|
|
||||||
$form = new Form(
|
$form = new Form(
|
||||||
$this,
|
$this,
|
||||||
'Form',
|
'Form',
|
||||||
@ -830,7 +850,8 @@ class UploadFieldTest_Controller extends Controller implements TestOnly {
|
|||||||
$fieldReadonly,
|
$fieldReadonly,
|
||||||
$fieldDisabled,
|
$fieldDisabled,
|
||||||
$fieldSubfolder,
|
$fieldSubfolder,
|
||||||
$fieldCanUploadFalse
|
$fieldCanUploadFalse,
|
||||||
|
$fieldCanAttachExisting
|
||||||
),
|
),
|
||||||
new FieldList(
|
new FieldList(
|
||||||
new FormAction('submit')
|
new FormAction('submit')
|
||||||
@ -847,7 +868,8 @@ class UploadFieldTest_Controller extends Controller implements TestOnly {
|
|||||||
'ReadonlyField',
|
'ReadonlyField',
|
||||||
'DisabledField',
|
'DisabledField',
|
||||||
'SubfolderField',
|
'SubfolderField',
|
||||||
'CanUploadFalseField'
|
'CanUploadFalseField',
|
||||||
|
'CanAttachExistingField'
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
return $form;
|
return $form;
|
||||||
|
Loading…
Reference in New Issue
Block a user