aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/smarty/smarty/docs/programmers/plugins/plugins-block-functions.md
blob: 47281fef503f181cac30933192b9d293a80fb993 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
Block Functions {#plugins.block.functions}
===============

void

smarty\_block\_

name

array

\$params

mixed

\$content

object

\$template

boolean

&\$repeat

Block functions are functions of the form: `{func} .. {/func}`. In other
words, they enclose a template block and operate on the contents of this
block. Block functions take precedence over [custom
functions](#language.custom.functions) of the same name, that is, you
cannot have both custom function `{func}` and block function
`{func}..{/func}`.

-   By default your function implementation is called twice by Smarty:
    once for the opening tag, and once for the closing tag. (See
    `$repeat` below on how to change this.)

-   Starting with Smarty 3.1 the returned value of the opening tag call
    is displayed as well.

-   Only the opening tag of the block function may have
    [attributes](#language.syntax.attributes). All attributes passed to
    template functions from the template are contained in the `$params`
    variable as an associative array. The opening tag attributes are
    also accessible to your function when processing the closing tag.

-   The value of the `$content` variable depends on whether your
    function is called for the opening or closing tag. In case of the
    opening tag, it will be NULL, and in case of the closing tag it will
    be the contents of the template block. Note that the template block
    will have already been processed by Smarty, so all you will receive
    is the template output, not the template source.

-   The parameter `$repeat` is passed by reference to the function
    implementation and provides a possibility for it to control how many
    times the block is displayed. By default `$repeat` is TRUE at the
    first call of the block-function (the opening tag) and FALSE on all
    subsequent calls to the block function (the block\'s closing tag).
    Each time the function implementation returns with `$repeat` being
    TRUE, the contents between `{func}...{/func}` are evaluated and the
    function implementation is called again with the new block contents
    in the parameter `$content`.

If you have nested block functions, it\'s possible to find out what the
parent block function is by accessing `$smarty->_tag_stack` variable.
Just do a [`var_dump()`](&url.php-manual;var_dump) on it and the
structure should be apparent.


    <?php
    /*
     * Smarty plugin
     * -------------------------------------------------------------
     * File:     block.translate.php
     * Type:     block
     * Name:     translate
     * Purpose:  translate a block of text
     * -------------------------------------------------------------
     */
    function smarty_block_translate($params, $content, Smarty_Internal_Template $template, &$repeat)
    {
        // only output on the closing tag
        if(!$repeat){
            if (isset($content)) {
                $lang = $params['lang'];
                // do some intelligent translation thing here with $content
                return $translation;
            }
        }
    }
    ?>

         

See also: [`registerPlugin()`](#api.register.plugin),
[`unregisterPlugin()`](#api.unregister.plugin).