mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 06:05:56 +00:00
API CHANGE Removed LeftAndMain->EditForm(), please use getEditForm() instead
API CHANGE Returning LeftAndMain->EmptyForm() as a welcome/placeholder message from LeftAndMain->getEditForm() if no record is found. Removed this placeholder from LeftAndMain_right.ss ENHANCEMENT Allowing optional $id parameter in LeftAndMain->getEditForm() (and subclasses) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@92710 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
fef2f77b09
commit
dc4375a383
@ -282,13 +282,15 @@ HTML;
|
|||||||
/**
|
/**
|
||||||
* Return the form that displays the details of a folder, including a file list and fields for editing the folder name.
|
* Return the form that displays the details of a folder, including a file list and fields for editing the folder name.
|
||||||
*/
|
*/
|
||||||
function getEditForm($id) {
|
function getEditForm($id = null) {
|
||||||
if($id && $id != "root") {
|
if($id && $id != "root") {
|
||||||
$record = DataObject::get_by_id("File", $id);
|
$record = DataObject::get_by_id("File", $id);
|
||||||
} else {
|
} else {
|
||||||
$record = singleton("Folder");
|
$record = singleton("Folder");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($record && !$record->canView()) return Security::permissionFailure($this);
|
||||||
|
|
||||||
if($record) {
|
if($record) {
|
||||||
$fields = $record->getCMSFields();
|
$fields = $record->getCMSFields();
|
||||||
$actions = new FieldSet();
|
$actions = new FieldSet();
|
||||||
@ -314,12 +316,7 @@ HTML;
|
|||||||
$form->makeReadonly();
|
$form->makeReadonly();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$form = new Form(
|
$form = $this->EmptyForm();
|
||||||
$this,
|
|
||||||
"EditForm",
|
|
||||||
new FieldSet(),
|
|
||||||
new FieldSet()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $form;
|
return $form;
|
||||||
|
@ -327,8 +327,12 @@ JS;
|
|||||||
/**
|
/**
|
||||||
* Calls {@link SiteTree->getCMSFields()}
|
* Calls {@link SiteTree->getCMSFields()}
|
||||||
*/
|
*/
|
||||||
public function getEditForm($id) {
|
public function getEditForm($id = null) {
|
||||||
$record = $this->getRecord($id);
|
// Include JavaScript to ensure HtmlEditorField works.
|
||||||
|
HtmlEditorField::include_js();
|
||||||
|
|
||||||
|
$record = ($id) ? $this->getRecord($id) : null;
|
||||||
|
if($record && !$record->canView()) return Security::permissionFailure($this);
|
||||||
|
|
||||||
if($record) {
|
if($record) {
|
||||||
if($record->IsDeletedFromStage) $record->Status = _t('CMSMain.REMOVEDFD',"Removed from the draft site");
|
if($record->IsDeletedFromStage) $record->Status = _t('CMSMain.REMOVEDFD',"Removed from the draft site");
|
||||||
@ -401,19 +405,12 @@ JS;
|
|||||||
$form->loadDataFrom($siteConfig);
|
$form->loadDataFrom($siteConfig);
|
||||||
return $form;
|
return $form;
|
||||||
} else {
|
} else {
|
||||||
$form = new Form(
|
$form = $this->EmptyForm();
|
||||||
$this,
|
|
||||||
"EditForm",
|
|
||||||
new FieldSet(),
|
|
||||||
new FieldSet()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $form;
|
return $form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------------------//
|
//------------------------------------------------------------------------------------------//
|
||||||
// Data saving handlers
|
// Data saving handlers
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ class CommentAdmin extends LeftAndMain {
|
|||||||
return $section;
|
return $section;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function EditForm() {
|
public function getEditForm($id = null) {
|
||||||
$section = $this->Section();
|
$section = $this->Section();
|
||||||
|
|
||||||
if($section == 'approved') {
|
if($section == 'approved') {
|
||||||
|
@ -339,12 +339,16 @@ class LeftAndMain extends Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function show($request) {
|
public function show($request) {
|
||||||
|
$form = $this->getEditForm($request->param('ID'));
|
||||||
|
|
||||||
if(Director::is_ajax()) {
|
if(Director::is_ajax()) {
|
||||||
SSViewer::setOption('rewriteHashlinks', false);
|
SSViewer::setOption('rewriteHashlinks', false);
|
||||||
return $this->EditForm()->formHtmlContent();
|
return $form->formHtmlContent();
|
||||||
} else {
|
} else {
|
||||||
// Rendering is handled by template, which will call EditForm() eventually
|
// Rendering is handled by template, which will call EditForm() eventually
|
||||||
return array();
|
return $this->customise(array(
|
||||||
|
'EditForm' => $form
|
||||||
|
))->renderWith($this->getViewer('show'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -358,7 +362,7 @@ class LeftAndMain extends Controller {
|
|||||||
if($record && !$record->canView()) return Security::permissionFailure($this);
|
if($record && !$record->canView()) return Security::permissionFailure($this);
|
||||||
}
|
}
|
||||||
|
|
||||||
$form = $this->EditForm();
|
$form = $this->getEditForm();
|
||||||
if($form) return $form->formHtmlContent();
|
if($form) return $form->formHtmlContent();
|
||||||
else return "";
|
else return "";
|
||||||
}
|
}
|
||||||
@ -816,20 +820,46 @@ JS;
|
|||||||
return FormResponse::respond();
|
return FormResponse::respond();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function EditForm() {
|
/**
|
||||||
// Include JavaScript to ensure HtmlEditorField works.
|
* Gets the edit form of a specific record. Will usually construct itself
|
||||||
HtmlEditorField::include_js();
|
* from {@link DataObject->getCMSFields()} for the specific managed subclass
|
||||||
|
* defined in {@link LeftAndMain::$tree_class}.
|
||||||
if ($this->currentPageID() != 0) {
|
*
|
||||||
$record = $this->currentPage();
|
* @param int $id ID of a record for {@link LeftAndMain::$tree_class} (Optional)
|
||||||
if(!$record) return false;
|
* @return Form Should return a form regardless wether a record has been found.
|
||||||
if($record && !$record->canView()) return Security::permissionFailure($this);
|
* Form might be readonly if the current user doesn't have the permission to edit
|
||||||
}
|
* the record.
|
||||||
if ($this->hasMethod('getEditForm')) {
|
*/
|
||||||
return $this->getEditForm($this->currentPageID());
|
function getEditForm($id = null) {
|
||||||
|
die('getEditForm(): Not implemented');
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
/**
|
||||||
|
* Returns a placeholder form, used by {@link getEditForm()} if no record is selected.
|
||||||
|
* Our javascript logic always requires a form to be present in the CMS interface.
|
||||||
|
*
|
||||||
|
* @return Form
|
||||||
|
*/
|
||||||
|
function EmptyForm() {
|
||||||
|
return new Form(
|
||||||
|
$this,
|
||||||
|
"EditForm",
|
||||||
|
new FieldSet(
|
||||||
|
new HeaderField(
|
||||||
|
'WelcomeHeader',
|
||||||
|
$this->getApplicationName()
|
||||||
|
),
|
||||||
|
new LiteralField(
|
||||||
|
'WelcomeText',
|
||||||
|
sprintf('<p>%s %s. %s</p>',
|
||||||
|
_t('LeftAndMain_right.ss.WELCOMETO','Welcome to'),
|
||||||
|
$this->getApplicationName(),
|
||||||
|
_t('CHOOSEPAGE','Please choose an item from the left.')
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new FieldSet()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function myprofile() {
|
public function myprofile() {
|
||||||
|
@ -48,13 +48,15 @@ class SecurityAdmin extends LeftAndMain implements PermissionProvider {
|
|||||||
Requirements::javascript(THIRDPARTY_DIR . "/greybox/greybox.js");
|
Requirements::javascript(THIRDPARTY_DIR . "/greybox/greybox.js");
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getEditForm($id) {
|
public function getEditForm($id = null) {
|
||||||
$record = null;
|
$record = null;
|
||||||
|
|
||||||
if($id && $id != 'root') {
|
if($id && $id != 'root') {
|
||||||
$record = DataObject::get_by_id($this->stat('tree_class'), $id);
|
$record = DataObject::get_by_id($this->stat('tree_class'), $id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($record && !$record->canView()) return Security::permissionFailure($this);
|
||||||
|
|
||||||
if($record) {
|
if($record) {
|
||||||
$fields = $record->getCMSFields();
|
$fields = $record->getCMSFields();
|
||||||
|
|
||||||
@ -71,12 +73,7 @@ class SecurityAdmin extends LeftAndMain implements PermissionProvider {
|
|||||||
$form->setFields($readonlyFields);
|
$form->setFields($readonlyFields);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$form = new Form(
|
$form = $this->EmptyForm();
|
||||||
$this,
|
|
||||||
"EditForm",
|
|
||||||
new FieldSet(),
|
|
||||||
new FieldSet()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $form;
|
return $form;
|
||||||
|
@ -35,11 +35,6 @@
|
|||||||
// Can't bind this through jQuery
|
// Can't bind this through jQuery
|
||||||
window.onbeforeunload = function(e) {return self._checkChangeTracker(false);};
|
window.onbeforeunload = function(e) {return self._checkChangeTracker(false);};
|
||||||
|
|
||||||
// set default placeholder if form has no children
|
|
||||||
this.setPlaceholderHtml(jQuery('.ss-cmsForm-welcomeMessage').html());
|
|
||||||
jQuery('.ss-cmsForm-welcomeMessage').remove();
|
|
||||||
if(!self.find('*').length) self.removeForm();
|
|
||||||
|
|
||||||
$._super();
|
$._super();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -1,11 +1,3 @@
|
|||||||
<div class='ss-cmsForm-welcomeMessage'>
|
|
||||||
<h1>$ApplicationName</h1>
|
|
||||||
<p>
|
|
||||||
<% _t('WELCOMETO','Welcome to') %> $ApplicationName!
|
|
||||||
<% _t('CHOOSEPAGE','Please choose an item from the left.') %>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
$EditForm
|
$EditForm
|
||||||
|
|
||||||
<div class="notice-wrap"></div>
|
<div class="notice-wrap"></div>
|
Loading…
x
Reference in New Issue
Block a user