Merge branch '3.1'

This commit is contained in:
Andrew Short 2013-03-15 21:59:52 +11:00
commit 18f4f68101
8 changed files with 81 additions and 45 deletions

View File

@ -757,6 +757,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'), 'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'),
); );
$gridField->getConfig()->getComponentByType('GridFieldSortableHeader')->setFieldSorting(array('getTreeTitle' => 'Title')); $gridField->getConfig()->getComponentByType('GridFieldSortableHeader')->setFieldSorting(array('getTreeTitle' => 'Title'));
$gridField->getState()->ParentID = $parentID;
if(!$params) { if(!$params) {
$fields = array_merge(array('listChildrenLink' => ''), $fields); $fields = array_merge(array('listChildrenLink' => ''), $fields);
@ -1277,24 +1278,34 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$newPage = $page->duplicate(); $newPage = $page->duplicate();
// ParentID can be hard-set in the URL. This is useful for pages with multiple parents // ParentID can be hard-set in the URL. This is useful for pages with multiple parents
if($_GET['parentID'] && is_numeric($_GET['parentID'])) { if(isset($_GET['parentID']) && is_numeric($_GET['parentID'])) {
$newPage->ParentID = $_GET['parentID']; $newPage->ParentID = $_GET['parentID'];
$newPage->write(); $newPage->write();
} }
// Reload form, data and actions might have changed $this->response->addHeader(
$form = $this->getEditForm($newPage->ID); 'X-Status',
rawurlencode(_t(
'CMSMain.DUPLICATED',
"Duplicated '{title}' successfully",
array('title' => $newPage->Title)
))
);
$url = Controller::join_links(singleton('CMSPageEditController')->Link('show'), $newPage->ID);
$this->response->addHeader('X-ControllerURL', $url);
$this->request->addHeader('X-Pjax', 'Content');
$this->response->addHeader('X-Pjax', 'Content');
return $form->forTemplate(); return $this->getResponseNegotiator()->respond($this->request);
} else { } else {
user_error("CMSMain::duplicate() Bad ID: '$id'", E_USER_WARNING); return new SS_HTTPResponse("CMSMain::duplicate() Bad ID: '$id'", 400);
} }
} }
public function duplicatewithchildren($request) { public function duplicatewithchildren($request) {
// Protect against CSRF on destructive action // Protect against CSRF on destructive action
if(!SecurityToken::inst()->checkRequest($request)) return $this->httpError(400); if(!SecurityToken::inst()->checkRequest($request)) return $this->httpError(400);
increase_time_limit_to();
if(($id = $this->urlParams['ID']) && is_numeric($id)) { if(($id = $this->urlParams['ID']) && is_numeric($id)) {
$page = DataObject::get_by_id("SiteTree", $id); $page = DataObject::get_by_id("SiteTree", $id);
if($page && (!$page->canEdit() || !$page->canCreate())) return Security::permissionFailure($this); if($page && (!$page->canEdit() || !$page->canCreate())) return Security::permissionFailure($this);
@ -1302,36 +1313,25 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$newPage = $page->duplicateWithChildren(); $newPage = $page->duplicateWithChildren();
// Reload form, data and actions might have changed $this->response->addHeader(
$form = $this->getEditForm($newPage->ID); 'X-Status',
rawurlencode(_t(
'CMSMain.DUPLICATEDWITHCHILDREN',
"Duplicated '{title}' and children successfully",
array('title' => $newPage->Title)
))
);
$url = Controller::join_links(singleton('CMSPageEditController')->Link('show'), $newPage->ID);
$this->response->addHeader('X-ControllerURL', $url);
$this->request->addHeader('X-Pjax', 'Content');
$this->response->addHeader('X-Pjax', 'Content');
return $form->forTemplate(); return $this->getResponseNegotiator()->respond($this->request);
} else { } else {
user_error("CMSMain::duplicate() Bad ID: '$id'", E_USER_WARNING); return new SS_HTTPResponse("CMSMain::duplicatewithchildren() Bad ID: '$id'", 400);
} }
} }
/**
* Return the version number of this application.
* Uses the subversion path information in <mymodule>/silverstripe_version
* (automacially replaced by build scripts).
*
* @return string
*/
public function CMSVersion() {
$cmsVersion = file_get_contents(CMS_PATH . '/silverstripe_version');
if(!$cmsVersion) $cmsVersion = _t('LeftAndMain.VersionUnknown', 'Unknown');
$frameworkVersion = file_get_contents(FRAMEWORK_PATH . '/silverstripe_version');
if(!$frameworkVersion) $frameworkVersion = _t('LeftAndMain.VersionUnknown', 'Unknown');
return sprintf(
"CMS: %s Framework: %s",
$cmsVersion,
$frameworkVersion
);
}
public function providePermissions() { public function providePermissions() {
$title = _t("CMSPagesController.MENUTITLE", LeftAndMain::menu_title_for_class('CMSPagesController')); $title = _t("CMSPagesController.MENUTITLE", LeftAndMain::menu_title_for_class('CMSPagesController'));
return array( return array(

View File

@ -117,12 +117,10 @@ class RootURLController extends Controller {
return $this->response; return $this->response;
} }
$request = new SS_HTTPRequest ( $request->setUrl(self::get_homepage_link() . '/');
$request->httpMethod(), self::get_homepage_link() . '/', $request->getVars(), $request->postVars()
);
$request->match('$URLSegment//$Action', true); $request->match('$URLSegment//$Action', true);
$controller = new ModelAsController(); $controller = new ModelAsController();
$result = $controller->handleRequest($request, $model); $result = $controller->handleRequest($request, $model);
$this->popCurrent(); $this->popCurrent();

View File

@ -70,7 +70,8 @@
}); });
$(".cms-add-form #PageType li").entwine({ $(".cms-add-form #PageType li").entwine({
onclick: function() { onclick: function(e) {
e.preventDefault();
this.setSelected(true); this.setSelected(true);
}, },
setSelected: function(bool) { setSelected: function(bool) {
@ -90,9 +91,18 @@
$(".cms-page-add-button").entwine({ $(".cms-page-add-button").entwine({
onclick: function(e) { onclick: function(e) {
var selected = $('.cms-tree').jstree('get_selected'), var tree = $('.cms-tree'), list = $('.cms-list'), parentId = 0;
parentId = selected ? $(selected[0]).data('id') : null,
data = {selector: this.data('targetPanel'),pjax: this.data('pjax')}, // Choose parent ID either from tree or list view, depending which is visible
if(tree.is(':visible')) {
var selected = tree.jstree('get_selected');
parentId = selected ? $(selected[0]).data('id') : null;
} else {
var state = list.find('input[name="Page[GridState]"]').val();
if(state) parentId = parseInt(JSON.parse(state).ParentID, 10);
}
var data = {selector: this.data('targetPanel'),pjax: this.data('pjax')},
url = parentId ? ss.i18n.sprintf(this.data('urlAddpage'), parentId) : this.attr('href'); url = parentId ? ss.i18n.sprintf(this.data('urlAddpage'), parentId) : this.attr('href');
$('.cms-container').loadPanel(url, null, data); $('.cms-container').loadPanel(url, null, data);

View File

@ -12,7 +12,7 @@
'edit': { 'edit': {
'label': ss.i18n._t('Tree.EditPage'), 'label': ss.i18n._t('Tree.EditPage'),
'action': function(obj) { 'action': function(obj) {
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf( $('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
self.data('urlEditpage'), obj.data('id') self.data('urlEditpage'), obj.data('id')
)); ));
} }
@ -34,7 +34,7 @@
disallowedClass = disallowedChildren[i]; disallowedClass = disallowedChildren[i];
if(allowedChildren[disallowedClass]) { if(allowedChildren[disallowedClass]) {
delete allowedChildren[disallowedClass]; delete allowedChildren[disallowedClass];
} }
} }
} }
@ -46,7 +46,7 @@
'_class': 'class-' + klass, '_class': 'class-' + klass,
'action': function(obj) { 'action': function(obj) {
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf( $('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
self.data('urlAddpage'), id, klass self.data('urlAddpage'), id, klass
)); ));
} }
}; };
@ -59,6 +59,27 @@
}; };
} }
menuitems['duplicate'] = {
'label': ss.i18n._t('Tree.Duplicate'),
'submenu': [
{
'label': ss.i18n._t('Tree.ThisPageOnly'),
'action': function(obj) {
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
self.data('urlDuplicate'), obj.data('id')
));
}
},{
'label': ss.i18n._t('Tree.ThisPageAndSubpages'),
'action': function(obj) {
$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
self.data('urlDuplicatewithchildren'), obj.data('id')
));
}
}
]
};
return menuitems; return menuitems;
} }
}; };

