X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=inline;f=include%2Ffriendica_smarty.php;h=f95bb69aaae2ef292f6cd79f209d55b09b82589a;hb=b3e6a1d2832be024819328e51e9e1df4c25b560f;hp=f9d91a827d01e58e4bb83985d1dbace330e3fc24;hpb=ddf1caf0fd9ea4fc97147ba7b45587bcf7a6fab4;p=friendica.git
diff --git a/include/friendica_smarty.php b/include/friendica_smarty.php
index f9d91a827d..f95bb69aaa 100644
--- a/include/friendica_smarty.php
+++ b/include/friendica_smarty.php
@@ -1,12 +1,17 @@
"view/theme/$theme/smarty3/");
- if( x($a->theme_info,"extends") )
- $template_dirs = $template_dirs + array('extends' => "view/theme/".$a->theme_info["extends"]."/smarty3/");
- $template_dirs = $template_dirs + array('base' => 'view/smarty3/');
+ $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 . "/");
$this->setTemplateDir($template_dirs);
$this->setCompileDir('view/smarty3/compiled/');
@@ -31,37 +36,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";
+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 = 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=''){
+
+ public function getTemplateFile($file, $root = '')
+ {
$a = get_app();
- $template_file = get_template_file($a, 'smarty3/' . $file, $root);
+ $template_file = get_template_file($a, SMARTY3_TEMPLATE_FOLDER . '/' . $file, $root);
$template = new FriendicaSmarty();
$template->filename = $template_file;
return $template;