X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=include%2Ffriendica_smarty.php;h=a7d153e30963b98de08e123a17508d7a6a2d9223;hb=28d79281a9d521591d197215aaf9a7c92ed265e1;hp=b5169267545b9f53ca3dc300e5ad850e4c57bea9;hpb=462f19ccf2eb54306415f03892da6bf4ef1fa7d3;p=friendica.git
diff --git a/include/friendica_smarty.php b/include/friendica_smarty.php
index b516926754..a7d153e309 100644
--- a/include/friendica_smarty.php
+++ b/include/friendica_smarty.php
@@ -1,14 +1,16 @@
"view/theme/$theme/".SMARTY3_TEMPLATE_FOLDER."/");
- if( x($a->theme_info,"extends") )
- $template_dirs = $template_dirs + array('extends' => "view/theme/".$a->theme_info["extends"]."/".SMARTY3_TEMPLATE_FOLDER."/");
- $template_dirs = $template_dirs + array('base' => "view/".SMARTY3_TEMPLATE_FOLDER."/");
+ $template_dirs = ['theme' => "view/theme/$theme/" . SMARTY3_TEMPLATE_FOLDER . "/"];
+ if (x($a->theme_info, "extends"))
+ $template_dirs = $template_dirs + ['extends' => "view/theme/" . $a->theme_info["extends"] . "/" . SMARTY3_TEMPLATE_FOLDER . "/"];
+ $template_dirs = $template_dirs + ['base' => "view/" . SMARTY3_TEMPLATE_FOLDER . "/"];
$this->setTemplateDir($template_dirs);
$this->setCompileDir('view/smarty3/compiled/');
@@ -33,44 +35,60 @@ class FriendicaSmarty extends Smarty {
$this->error_reporting = E_ALL & ~E_NOTICE;
}
- function parsed($template = '') {
- if($template) {
+ function parsed($template = '')
+ {
+ if ($template) {
return $this->fetch('string:' . $template);
}
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();
+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) {
+ public function replaceMacros($s, $r)
+ {
$template = '';
- if(gettype($s) === 'string') {
+ if (gettype($s) === 'string') {
$template = $s;
$s = new FriendicaSmarty();
}
- foreach($r as $key=>$value) {
- if($key[0] === '$') {
+
+ $r['$APP'] = get_app();
+
+ // "middleware": inject variables into templates
+ $arr = [
+ "template" => basename($s->filename),
+ "vars" => $r
+ ];
+ Addon::callHooks("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=''){
+
+ public function getTemplateFile($file, $root = '')
+ {
$a = get_app();
- $template_file = get_template_file($a, SMARTY3_TEMPLATE_FOLDER.'/'.$file, $root);
+ $template_file = get_template_file($a, SMARTY3_TEMPLATE_FOLDER . '/' . $file, $root);
$template = new FriendicaSmarty();
$template->filename = $template_file;
return $template;