]> git.mxchange.org Git - friendica.git/blobdiff - include/friendica_smarty.php
Use short form array syntax everywhere
[friendica.git] / include / friendica_smarty.php
index 3c2dc7b9150e242b56b363ab62bf1c8c57365917..1992a3716ee5e159fc995af1972af210f04c06f2 100644 (file)
@@ -1,15 +1,17 @@
 <?php
 
-require_once "object/TemplateEngine.php";
-require_once("library/Smarty/libs/Smarty.class.php");
+use Friendica\Render\ITemplateEngine;
+
 require_once "include/plugin.php";
 
-define('SMARTY3_TEMPLATE_FOLDER','templates');
+define('SMARTY3_TEMPLATE_FOLDER', 'templates');
 
-class FriendicaSmarty extends Smarty {
+class FriendicaSmarty extends Smarty
+{
        public $filename;
 
-       function __construct() {
+       function __construct()
+       {
                parent::__construct();
 
                $a = get_app();
@@ -17,10 +19,10 @@ class FriendicaSmarty extends Smarty {
 
                // setTemplateDir can be set to an array, which Smarty will parse in order.
                // The order is thus very important here
-               $template_dirs = array('theme' => "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/');
@@ -34,43 +36,49 @@ 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";
+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();
+       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) {
+       public function replaceMacros($s, $r)
+       {
                $template = '';
-               if(gettype($s) === 'string') {
+               if (gettype($s) === 'string') {
                        $template = $s;
                        $s = new FriendicaSmarty();
                }
 
+               $r['$APP'] = get_app();
+
                // "middleware": inject variables into templates
                $arr = [
-                       "template"=> basename($s->filename),
+                       "template" => basename($s->filename),
                        "vars" => $r
                ];
                call_hooks("template_vars", $arr);
                $r = $arr['vars'];
 
-               foreach($r as $key=>$value) {
-                       if($key[0] === '$') {
+               foreach ($r as $key => $value) {
+                       if ($key[0] === '$') {
                                $key = substr($key, 1);
                        }
                        $s->assign($key, $value);
@@ -78,9 +86,10 @@ class FriendicaSmartyEngine implements ITemplateEngine {
                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;