summaryrefslogtreecommitdiff
path: root/core/controllers
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2008-12-20 01:42:18 +0000
committerBharat Mediratta <bharat@menalto.com>2008-12-20 01:42:18 +0000
commite4bace4c7414138d8d9b67f79a902f63694fc10c (patch)
tree9c45ba59a588723b6245d0936497f9338eaf70fc /core/controllers
parentb933d1a17096bfe61cf43ee866d7ae5eb557e3af (diff)
Collapse Admin_Dashboard_Controller down into a single theme call, since now
all dashboard blocks are stored in modules.
Diffstat (limited to 'core/controllers')
-rw-r--r--core/controllers/admin.php19
-rw-r--r--core/controllers/admin_dashboard.php4
2 files changed, 14 insertions, 9 deletions
diff --git a/core/controllers/admin.php b/core/controllers/admin.php
index d6d65c69..2a6bae7e 100644
--- a/core/controllers/admin.php
+++ b/core/controllers/admin.php
@@ -18,20 +18,25 @@
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
class Admin_Controller extends Controller {
- public function __construct() {
+ private $theme;
+
+ public function __construct($theme=null) {
if (!(user::active()->admin)) {
throw new Exception("@todo UNAUTHORIZED", 401);
}
+ $this->theme = $theme;
parent::__construct();
}
+ public function theme() {
+ return $this->theme;
+ }
+
public function __call($controller_name, $args) {
if ($controller_name == "index") {
$controller_name = "dashboard";
}
-
- $controller = "Admin_{$controller_name}_Controller";
- $controller = new $controller;
+ $controller_name = "Admin_{$controller_name}_Controller";
if ($args) {
$method = array_shift($args);
@@ -40,9 +45,9 @@ class Admin_Controller extends Controller {
}
$theme_name = module::get_var("core", "active_admin_theme", "admin_default");
- $template = new Admin_View("admin.html", $theme_name);
- $template->content =
- call_user_func_array(array(new $controller, $method), $args);
+ $this->template = $template = new Admin_View("admin.html", $theme_name);
+ $template->content = call_user_func_array(
+ array(new $controller_name($template), $method), $args);
print $template;
}
}
diff --git a/core/controllers/admin_dashboard.php b/core/controllers/admin_dashboard.php
index 7d752495..a29c2167 100644
--- a/core/controllers/admin_dashboard.php
+++ b/core/controllers/admin_dashboard.php
@@ -17,9 +17,9 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
-class Admin_Dashboard_Controller extends Controller {
+class Admin_Dashboard_Controller extends Admin_Controller {
public function index() {
- return new View("admin_dashboard.html");
+ return $this->theme()->dashboard_blocks();
}
}