diff options
author | Bharat Mediratta <bharat@menalto.com> | 2009-05-28 06:11:53 +0800 |
---|---|---|
committer | Gallery Role Account <gallery@menalto.com> | 2009-05-28 11:07:08 +0800 |
commit | 3413fe6bfd423d45d083ff4ed62c0f72c2cc272f (patch) | |
tree | 9310d1c82838d3e5076042be48178f5d53f5d971 /system/controllers/template.php | |
parent | b245e3475f66c94afb94f8b2287bf0185a343732 (diff) |
Rename 'kohana' to 'system' to conform to the Kohana filesystem layout. I'm comfortable with us not clearly drawing the distinction about the fact that it's Kohana.
Signed-off-by: Gallery Role Account <gallery@menalto.com>
Diffstat (limited to 'system/controllers/template.php')
-rw-r--r-- | system/controllers/template.php | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/system/controllers/template.php b/system/controllers/template.php new file mode 100644 index 00000000..34d1a226 --- /dev/null +++ b/system/controllers/template.php @@ -0,0 +1,54 @@ +<?php defined('SYSPATH') OR die('No direct access allowed.'); +/** + * Allows a template to be automatically loaded and displayed. Display can be + * dynamically turned off in the controller methods, and the template file + * can be overloaded. + * + * To use it, declare your controller to extend this class: + * `class Your_Controller extends Template_Controller` + * + * $Id: template.php 3769 2008-12-15 00:48:56Z zombor $ + * + * @package Core + * @author Kohana Team + * @copyright (c) 2007-2008 Kohana Team + * @license http://kohanaphp.com/license.html + */ +abstract class Template_Controller extends Controller { + + // Template view name + public $template = 'template'; + + // Default to do auto-rendering + public $auto_render = TRUE; + + /** + * Template loading and setup routine. + */ + public function __construct() + { + parent::__construct(); + + // Load the template + $this->template = new View($this->template); + + if ($this->auto_render == TRUE) + { + // Render the template immediately after the controller method + Event::add('system.post_controller', array($this, '_render')); + } + } + + /** + * Render the loaded template. + */ + public function _render() + { + if ($this->auto_render == TRUE) + { + // Render the template when the class is destroyed + $this->template->render(TRUE); + } + } + +} // End Template_Controller
\ No newline at end of file |