X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2Ffriendica_smarty.php;h=3c2dc7b9150e242b56b363ab62bf1c8c57365917;hb=0aa69f134f8b2ac438af052ea6a4839b67e7be33;hp=b5169267545b9f53ca3dc300e5ad850e4c57bea9;hpb=3339f55310587d96bb4e0cf43542719a5a41448b;p=friendica.git diff --git a/include/friendica_smarty.php b/include/friendica_smarty.php index b516926754..3c2dc7b915 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 = [ + "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);