mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 06:05:56 +00:00
MINOR Merged from branches/2.3
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@69958 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
7e09cc8a18
commit
300435fb13
@ -82,9 +82,14 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
|
|||||||
public function init() {
|
public function init() {
|
||||||
parent::init();
|
parent::init();
|
||||||
|
|
||||||
|
if(Translatable::is_enabled()) {
|
||||||
|
$this->Lang = $this->requestParams["lang"] ? $this->requestParams["lang"] : Translatable::default_lang();
|
||||||
|
Translatable::set_reading_lang($this->Lang);
|
||||||
|
}
|
||||||
|
|
||||||
// collect languages for TinyMCE spellchecker plugin
|
// collect languages for TinyMCE spellchecker plugin
|
||||||
if(Translatable::is_enabled()) {
|
if(Translatable::is_enabled()) {
|
||||||
$spellcheckLangs = i18n::get_existing_content_languages();
|
$spellcheckLangs = Translatable::get_existing_content_languages();
|
||||||
} else {
|
} else {
|
||||||
$defaultLang = Translatable::default_lang();
|
$defaultLang = Translatable::default_lang();
|
||||||
$spellcheckLangs = array($defaultLang => i18n::get_language_name($defaultLang));
|
$spellcheckLangs = array($defaultLang => i18n::get_language_name($defaultLang));
|
||||||
@ -458,6 +463,10 @@ JS;
|
|||||||
$parent = isset($_REQUEST['ParentID']) ? $_REQUEST['ParentID'] : 0;
|
$parent = isset($_REQUEST['ParentID']) ? $_REQUEST['ParentID'] : 0;
|
||||||
$suffix = isset($_REQUEST['Suffix']) ? "-" . $_REQUEST['Suffix'] : null;
|
$suffix = isset($_REQUEST['Suffix']) ? "-" . $_REQUEST['Suffix'] : null;
|
||||||
|
|
||||||
|
if(!$parent && isset($_REQUEST['Parent'])) {
|
||||||
|
$page = SiteTree::get_by_url($_REQUEST['Parent']);
|
||||||
|
if($page) $parent = $page->ID;
|
||||||
|
}
|
||||||
|
|
||||||
if(is_numeric($parent)) $parentObj = DataObject::get_by_id("SiteTree", $parent);
|
if(is_numeric($parent)) $parentObj = DataObject::get_by_id("SiteTree", $parent);
|
||||||
if(!$parentObj || !$parentObj->ID) $parent = 0;
|
if(!$parentObj || !$parentObj->ID) $parent = 0;
|
||||||
@ -476,6 +485,7 @@ JS;
|
|||||||
*/
|
*/
|
||||||
public function getNewItem($id, $setID = true) {
|
public function getNewItem($id, $setID = true) {
|
||||||
list($dummy, $className, $parentID, $suffix) = array_pad(explode('-',$id),4,null);
|
list($dummy, $className, $parentID, $suffix) = array_pad(explode('-',$id),4,null);
|
||||||
|
|
||||||
if(Translatable::is_enabled()) {
|
if(Translatable::is_enabled()) {
|
||||||
if (!Translatable::is_default_lang()) {
|
if (!Translatable::is_default_lang()) {
|
||||||
$originalItem = Translatable::get_original($className,Session::get("{$id}_originalLangID"));
|
$originalItem = Translatable::get_original($className,Session::get("{$id}_originalLangID"));
|
||||||
@ -487,6 +497,7 @@ JS;
|
|||||||
return $originalItem;
|
return $originalItem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$newItem = new $className();
|
$newItem = new $className();
|
||||||
|
|
||||||
if( !$suffix ) {
|
if( !$suffix ) {
|
||||||
@ -1540,7 +1551,7 @@ JS
|
|||||||
* Return a dropdown with existing languages
|
* Return a dropdown with existing languages
|
||||||
*/
|
*/
|
||||||
function LangSelector() {
|
function LangSelector() {
|
||||||
$langs = i18n::get_existing_content_languages('SiteTree');
|
$langs = Translatable::get_existing_content_languages('SiteTree');
|
||||||
|
|
||||||
return new DropdownField("LangSelector","Language",$langs,Translatable::current_lang());
|
return new DropdownField("LangSelector","Language",$langs,Translatable::current_lang());
|
||||||
}
|
}
|
||||||
@ -1549,7 +1560,7 @@ JS
|
|||||||
* Determine if there are more than one languages in our site tree
|
* Determine if there are more than one languages in our site tree
|
||||||
*/
|
*/
|
||||||
function MultipleLanguages() {
|
function MultipleLanguages() {
|
||||||
$langs = i18n::get_existing_content_languages('SiteTree');
|
$langs = Translatable::get_existing_content_languages('SiteTree');
|
||||||
|
|
||||||
return (count($langs) > 1);
|
return (count($langs) > 1);
|
||||||
}
|
}
|
||||||
|
@ -116,7 +116,7 @@ class LeftAndMain extends Controller {
|
|||||||
|
|
||||||
// set reading lang
|
// set reading lang
|
||||||
if(Translatable::is_enabled() && !Director::is_ajax()) {
|
if(Translatable::is_enabled() && !Director::is_ajax()) {
|
||||||
Translatable::choose_site_lang(array_keys(i18n::get_existing_content_languages('SiteTree')));
|
Translatable::choose_site_lang(array_keys(Translatable::get_existing_content_languages('SiteTree')));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allow customisation of the access check by a decorator
|
// Allow customisation of the access check by a decorator
|
||||||
@ -461,7 +461,7 @@ class LeftAndMain extends Controller {
|
|||||||
|
|
||||||
function getSiteTreeFor($className, $rootID = null) {
|
function getSiteTreeFor($className, $rootID = null) {
|
||||||
$obj = $rootID ? $this->getRecord($rootID) : singleton($className);
|
$obj = $rootID ? $this->getRecord($rootID) : singleton($className);
|
||||||
$obj->markPartialTree();
|
$obj->markPartialTree(null, $this);
|
||||||
if($p = $this->currentPage()) $obj->markToExpose($p);
|
if($p = $this->currentPage()) $obj->markToExpose($p);
|
||||||
|
|
||||||
// getChildrenAsUL is a flexible and complex way of traversing the tree
|
// getChildrenAsUL is a flexible and complex way of traversing the tree
|
||||||
|
@ -379,14 +379,25 @@ div.originallang_holder.field.CompositeField.nolabel {
|
|||||||
font-style: italic;
|
font-style: italic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.right form .field.CompositeField .originallang label.left,
|
||||||
|
.right form .field.CompositeField.originallang_holder label.left {
|
||||||
|
margin-left: 0;
|
||||||
|
width: auto;
|
||||||
|
float: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.right form div.field.CompositeField .originallang .middleColumn {
|
||||||
|
clear: left;
|
||||||
|
}
|
||||||
|
|
||||||
.right form div.languageDropdown {
|
.right form div.languageDropdown {
|
||||||
clear: right;
|
clear: right;
|
||||||
float: left;
|
float: left;
|
||||||
padding-right: 4px;
|
padding-right: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.right form div.createTranslationButton {
|
.right form .field.createTranslationButton .middleColumn {
|
||||||
clear: right;
|
background: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.translatingMessage {
|
.translatingMessage {
|
||||||
|
@ -301,6 +301,12 @@ CMSRightForm.prototype = {
|
|||||||
url = SiteTreeHandlers.loadPage_url + sep + 'ID=' + id;
|
url = SiteTreeHandlers.loadPage_url + sep + 'ID=' + id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// used to set language in CMSMain->init()
|
||||||
|
var lang = $('LangSelector') ? $F('LangSelector') : null;
|
||||||
|
if(lang) {
|
||||||
|
url += '&lang='+lang;
|
||||||
|
}
|
||||||
|
|
||||||
statusMessage("loading...");
|
statusMessage("loading...");
|
||||||
this.loadURLFromServer(url);
|
this.loadURLFromServer(url);
|
||||||
} else {
|
} else {
|
||||||
|
@ -40,7 +40,8 @@ if((typeof tinyMCE != 'undefined')) {
|
|||||||
|
|
||||||
safari_warning : false,
|
safari_warning : false,
|
||||||
relative_urls : true,
|
relative_urls : true,
|
||||||
verify_html : true
|
verify_html : true,
|
||||||
|
use_native_selects : true // fancy selects are bug as of SS 2.3.0
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,6 @@ $lang['en_US']['AssetTableField']['CAPTION'] = 'Caption';
|
|||||||
$lang['en_US']['AssetTableField']['CREATED'] = 'First uploaded';
|
$lang['en_US']['AssetTableField']['CREATED'] = 'First uploaded';
|
||||||
$lang['en_US']['AssetTableField']['DIM'] = 'Dimensions';
|
$lang['en_US']['AssetTableField']['DIM'] = 'Dimensions';
|
||||||
$lang['en_US']['AssetTableField']['DIMLIMT'] = 'Limit The Dimensions In The Popup Window';
|
$lang['en_US']['AssetTableField']['DIMLIMT'] = 'Limit The Dimensions In The Popup Window';
|
||||||
$lang['en_US']['AssetTableField']['EDITIMAGE'] = 'Edit this image';
|
|
||||||
$lang['en_US']['AssetTableField']['FILENAME'] = 'Filename';
|
$lang['en_US']['AssetTableField']['FILENAME'] = 'Filename';
|
||||||
$lang['en_US']['AssetTableField']['GALLERYOPTIONS'] = 'Gallery Options';
|
$lang['en_US']['AssetTableField']['GALLERYOPTIONS'] = 'Gallery Options';
|
||||||
$lang['en_US']['AssetTableField']['IMAGE'] = 'Image';
|
$lang['en_US']['AssetTableField']['IMAGE'] = 'Image';
|
||||||
|
@ -65,8 +65,9 @@ class RebuildStaticCacheTask extends Controller {
|
|||||||
|
|
||||||
$urls = array_slice($urls, $start, $count);
|
$urls = array_slice($urls, $start, $count);
|
||||||
|
|
||||||
if(!isset($_GET['urls']) && $start == 0) {
|
if(!isset($_GET['urls']) && $start == 0 && file_exists("../cache")) {
|
||||||
echo "Removing old cache... ";
|
echo "Removing old cache... \n";
|
||||||
|
flush();
|
||||||
Filesystem::removeFolder("../cache", true);
|
Filesystem::removeFolder("../cache", true);
|
||||||
echo "done.\n\n";
|
echo "done.\n\n";
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user