mirror of
https://github.com/silverstripe/silverstripe-widgets
synced 2024-10-22 15:05:54 +00:00
Merge branch '1.3'
This commit is contained in:
commit
f3b14df4e4
@ -6,39 +6,42 @@
|
|||||||
*/
|
*/
|
||||||
class WidgetContentControllerExtension extends Extension
|
class WidgetContentControllerExtension extends Extension
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private static $allowed_actions = array(
|
private static $allowed_actions = array(
|
||||||
'handleWidget'
|
'handleWidget'
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles widgets attached to a page through one or more {@link WidgetArea}
|
* Handles widgets attached to a page through one or more {@link WidgetArea}
|
||||||
* elements.
|
* elements.
|
||||||
*
|
*
|
||||||
* Iterated through each $has_one relation with a {@link WidgetArea} and
|
* Iterated through each $has_one relation with a {@link WidgetArea} and
|
||||||
* looks for connected widgets by their database identifier.
|
* looks for connected widgets by their database identifier.
|
||||||
*
|
*
|
||||||
* Assumes URLs in the following format: <URLSegment>/widget/<Widget-ID>.
|
* Assumes URLs in the following format: <URLSegment>/widget/<Widget-ID>.
|
||||||
*
|
*
|
||||||
* @return RequestHandler
|
* @return RequestHandler
|
||||||
*/
|
*/
|
||||||
public function handleWidget()
|
public function handleWidget()
|
||||||
{
|
{$SQL_id = $this->owner->getRequest()->param('ID');
|
||||||
$SQL_id = $this->owner->getRequest()->param('ID');
|
if(!$SQL_id) {return false;
|
||||||
if (!$SQL_id) {
|
}
|
||||||
return false;
|
/** @var SiteTree $widgetOwner */
|
||||||
}
|
$widgetOwner = $this->owner->data();
|
||||||
|
while($widgetOwner->InheritSideBar && $widgetOwner->Parent()->exists()){
|
||||||
|
$widgetOwner = $widgetOwner->Parent();
|
||||||
|
}
|
||||||
|
|
||||||
// find WidgetArea relations
|
// find WidgetArea relations
|
||||||
$widgetAreaRelations = array();
|
$widgetAreaRelations = array();
|
||||||
$hasOnes = $this->owner->data()->hasOne();
|
$hasOnes = $widgetOwner->hasOne();
|
||||||
|
|
||||||
if (!$hasOnes) {
|
if(!$hasOnes) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($hasOnes as $hasOneName => $hasOneClass) {
|
foreach ($hasOnes as $hasOneName => $hasOneClass) {
|
||||||
if ($hasOneClass == 'WidgetArea' || is_subclass_of($hasOneClass, 'WidgetArea')) {
|
if ($hasOneClass == 'WidgetArea' || is_subclass_of($hasOneClass, 'WidgetArea')) {
|
||||||
@ -54,10 +57,10 @@ class WidgetContentControllerExtension extends Extension
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
$widget = $this->owner->data()->$widgetAreaRelation()->Widgets()
|
$widget = $widgetOwner->$widgetAreaRelation()->Widgets()
|
||||||
->filter('ID', $SQL_id)
|
->filter('ID', $SQL_id)
|
||||||
->First();
|
->First();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$widget) {
|
if (!$widget) {
|
||||||
user_error('No widget found', E_USER_ERROR);
|
user_error('No widget found', E_USER_ERROR);
|
||||||
|
@ -45,80 +45,95 @@ class WidgetController extends Controller
|
|||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $action
|
* @param string $action
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function Link($action = null)
|
public function Link($action = null)
|
||||||
{
|
{
|
||||||
$id = ($this->widget) ? $this->widget->ID : null;
|
$id = ($this->widget) ? $this->widget->ID : null;
|
||||||
$segment = Controller::join_links('widget', $id, $action);
|
$segment = Controller::join_links('widget', $id, $action);
|
||||||
|
|
||||||
if ($page = Director::get_current_page()) {
|
$page = Director::get_current_page();
|
||||||
return $page->Link($segment);
|
if($page && !($page instanceof WidgetController)) {return $page->Link($segment);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Controller::curr()->Link($segment);
|
if ($controller = $this->getParentController()) {return $controller->Link($segment);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
return $segment;
|
||||||
* @return Widget
|
}
|
||||||
*/
|
|
||||||
public function getWidget()
|
/**
|
||||||
|
* Cycles up the controller stack until it finds a non-widget controller
|
||||||
|
* This is needed becauseController::currreturns the widget controller,
|
||||||
|
* which means anyLinkfunction turns into endless loop.
|
||||||
|
*
|
||||||
|
* @return Controller
|
||||||
|
*/
|
||||||
|
public function getParentController()
|
||||||
{
|
{
|
||||||
return $this->widget;
|
foreach(Controller::$controller_stack as $controller) {
|
||||||
}
|
if (!($controller instanceof WidgetController)) {
|
||||||
|
return $controller;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Overloaded from {@link Widget->Content()} to allow for controller / form
|
* @return Widget
|
||||||
* linking.
|
*/
|
||||||
*
|
public function getWidget()
|
||||||
* @return string HTML
|
{return $this->widget;
|
||||||
*/
|
}
|
||||||
public function Content()
|
|
||||||
{
|
|
||||||
return $this->renderWith(array_reverse(ClassInfo::ancestry($this->widget->class)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Overloaded from {@link Widget->WidgetHolder()} to allow for controller/
|
* Overloaded from {@link Widget->Content()} to allow for controller / form
|
||||||
* form linking.
|
* linking.
|
||||||
*
|
*
|
||||||
* @return string HTML
|
* @return string HTML
|
||||||
*/
|
*/
|
||||||
public function WidgetHolder()
|
public function Content()
|
||||||
{
|
{return $this->renderWith(array_reverse(ClassInfo::ancestry($this->widget->class)));
|
||||||
return $this->renderWith("WidgetHolder");
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Uses the `WidgetEditor.ss` template and {@link Widget->editablesegment()}
|
* Overloaded from {@link Widget->WidgetHolder()} to allow for controller/
|
||||||
* to render a administrator-view of the widget. It is assumed that this
|
* form linking.
|
||||||
* view contains form elements which are submitted and saved through
|
*
|
||||||
* {@link WidgetAreaEditor} within the CMS interface.
|
* @return string HTML
|
||||||
*
|
*/
|
||||||
* @return string HTML
|
public function WidgetHolder()
|
||||||
*/
|
{return $this->renderWith("WidgetHolder");
|
||||||
public function editablesegment()
|
}
|
||||||
{
|
|
||||||
|
/**
|
||||||
|
* Uses the `WidgetEditor.ss` template and {@link Widget->editablesegment()}
|
||||||
|
* to render a administrator-view of the widget. It is assumed that this
|
||||||
|
* view contains form elements which are submitted and saved through
|
||||||
|
* {@link WidgetAreaEditor} within the CMS interface.
|
||||||
|
*
|
||||||
|
* @return string HTML
|
||||||
|
*/
|
||||||
|
public function editablesegment() {
|
||||||
// use left and main to set the html config
|
// use left and main to set the html config
|
||||||
$leftandmain = LeftAndMain::create();
|
$leftandmain = LeftAndMain::create();
|
||||||
$leftandmain->init();
|
$leftandmain->init();
|
||||||
|
$className = $this->urlParams['ID'];
|
||||||
$className = $this->urlParams['ID'];
|
if (class_exists('Translatable') && Member::currentUserID()) {
|
||||||
if (class_exists('Translatable') && Member::currentUserID()) {
|
// set current locale based on logged in user's locale
|
||||||
// set current locale based on logged in user's locale
|
$locale = Member::currentUser()->Locale;
|
||||||
$locale = Member::currentUser()->Locale;
|
i18n::set_locale($locale);
|
||||||
i18n::set_locale($locale);
|
}
|
||||||
}
|
if(class_exists($className) && is_subclass_of($className, 'Widget')) {
|
||||||
if (class_exists($className) && is_subclass_of($className, 'Widget')) {
|
$obj = new $className();
|
||||||
$obj = new $className();
|
return $obj->EditableSegment();
|
||||||
return $obj->EditableSegment();
|
} else {
|
||||||
} else {
|
user_error("Bad widget class: $className", E_USER_WARNING);
|
||||||
user_error("Bad widget class: $className", E_USER_WARNING);
|
return "Bad widget class name given";
|
||||||
return "Bad widget class name given";
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
ar:
|
ar:
|
||||||
Widget:
|
Widget:
|
||||||
PLURALNAME: تطبيقات مصغرة
|
PLURALNAME: 'تطبيقات مصغرة'
|
||||||
SINGULARNAME: تطبيق مصغر
|
SINGULARNAME: 'تطبيق مصغر'
|
||||||
WidgetArea:
|
WidgetArea:
|
||||||
PLURALNAME: 'مساحات التطبيقات المصغرة'
|
PLURALNAME: 'مساحات التطبيقات المصغرة'
|
||||||
SINGULARNAME: 'مساحة التطبيقات المصغرة'
|
SINGULARNAME: 'مساحة التطبيقات المصغرة'
|
||||||
@ -14,4 +14,4 @@ ar:
|
|||||||
WidgetDescription_ss:
|
WidgetDescription_ss:
|
||||||
CLICKTOADDWIDGET: 'اضغط لإضافة هذا التطبيق المصغر'
|
CLICKTOADDWIDGET: 'اضغط لإضافة هذا التطبيق المصغر'
|
||||||
WidgetEditor_ss:
|
WidgetEditor_ss:
|
||||||
DELETE: مسح
|
DELETE: 'مسح'
|
||||||
|
@ -3,8 +3,8 @@ de:
|
|||||||
PLURALNAME: Widgets
|
PLURALNAME: Widgets
|
||||||
SINGULARNAME: Widget
|
SINGULARNAME: Widget
|
||||||
WidgetArea:
|
WidgetArea:
|
||||||
PLURALNAME: 'Widgetbereiche'
|
PLURALNAME: Widgetbereiche
|
||||||
SINGULARNAME: 'Widgetbereich'
|
SINGULARNAME: Widgetbereich
|
||||||
WidgetAreaEditor_ss:
|
WidgetAreaEditor_ss:
|
||||||
AVAILABLE: 'Vorhandene Widgets'
|
AVAILABLE: 'Vorhandene Widgets'
|
||||||
AVAILWIDGETS: 'Klicke den Widget Titel, um es zu benutzen.'
|
AVAILWIDGETS: 'Klicke den Widget Titel, um es zu benutzen.'
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
fa_IR:
|
fa_IR:
|
||||||
Widget:
|
Widget:
|
||||||
PLURALNAME: ویجت ها
|
PLURALNAME: 'ویجت ها'
|
||||||
SINGULARNAME: ویجت
|
SINGULARNAME: ویجت
|
||||||
WidgetArea:
|
WidgetArea:
|
||||||
PLURALNAME: 'محیط ویجت ها'
|
PLURALNAME: 'محیط ویجت ها'
|
||||||
|
17
lang/sk.yml
Normal file
17
lang/sk.yml
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
sk:
|
||||||
|
Widget:
|
||||||
|
PLURALNAME: Widgety
|
||||||
|
SINGULARNAME: Widget
|
||||||
|
WidgetArea:
|
||||||
|
PLURALNAME: 'Oblasti widgetu'
|
||||||
|
SINGULARNAME: 'Oblasť widgetu'
|
||||||
|
WidgetAreaEditor_ss:
|
||||||
|
AVAILABLE: 'Dostupné widgety'
|
||||||
|
AVAILWIDGETS: 'Kliknite na názov widgetu pre jeho použitie na tejto stránke.'
|
||||||
|
INUSE: 'Momentálne používané widgety.'
|
||||||
|
NOAVAIL: 'Momentálne nie sú dostupné žiadne widgety.'
|
||||||
|
TOSORT: 'Pre zotriedenie momentálne používaných widgetov na tejto stránke, potiahnite ich hore alebo dole.'
|
||||||
|
WidgetDescription_ss:
|
||||||
|
CLICKTOADDWIDGET: 'Kliknite pre pridanie tohto widgetu'
|
||||||
|
WidgetEditor_ss:
|
||||||
|
DELETE: Vymazať
|
@ -3,8 +3,8 @@ sv:
|
|||||||
PLURALNAME: Widgets
|
PLURALNAME: Widgets
|
||||||
SINGULARNAME: Widget
|
SINGULARNAME: Widget
|
||||||
WidgetArea:
|
WidgetArea:
|
||||||
PLURALNAME: 'Widgetområden'
|
PLURALNAME: Widgetområden
|
||||||
SINGULARNAME: 'Widgetområde'
|
SINGULARNAME: Widgetområde
|
||||||
WidgetAreaEditor_ss:
|
WidgetAreaEditor_ss:
|
||||||
AVAILABLE: 'Tillgängliga widgets'
|
AVAILABLE: 'Tillgängliga widgets'
|
||||||
AVAILWIDGETS: 'Klicka på en widget nedan för att använda den på sidan.'
|
AVAILWIDGETS: 'Klicka på en widget nedan för att använda den på sidan.'
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
zh:
|
zh:
|
||||||
Widget:
|
Widget:
|
||||||
PLURALNAME: 小工具
|
PLURALNAME: '小工具'
|
||||||
SINGULARNAME: 小工具
|
SINGULARNAME: '小工具'
|
||||||
WidgetArea:
|
WidgetArea:
|
||||||
PLURALNAME: '小工具区域'
|
PLURALNAME: '小工具区域'
|
||||||
SINGULARNAME: '小工具区域'
|
SINGULARNAME: '小工具区域'
|
||||||
@ -14,4 +14,4 @@ zh:
|
|||||||
WidgetDescription_ss:
|
WidgetDescription_ss:
|
||||||
CLICKTOADDWIDGET: '点击添加该小工具'
|
CLICKTOADDWIDGET: '点击添加该小工具'
|
||||||
WidgetEditor_ss:
|
WidgetEditor_ss:
|
||||||
DELETE: 删除
|
DELETE: '删除'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user