Use the source tab below to compare the rendered template to the source to use how you can use ViewFish Templating.
This is a test of ViewFish Templating. It was written by Adam Scheinberg. It is written in PHP.
The current date is January 22, 2025, which is often written as 2025-01-22 and corresponds to unix timestamp 1737531794, which can also be expressed as 1737531794. You can use arguments found at php.net/date.
It has basic skills, such as escaping text: <i><b>This should be escaped text</b></i>
It supports simple string functions, such as str_rot13 - IvrjSvfu Grzcyngvat - and juggling case - viewfish templating.
It supports custom functions: "Viewfish Templating-VIEWFISH TEMPLATING".
It also can chain functions, such as uppercasing and str_rot13: IVRJSVFU GRZCYNGVAT.
Here is a function that was dynamically added, sha1: 882d0edf97c3d20bdb3547dc7f9a68f62f99fe03
Here are example of a dynamic placeholders 1) a unique identifier: 6790a19281bb0 2) a datetime: 2025-01-22 7:43:14 and 3) a datetime in UTC: 2025-01-22 7:43:14.
You can use substr, here's substr($str,3,10): quick bro. A long string can be quickly shortened using the shortcut function ellipsis: The quick brown fo…
Variables that end with an exclamation point will be removed if they are not matched - for example, it should be blank between the quotes "". But those unmatched will remain untouched, like {{so}}.
<?php
# require the templating library
require '../source/ViewFish.php';
# first, you instantiate a ViewFish object
$T = new ViewFish\viewfish();
# set the template path
$T->set_template_path(__DIR__.'/../templates/');
# You can feed the Small Axe object a memcached resource for storing uncompiled templates
# a memory cache system is optional
$memcache = new Memcached();
$memcache->addServer("localhost", 11211);
$T->enable_cache($memcache);
# you can also add functions that the template can parse
# currently, functions are only supported if they can take the value as an argument and return it as a string
# only functions YOU explicitly allow will work in your templates
# for example, this will add the "sha1()" and "str_rot13" functions
$T->extend(['sha1', 'str_rot13']);
# the extend() method will also accept your custom functions
function custom_function($string) {
return '"<i>'.ucwords(strtolower($string))."-".strtoupper($string).'"</i>';
}
$T->extend(['custom_function']);
# define our variables
$vars = [
'software_title' => "ViewFish Templating",
"author" => "adam scheinberg",
'year' => date('Y'),
'language' => "php",
'test_text' => "<i><b>This should be escaped text</b></i>",
'random' => "This is a random string",
'longstring' => "The quick brown fox jumped over the lazy dog"
];
# load template by passing either the file in the templates folder OR a hard coded path
# when searching the template directory, if no file extension is provided and no file is matched without an extension,
# it will assume ".tmpl" or ".tpl"
$template = $T->load_template("demo1");
# compile the template
$html = $T->render($template,$vars);
# echo the template
echo $html;
<html>
<head>
<title>A test of {{software_title|ucwords}}</title>
</head>
<body>
<h1>WELCOME TO {{software_title|upper}}</h1>
<p>This is a test of {{software_title}}. It was written by {{author|ucwords}}. It is written in {{language|upper}}.</p>
<p>The current date is {{date|F d, Y}}, which is often written as {{date|Y-m-d}} and corresponds to unix timestamp {{date|U}}, which can also be expressed as [[timestamp]]. You can use arguments found at <a href="https://php.net/date">php.net/date</a>.</p>
<p>It has basic skills, such as escaping text: <code>{{test_text|e}}</code></p>
<p>It supports simple string functions, such as str_rot13 - {{software_title|str_rot13}} - and juggling case - {{software_title|lower}}. </p>
{* this is a Smarty style comment *}
<p>It supports custom functions: {{software_title|custom_function}}. </p>
/*
this
is
a
C style
comment */
<p>It also can chain functions, such as uppercasing and str_rot13: {{software_title|upper|str_rot13}}. </p>
<p>Here is a function that was dynamically added, sha1: {{random|sha1}}</p>
<p>Here are example of a dynamic placeholders 1) a unique identifier: [[uniqid]] 2) a datetime: [[datetime]] and 3) a datetime in UTC: [[utcdatetime]].</p>
<p>You can use <b>substr</b>, here's substr($str,3,10): <i>{{longstring|substr:3:10}}</i>. A long string can be quickly shortened using the shortcut function <b>ellipsis</b>: <i>{{longstring|ellipsis:18}}</i></p>
<p>Variables that end with an exclamation point will be removed if they are not matched - for example, it should be blank between the quotes "{{test!}}". But those unmatched will remain untouched, like {{so}}. </p>
</body>
</html>