Home > Contents > Index > 
Template Tags TOC | Alpha TOC | Tag Family TOC | Purpose TOC | Annotated TOC | Index 
render:calltemplate
Invokes a Template, as either a pagelet or an element, for the purpose of rendering an asset.
Syntax
<render:calltemplate site="site name" slotname="name of slot" tid="caller Template or CSElement id" [ttype="caller Template or CSElement"] [c="asset type"] [cid="asset id"] [tname="target Template or CSElement name"] [context="context override"] [style="pagelet or element"] [variant="template variant name"] [packedargs="packed arguments"]> [<render:argument name="variable1" value="value1"/>] </render:calltemplate>Attributes
- site (required)
- The name of the site containing the Template to be invoked.
- slotname (required)
- This attribute defines an identifier for the "slot" that is being filled with the called template. It should be reasonably easy to understand for humans and should be unique across all templates. Future versions of CS Direct will make extensive use of the
slotnameattribute.- tid (required)
- The id of the template in which this tag is located. If this tag is located in a CSElement, then the value of this attribute should be the id of the CSElement, and
ttypeshould be set toCSElement.- ttype (optional)
- This attribute identifies whether the code that contains this tag is a
Templateor aCSElement. The default value isTemplate, andCSElementis the other legal value. Seetid.- c (optional)
- The asset type to be rendered by the called Template. The value of this attribute will be passed to the called code. If
c,cid, andtnameare set, thencontextdata is ignored.- cid (optional)
- The id of the asset to be rendered by the called Template. The value of this attribute will be passed to the called code. This is required if
cis set.- tname (optional)
- The name of the Template to be called. This is required if
candcidare set. If these three attributes are not set, the called template will be determined by looking atcontextdata.- context (optional)
- This attributes contains a context override parameter. If
c,cid, andtnameare not specified, then this attribute value will be examined to determine which template to call and which asset to render using the specified template. If this value is not specified, then an ICS variable of the same name will be examined for the same purpose. If nocontextvalue can be located, then the slot will be not be populated, and this tag will do nothing. Future versions of CS Direct will provide an interface that allows thecontextdata to be set automatically. Manually overriding this value should be considered an advanced technique.- style (optional)
- Flag that indicates that the called Template should be called as an element or as a pagelet. The default value is
pagelet. Setting this attribute value toelementwill result in the template being called as an element. This is useful if a nested pagelet is not necessary or desireable (i.e. would be overkill) for the target Template. When the style iselement, the scope of the called element is local: only variables specified as arguments and attributes will be accessible to the called element, and variable values in the caller will not be affected. Note that if this is set toelement, then the invoked Template will be embedded in the caller, and this can have performance, dependency, and caching implications, which can be good or bad depending on your code).- variant (optional)
- This attribute specifies the name of the Template variant to render. Template variants enable multiple code implementations of a Template (for example, WEP vs XHTML). Future versions of CS Direct may implement this feature; as of the current release it is not yet supported.
- packedargs (optional)
- This attribute contains a series of arguments (name-value pairs) URL-encoded as a string.
Parameters
- render:argument (optional)
- Nested parameter tag. The render:calltemplate tag allows arbitrary argument tags to be added in order to pass name/value pairs to the called Template or CSElement.
Description
This tag is the preferred method for invoking a template. It effectively replaces
render:satellitepage,render:contentserver, andrender:callelementin most (but certainly not all) cases. It causes a specific asset to be rendered by a specific template. The template can be rendered either as an inline element or as a nested pagelet (seestyle, above).Instances of this tag must contain information about who the caller is in order to operate correctly. The caller must be either another Template or a CSElement. This tag will not operate correctly without valid information about the caller. (see
tid&ttypeabove).
render:calltemplateoperates in two modes: explicit mode and context mode.In explicit mode,
c,cid, andtnameare explicitly specified as attributes to the tag. In essence, the asset identified bycandcidwill be rendered by the template corresponding to the template namedtname. If tname starts with "/" then the typeless template corresponding totnamewill be called. Otherwise, the template corresponding to the specifiedtnameand asset type ("c") will be called. Explicit mode is the only mode that is currently supported.In context mode, the
contextattribute (which defaults to an ICS variable of the same name if not present) will be examined to determine the template and asset to be rendered. Context mode support is not currently enabled in the CS Direct interface, however future versions may include it.errno
The possible values of
errnoinclude:
Example
The following example, taken from the FirstSite Mark II Layout template, calls a template to render the html
headtag. This tag displays the htmltitletag containing the description of the asset being rendered.In this tag, most of the attribute values are set from other variables in the variable space, either because they have been passed in, or because they have been explicitly looked up.
The following table describes the origin of the ICS variables referenced below.
Variable origins Variable name Origin site The sitevariable is set as a resarg in all of the templates and SiteEntry assets. As such, it can be expected to be set correctly to the name of the current site.tid The tidvariable is set in the resargs of the called template. Because this code is in a Template, thetidattribute is set to the value of thetidvariable. If this code had been located in a CSElement, this attribute would have been set to the value of theeidvariable and thettypeattribute would also have been set toCSElement. See above for details.c The cvariable is specified on the URL and is passed unchanged into the Layout template.cid The cidvariable is specified on the URL and is passed unchanged into the Layout template.tname The tnamevariable is set immediately above therender:calltemplatetag in the Layout template. It is set using therender:lookuptag, which effectively looks up the actual value of the template name to be rendered. For reasons relating to template replication, it's not a good idea to hard-code asset names in templates. Therender:lookuptag provides an abstraction around hard-coding attribute values. Out of the box, however, theFSIILayouttemplate sets the name of the head template asFSIIHead, and as such the variabletnameresolves toFSIIHead.p The variable pis specified on the URL and is passed unchanged into the layout template.<render:calltemplate site='<%=ics.GetVar("site")%>' slotname="Head" tid='<%=ics.GetVar("tid")%>' c='<%=ics.GetVar("c")%>' cid='<%=ics.GetVar("cid")%>' tname='<%=ics.GetVar("HeadVar")%>'> <render:argument name="p" value='<%=ics.GetVar("p")%>' /> </render:calltemplate>See Also
Home > Contents > Index > 
FatWire JSP Tag Reference
Copyright 2005,2006,2007 by FatWire Software
All rights reserved.