diff --git a/core/Plugin.php b/core/Plugin.php index af564a002b8e3eaaa6ab89be037888a2685181f3..bb361b5bb5e596b4c9038ce2ad7b5985d77745af 100644 --- a/core/Plugin.php +++ b/core/Plugin.php @@ -8,6 +8,7 @@ */ namespace Piwik; +use Piwik\Container\StaticContainer; use Piwik\Plugin\Dependency; use Piwik\Plugin\MetadataLoader; @@ -359,7 +360,7 @@ class Plugin $this->cache->save($cacheId, $classname); } - return new $classname; + return StaticContainer::get($classname); } public function findMultipleComponents($directoryWithinPlugin, $expectedSubclass) diff --git a/core/Plugin/Menu.php b/core/Plugin/Menu.php index d2c54645f1c3e4afbbf389681877c9afbb17a10d..e354728821c7d259a7dea145fa5cc486e01e79ee 100644 --- a/core/Plugin/Menu.php +++ b/core/Plugin/Menu.php @@ -30,16 +30,6 @@ use Piwik\Plugins\UsersManager\UserPreferences; */ class Menu { - protected $module = ''; - - /** - * @ignore - */ - public function __construct() - { - $this->module = $this->getModule(); - } - private function getModule() { $className = get_class($this); @@ -69,7 +59,7 @@ class Menu { $params = (array) $additionalParams; $params['action'] = ''; - $params['module'] = $this->module; + $params['module'] = $this->getModule(); return $params; } @@ -88,11 +78,12 @@ class Menu */ protected function urlForAction($controllerAction, $additionalParams = array()) { - $this->checkisValidCallable($this->module, $controllerAction); + $module = $this->getModule(); + $this->checkisValidCallable($module, $controllerAction); $params = (array) $additionalParams; $params['action'] = $controllerAction; - $params['module'] = $this->module; + $params['module'] = $module; return $params; } diff --git a/core/Plugin/Widgets.php b/core/Plugin/Widgets.php index 36081fe2d29e86ae09677cbbf0dcc923c4b4733c..5a0cad6fde1f5131b40b5e9cec9d80f626655f3b 100644 --- a/core/Plugin/Widgets.php +++ b/core/Plugin/Widgets.php @@ -25,16 +25,6 @@ class Widgets protected $category = ''; protected $widgets = array(); - private $module = ''; - - /** - * @ignore - */ - public function __construct() - { - $this->module = $this->getModule(); - } - /** * @ignore */ @@ -77,7 +67,7 @@ class Widgets 'name' => $name, 'params' => $parameters, 'method' => $method, - 'module' => $this->module); + 'module' => $this->getModule()); } /** @@ -182,7 +172,7 @@ class Widgets return; } - $controllerClass = '\\Piwik\\Plugins\\' . $this->module . '\\Controller'; + $controllerClass = 'Piwik\\Plugins\\' . $this->getModule() . '\\Controller'; if (!Development::methodExists($this, $method) && !Development::methodExists($controllerClass, $method)) { diff --git a/plugins/CoreHome/Widgets.php b/plugins/CoreHome/Widgets.php index 68812f07494005d2f53960b493a595752a842294..17d888bd35c43c6226af07a4cc0740047a27d6a4 100644 --- a/plugins/CoreHome/Widgets.php +++ b/plugins/CoreHome/Widgets.php @@ -10,12 +10,23 @@ namespace Piwik\Plugins\CoreHome; use Piwik\Common; use Piwik\Piwik; +use Piwik\Translation\Translator; use Piwik\View; class Widgets extends \Piwik\Plugin\Widgets { protected $category = 'Example Widgets'; + /** + * @var Translator + */ + private $translator; + + public function __construct(Translator $translator) + { + $this->translator = $translator; + } + protected function init() { $this->addWidget('CoreHome_SupportPiwik', 'getDonateForm'); @@ -31,7 +42,7 @@ class Widgets extends \Piwik\Plugin\Widgets if (Common::getRequestVar('widget', false) && Piwik::hasUserSuperUserAccess()) { - $view->footerMessage = Piwik::translate('CoreHome_OnlyForSuperUserAccess'); + $view->footerMessage = $this->translator->translate('CoreHome_OnlyForSuperUserAccess'); } return $view->render(); @@ -43,8 +54,8 @@ class Widgets extends \Piwik\Plugin\Widgets public function getPromoVideo() { $view = new View('@CoreHome/getPromoVideo'); - $view->shareText = Piwik::translate('CoreHome_SharePiwikShort'); - $view->shareTextLong = Piwik::translate('CoreHome_SharePiwikLong'); + $view->shareText = $this->translator->translate('CoreHome_SharePiwikShort'); + $view->shareTextLong = $this->translator->translate('CoreHome_SharePiwikLong'); $view->promoVideoUrl = 'https://www.youtube.com/watch?v=OslfF_EH81g'; return $view->render();