1Template::Plugin::CycleU(s3e)r Contributed Perl DocumentaTteimopnlate::Plugin::Cycle(3)
2
3
4

NAME

6       Template::Plugin::Cycle - Cyclically insert into a Template from a
7       sequence of values
8

SYNOPSIS

10         [% USE cycle('row', 'altrow') %]
11
12         <table border="1">
13           <tr class="[% class %]">
14             <td>First row</td>
15           </tr>
16           <tr class="[% class %]">
17             <td>Second row</td>
18           </tr>
19           <tr class="[% class %]">
20             <td>Third row</td>
21           </tr>
22         </table>
23
24
25
26
27
28         ###################################################################
29         # Alternatively, you might want to make it available to all templates
30         # throughout an entire application.
31
32         use Template::Plugin::Cycle;
33
34         # Create a Cycle object and set some values
35         my $Cycle = Template::Plugin::Cycle->new;
36         $Cycle->init('normalrow', 'alternaterow');
37
38         # Bind the Cycle object into the Template
39         $Template->process( 'tablepage.html', class => $Cycle );
40
41
42
43
44
45         #######################################################
46         # Later that night in a Template
47
48         <table border="1">
49           <tr class="[% class %]">
50             <td>First row</td>
51           </tr>
52           <tr class="[% class %]">
53             <td>Second row</td>
54           </tr>
55           <tr class="[% class %]">
56             <td>Third row</td>
57           </tr>
58         </table>
59
60         [% class.reset %]
61         <table border="1">
62           <tr class="[% class %]">
63             <td>Another first row</td>
64           </tr>
65         </table>
66
67
68
69
70
71         #######################################################
72         # Which of course produces
73
74         <table border="1">
75           <tr class="normalrow">
76             <td>First row</td>
77           </tr>
78           <tr class="alternaterow">
79             <td>Second row</td>
80           </tr>
81           <tr class="normalrow">
82             <td>Third row</td>
83           </tr>
84         </table>
85
86         <table border="1">
87           <tr class="normalrow">
88             <td>Another first row</td>
89           </tr>
90         </table>
91

DESCRIPTION

93       Sometimes, apparently almost exclusively when doing alternating table
94       row backgrounds, you need to print an alternating, cycling, set of
95       values into a template.
96
97       Template::Plugin::Cycle is a small, simple, and hopefully DWIM solution
98       to these sorts of tasks.
99
100       It can be used either as a normal Template::Plugin, or can be created
101       directly and passed in as a template argument, so that you can set up
102       situations where it is implicitly available in every page.
103

METHODS

105   new [ $Context ] [, @list ]
106       The "new" constructor creates and returns a new
107       "Template::Plugin::Cycle" object. It can be optionally passed an
108       initial set of values to cycle through.
109
110       When called from within a Template, the new constructor will be passed
111       the current Template::Context as the first argument. This will be
112       ignored.
113
114       By doing this, you can use it both directly, AND from inside a
115       Template.
116
117   init @list
118       If you need to set the values for a new empty object, of change the
119       values to cycle through for an existing object, they can be passed to
120       the "init" method.
121
122       The method always returns the '' null string, to avoid inserting
123       anything into the template.
124
125   elements
126       The "elements" method returns the number of items currently set for the
127       "Template::Plugin::Cycle" object.
128
129   list
130       The "list" method returns the current list of values for the
131       "Template::Plugin::Cycle" object.
132
133       This is also the prefered method for getting access to a value at a
134       particular position within the list of items being cycled to.
135
136         [%# Access a variety of things from the list %]
137         The first item in the Cycle object is [% cycle.list.first %].
138         The second item in the Cycle object is [% cycle.list.[1] %].
139         The last item in the Cycle object is [% cycle.list.last %].
140
141   next
142       The "next" method returns the next value from the Cycle. If the end of
143       the list of valuese is reached, it will "cycle" back the first object
144       again.
145
146       This method is also the one called when the object is stringified. That
147       is, when it appears on its own in a template. Thus, you can do
148       something like the following.
149
150         <!-- An example of alternate row classes in a table-->
151         <table border="1">
152           <!-- Explicitly access the next class in the cycle -->
153           <tr class="[% rowclass.next %]">
154             <td>First row</td>
155           </tr>
156           <!-- This has the same effect -->
157           <tr class="[% rowclass %]">
158             <td>Second row</td>
159           </tr>
160         </table>
161
162   value
163       The "value" method is an analogy for the "next" method.
164
165   reset
166       If a single "Template::Plugin::Cycle" object is to be used it multiple
167       places within a template, and it is important that the same value be
168       first every time, then the "reset" method can be used.
169
170       The "reset" method resets the Cycle, so that the next value returned
171       will be the first value in the Cycle object.
172

SUPPORT

174       Bugs should be submitted via the CPAN bug tracker, located at
175
176       <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Template-Plugin-Cycle>
177
178       For other issues, or commercial enhancement or support, contact the
179       author..
180

AUTHOR

182       Adam Kennedy <adamk@cpan.org>
183
184       Thank you to Phase N Australia (<http://phase-n.com/>) for permitting
185       the open sourcing and release of this distribution as a spin-off from a
186       commercial project.
187
189       Copyright 2004 - 2008 Adam Kennedy.
190
191       This program is free software; you can redistribute it and/or modify it
192       under the same terms as Perl itself.
193
194       The full text of the license can be found in the LICENSE file included
195       with this module.
196
197
198
199perl v5.34.0                      2021-07-23        Template::Plugin::Cycle(3)
Impressum