X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2Ffriendica_smarty.php;h=99dc12bf8d9a27c96d6a2b79bed01e9939ad2aa0;hb=143e1a4a836e1fe4d05ab5d1c6008aa0198d2db5;hp=b5169267545b9f53ca3dc300e5ad850e4c57bea9;hpb=3339f55310587d96bb4e0cf43542719a5a41448b;p=friendica.git diff --git a/include/friendica_smarty.php b/include/friendica_smarty.php index b516926754..99dc12bf8d 100644 --- a/include/friendica_smarty.php +++ b/include/friendica_smarty.php @@ -2,6 +2,7 @@ require_once "object/TemplateEngine.php"; require_once("library/Smarty/libs/Smarty.class.php"); +require_once "include/plugin.php"; define('SMARTY3_TEMPLATE_FOLDER','templates'); @@ -39,19 +40,19 @@ class FriendicaSmarty extends Smarty { } return $this->fetch('file:' . $this->filename); } - + } class FriendicaSmartyEngine implements ITemplateEngine { static $name ="smarty3"; - + public function __construct(){ if(!is_writable('view/smarty3/')){ echo "ERROR: folder view/smarty3/ must be writable by webserver."; killme(); } - } - + } + // ITemplateEngine interface public function replace_macros($s, $r) { $template = ''; @@ -59,15 +60,24 @@ class FriendicaSmartyEngine implements ITemplateEngine { $template = $s; $s = new FriendicaSmarty(); } + + // "middleware": inject variables into templates + $arr = array( + "template"=> basename($s->filename), + "vars" => $r + ); + call_hooks("template_vars", $arr); + $r = $arr['vars']; + foreach($r as $key=>$value) { if($key[0] === '$') { $key = substr($key, 1); } $s->assign($key, $value); } - return $s->parsed($template); + return $s->parsed($template); } - + public function get_template_file($file, $root=''){ $a = get_app(); $template_file = get_template_file($a, SMARTY3_TEMPLATE_FOLDER.'/'.$file, $root);