Merge branch 'extended-cookie'
[scuttle] / services / templateservice.php
1 <?php
2 class TemplateService {
3   var $basedir;
4
5   function &getInstance() {
6     static $instance;
7     if (!isset($instance)) {
8       $instance = new TemplateService();
9     }
10     return $instance;
11   }
12
13   function TemplateService() {
14     $this->basedir = $GLOBALS['TEMPLATES_DIR'];    
15   }
16
17   function loadTemplate($template, $vars = NULL) {
18     if (substr($template, -4) != '.php') {
19       $template .= '.php';
20     }
21     $tpl = new Template($this->basedir .'/'. $template, $vars, $this);
22     $tpl->parse();
23     return $tpl;
24   }
25 }
26
27 class Template {
28   var $vars = array();
29   var $file = '';
30   var $templateservice;
31
32   function Template($file, $vars = NULL, &$templateservice) {
33     $this->vars = $vars;
34     $this->file = $file;
35     $this->templateservice = $templateservice; 
36   }
37
38   function parse() {
39     if (isset($this->vars)) {
40       extract($this->vars);
41     }
42     include $this->file;
43   }
44
45   function includeTemplate($name) {
46     return $this->templateservice->loadTemplate($name, $this->vars);
47   }
48 }

Benjamin Mako Hill || Want to submit a patch?