X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=include%2Ffriendica_smarty.php;h=9ba2d2a744dcc88fea320253dec337d54345fefd;hb=b2cded0758946b413992e5742fa6321f3a34d933;hp=b5169267545b9f53ca3dc300e5ad850e4c57bea9;hpb=a2102e1ca08161cb8eef15e4d98c72aef7ed10d9;p=friendica.git
diff --git a/include/friendica_smarty.php b/include/friendica_smarty.php
index b516926754..9ba2d2a744 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,26 @@ class FriendicaSmartyEngine implements ITemplateEngine {
$template = $s;
$s = new FriendicaSmarty();
}
+
+ $r['$APP'] = get_app();
+
+ // "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);