
Comparing changes: https://github.com/smarty-php/smarty/compare/v4.3.1...v4.4.1 It is noticeable that Smarty 4.3.1 does not officially support PHP 8.3. Is only supported with 4.4.0. Remark: During tests with Smarty 4.5.1, it was noticed that the following warning occurs: Deprecated: Using the unregistered function "function_exists" in a template is deprecated and will be removed in a future version. Use Smarty::registerPlugin to explicitly register a custom modifier. As of Smarty 5.X.X, templates must be revised again. The Smarty release 5.0.2 is already officially available. However, integration into FlatPress is not entirely trivial.
95 lines
2.5 KiB
Markdown
95 lines
2.5 KiB
Markdown
Template Functions {#plugins.functions}
|
|
==================
|
|
|
|
void
|
|
|
|
smarty\_function\_
|
|
|
|
name
|
|
|
|
array
|
|
|
|
\$params
|
|
|
|
object
|
|
|
|
\$template
|
|
|
|
All [attributes](#language.syntax.attributes) passed to template
|
|
functions from the template are contained in the `$params` as an
|
|
associative array.
|
|
|
|
The output (return value) of the function will be substituted in place
|
|
of the function tag in the template, eg the
|
|
[`{fetch}`](#language.function.fetch) function. Alternatively, the
|
|
function can simply perform some other task without any output, eg the
|
|
[`{assign}`](#language.function.assign) function.
|
|
|
|
If the function needs to assign some variables to the template or use
|
|
some other Smarty-provided functionality, it can use the supplied
|
|
`$template` object to do so eg `$template->foo()`.
|
|
|
|
|
|
<?php
|
|
/*
|
|
* Smarty plugin
|
|
* -------------------------------------------------------------
|
|
* File: function.eightball.php
|
|
* Type: function
|
|
* Name: eightball
|
|
* Purpose: outputs a random magic answer
|
|
* -------------------------------------------------------------
|
|
*/
|
|
function smarty_function_eightball($params, Smarty_Internal_Template $template)
|
|
{
|
|
$answers = array('Yes',
|
|
'No',
|
|
'No way',
|
|
'Outlook not so good',
|
|
'Ask again soon',
|
|
'Maybe in your reality');
|
|
|
|
$result = array_rand($answers);
|
|
return $answers[$result];
|
|
}
|
|
?>
|
|
|
|
which can be used in the template as:
|
|
|
|
Question: Will we ever have time travel?
|
|
Answer: {eightball}.
|
|
|
|
|
|
|
|
<?php
|
|
/*
|
|
* Smarty plugin
|
|
* -------------------------------------------------------------
|
|
* File: function.assign.php
|
|
* Type: function
|
|
* Name: assign
|
|
* Purpose: assign a value to a template variable
|
|
* -------------------------------------------------------------
|
|
*/
|
|
function smarty_function_assign($params, Smarty_Internal_Template $template)
|
|
{
|
|
if (empty($params['var'])) {
|
|
trigger_error("assign: missing 'var' parameter");
|
|
return;
|
|
}
|
|
|
|
if (!in_array('value', array_keys($params))) {
|
|
trigger_error("assign: missing 'value' parameter");
|
|
return;
|
|
}
|
|
|
|
$template->assign($params['var'], $params['value']);
|
|
|
|
}
|
|
?>
|
|
|
|
|
|
|
|
See also: [`registerPlugin()`](#api.register.plugin),
|
|
[`unregisterPlugin()`](#api.unregister.plugin).
|