diff options
| author | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:07:19 +0200 |
|---|---|---|
| committer | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2021-07-22 16:19:12 +0200 |
| commit | a3da1483a9e689846179159355badfec8073dbec (patch) | |
| tree | 770dcca6bdf5f6f2a11b0e7fcbbeda6919a3fc52 /app/controllers/plugin_controller.php | |
current code from svn, revision 62608
Diffstat (limited to 'app/controllers/plugin_controller.php')
| -rw-r--r-- | app/controllers/plugin_controller.php | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/app/controllers/plugin_controller.php b/app/controllers/plugin_controller.php new file mode 100644 index 0000000..7710bff --- /dev/null +++ b/app/controllers/plugin_controller.php @@ -0,0 +1,70 @@ +<?php +/** + * Copyright (c) 2014 Rasmus Fuhse <fuhse@data-quest.de> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + */ + +class PluginController extends StudipController +{ + public function __construct($dispatcher) + { + parent::__construct($dispatcher); + + $this->plugin = $dispatcher->current_plugin; + + if ($this->plugin && $this->plugin->hasTranslation()) { + // Localization + $this->_ = function ($string) { + return call_user_func_array( + [$this->plugin, '_'], + func_get_args() + ); + }; + + $this->_n = function ($string0, $tring1, $n) { + return call_user_func_array( + [$this->plugin, '_n'], + func_get_args() + ); + }; + } + } + + /** + * Creates the body element id for this controller a given action. + * + * @param string $unconsumed_path Unconsumed path to extract action from + * @return string + */ + protected function getBodyElementIdForControllerAndAction($unconsumed_path) + { + $body_id = implode('-', [ + 'plugin', + strtosnakecase(get_class($this->plugin)), + parent::getBodyElementIdForControllerAndAction($unconsumed_path), + ]); + + return $body_id; + } + + /** + * Intercepts all non-resolvable method calls in order to correctly handle + * calls to _ and _n. + * + * @param string $method + * @param array $arguments + * @return mixed + */ + public function __call($method, $arguments) + { + $variables = get_object_vars($this); + if (isset($variables[$method]) && is_callable($variables[$method])) { + return call_user_func_array($variables[$method], $arguments); + } + return parent::__call($method, $arguments); + } +} |