View File

@ -29,7 +29,10 @@ if(typeof(ss) == 'undefined' || typeof(ss.i18n) == 'undefined') {
'AssetAdmin.ConfirmDelete': 'Do you really want to delete this folder and all contained files?', 'AssetAdmin.ConfirmDelete': 'Do you really want to delete this folder and all contained files?',
'Folder.Name': 'Folder name', 'Folder.Name': 'Folder name',
'Tree.AddSubPage': 'Add new page here', 'Tree.AddSubPage': 'Add new page here',
'Tree.Duplicate': 'Duplicate',
'Tree.EditPage': 'Edit', 'Tree.EditPage': 'Edit',
'Tree.ThisPageOnly': 'This page only',
'Tree.ThisPageAndSubpages': 'This page and subpages',
'CMSMain.ConfirmRestoreFromLive': "Do you really want to copy the published content to the draft site?", 'CMSMain.ConfirmRestoreFromLive': "Do you really want to copy the published content to the draft site?",
'CMSMain.RollbackToVersion': "Do you really want to roll back to version #%s of this page?", 'CMSMain.RollbackToVersion': "Do you really want to roll back to version #%s of this page?",
'URLSEGMENT.Edit': 'Edit', 'URLSEGMENT.Edit': 'Edit',

View File

@ -80,6 +80,8 @@ en:
DELETE: 'Delete draft' DELETE: 'Delete draft'
DELETEFP: Delete DELETEFP: Delete
DESCREMOVED: 'and {count} descendants' DESCREMOVED: 'and {count} descendants'
DUPLICATED: 'Duplicated ''{title}'' successfully'
DUPLICATEDWITHCHILDREN: 'Duplicated ''{title}'' and children successfully'
EMAIL: Email EMAIL: Email
EditTree: 'Edit Tree' EditTree: 'Edit Tree'
ListFiltered: 'Filtered list.' ListFiltered: 'Filtered list.'

View File

@ -82,6 +82,8 @@ en_GB:
DELETE: 'Delete from the draft site' DELETE: 'Delete from the draft site'
DELETEFP: 'Delete from the published site' DELETEFP: 'Delete from the published site'
DESCREMOVED: 'and {count} descendants' DESCREMOVED: 'and {count} descendants'
DUPLICATED: 'Duplicated ''{title}'' successfully'
DUPLICATEDWITHCHILDREN: 'Duplicated ''{title}'' and children successfully'
EMAIL: Email EMAIL: Email
EditTree: 'Edit Tree' EditTree: 'Edit Tree'
ListFiltered: 'Filtered list.' ListFiltered: 'Filtered list.'

View File

@ -19,7 +19,7 @@ $ExtraTreeTools
</div> </div>
<% end_if %> <% end_if %>
<div class="cms-tree" data-url-tree="$Link(getsubtree)" data-url-savetreenode="$Link(savetreenode)" data-url-updatetreenodes="$Link(updatetreenodes)" data-url-addpage="{$LinkPageAdd('AddForm/?action_doAdd=1')}&amp;ParentID=%s&amp;PageType=%s&amp;SecurityID=$SecurityID" data-url-editpage="$LinkPageEdit('%s')" data-hints="$SiteTreeHints.XML"> <div class="cms-tree" data-url-tree="$Link(getsubtree)" data-url-savetreenode="$Link(savetreenode)" data-url-updatetreenodes="$Link(updatetreenodes)" data-url-addpage="{$LinkPageAdd('AddForm/?action_doAdd=1')}&amp;ParentID=%s&amp;PageType=%s&amp;SecurityID=$SecurityID" data-url-editpage="$LinkPageEdit('%s')" data-url-duplicate="{$Link('duplicate/%s')}?SecurityID=$SecurityID" data-url-duplicatewithchildren="{$Link('duplicatewithchildren/%s')}?SecurityID=$SecurityID" data-hints="$SiteTreeHints.XML">
$SiteTreeAsUL $SiteTreeAsUL
</div> </div>
</div> </div>