From f574528338f8a7c1136432dba05abadf156b6c47 Mon Sep 17 00:00:00 2001 From: Hypolite Petovan Date: Thu, 1 Feb 2018 13:31:03 -0500 Subject: [PATCH] Add FriendicaSmarty and FriendicaSmartyEngine classes in src --- src/Render/FriendicaSmarty.php | 54 ++++++++++++++++++++++++++ src/Render/FriendicaSmartyEngine.php | 57 ++++++++++++++++++++++++++++ 2 files changed, 111 insertions(+) create mode 100644 src/Render/FriendicaSmarty.php create mode 100644 src/Render/FriendicaSmartyEngine.php diff --git a/src/Render/FriendicaSmarty.php b/src/Render/FriendicaSmarty.php new file mode 100644 index 0000000000..b863576127 --- /dev/null +++ b/src/Render/FriendicaSmarty.php @@ -0,0 +1,54 @@ + "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/'); + $this->setConfigDir('view/smarty3/config/'); + $this->setCacheDir('view/smarty3/cache/'); + + $this->left_delimiter = $a->get_template_ldelim('smarty3'); + $this->right_delimiter = $a->get_template_rdelim('smarty3'); + + // Don't report errors so verbosely + $this->error_reporting = E_ALL & ~E_NOTICE; + } + + function parsed($template = '') + { + if ($template) { + return $this->fetch('string:' . $template); + } + return $this->fetch('file:' . $this->filename); + } + +} \ No newline at end of file diff --git a/src/Render/FriendicaSmartyEngine.php b/src/Render/FriendicaSmartyEngine.php new file mode 100644 index 0000000000..a565f3ad36 --- /dev/null +++ b/src/Render/FriendicaSmartyEngine.php @@ -0,0 +1,57 @@ +ERROR: folder view/smarty3/ must be writable by webserver."; + killme(); + } + } + + // ITemplateEngine interface + public function replaceMacros($s, $r) + { + $template = ''; + if (gettype($s) === 'string') { + $template = $s; + $s = new FriendicaSmarty(); + } + + $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); + } + + public function getTemplateFile($file, $root = '') + { + $a = get_app(); + $template_file = get_template_file($a, SMARTY3_TEMPLATE_FOLDER . '/' . $file, $root); + $template = new FriendicaSmarty(); + $template->filename = $template_file; + return $template; + } +} -- 2.39.5