]> git.mxchange.org Git - friendica.git/commitdiff
Fix template_var hook
authorfabrixxm <fabrix.xm@gmail.com>
Fri, 6 Nov 2015 18:52:00 +0000 (19:52 +0100)
committerfabrixxm <fabrix.xm@gmail.com>
Fri, 6 Nov 2015 18:52:00 +0000 (19:52 +0100)
move it to smarty3 replate_macro, pass the theme name in $b

doc/Plugins.md
include/friendica_smarty.php
include/text.php

index 62d06f1c5683f8743b2c90f29aded0bbef11b8d0..24d403e1f6f57514070fbc528a0bc81fd4bfc4e7 100644 (file)
@@ -274,7 +274,11 @@ $b is an array containing $nav from nav.php.
 ###'template_vars'
 is called before vars are passed to the template engine to render the page.
 The registered function can add,change or remove variables passed to template.
-$b is the array of vars pased to 'replace_macros()' function.
+$b is an array with:
+
+    'template' => filename of template
+    'vars' => array of vars passed to template
+
 
 
 Complete list of hook callbacks
index b5169267545b9f53ca3dc300e5ad850e4c57bea9..3c2dc7b9150e242b56b363ab62bf1c8c57365917 100644 (file)
@@ -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 "<b>ERROR:</b> folder <tt>view/smarty3/</tt> 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);
index a738a281f58423c15d4efc80e1241185548cc2a6..f89a64a5706b3e96c73d00874180eab4fdca619f 100644 (file)
@@ -19,10 +19,6 @@ function replace_macros($s,$r) {
 
        $stamp1 = microtime(true);
 
-       // "middleware": inject variables into templates
-       call_hooks("template_vars", $r);
-
-
        $a = get_app();
 
        $t = $a->template_engine();