mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Triage of Template Tags rendering syntactically incorrect, per Disqus comment
This commit is contained in:
parent
eda75a2aa9
commit
9b8594af8c
@ -1,6 +1,6 @@
|
||||
# Built-in Page Controls
|
||||
|
||||
|
||||
|
||||
Ever wonder when you use `$Title` and `<% Control Children %>` what else you can call in the templates?. This page is
|
||||
here to help with a guide on what template controls you can call.
|
||||
|
||||
@ -16,19 +16,19 @@ within another page control.
|
||||
|
||||
### Controlling Menus Datafeeds
|
||||
|
||||
#### <% control Menu(1) >%, <% control Menu(2) >%, ...
|
||||
#### <% control Menu(1) %>, <% control Menu(2) %>, ...
|
||||
|
||||
Returns a fixed level menu. Because this only works in the top level, you can't use it for nested menus. Used <%
|
||||
control Children %> instead. You can nest `<% control Children %>`.
|
||||
|
||||
#### <% control ChildrenOf(page-url) >%
|
||||
#### <% control ChildrenOf(page-url) %>
|
||||
|
||||
This will create a datafeed of the children of the given page. Handy if you want a list of the subpages under staff (eg
|
||||
the staff) on the homepage etc
|
||||
|
||||
### Controlling Certain Pages
|
||||
|
||||
#### <% control Level(1) >%, <% control Level(2) >%, $Level(1).Title, $Level(2).Content, etc
|
||||
#### <% control Level(1) %>, <% control Level(2) %>, $Level(1).Title, $Level(2).Content, etc
|
||||
Returns the current section of the site that we're in, at the level specified by the numbers. For example, imagine
|
||||
you're on the page __about us > staff > bob marley__:
|
||||
|
||||
@ -36,7 +36,7 @@ you're on the page __about us > staff > bob marley__:
|
||||
* `<% control Level(2) %>` would return the staff page
|
||||
* `<% control Level(3) %>` would return the bob marley page
|
||||
|
||||
#### <% control Page(my-page) >%$Title<% end_control >%
|
||||
#### <% control Page(my-page) %>$Title<% end_control %>
|
||||
|
||||
"Page" will return a single page from the site tree, looking it up by URL. You can use it in the `<% control %>` format.
|
||||
Can't be called using $Page(my-page).Title.
|
||||
@ -69,32 +69,32 @@ line*. This interface is implemented by the [api:SiteConfig] class.
|
||||
|
||||
### Controlling Parents and Children
|
||||
|
||||
#### <% control Children >%
|
||||
#### <% control Children %>
|
||||
|
||||
This will return the children of the current page as a nested datafeed. Useful for nested navigations such as pop-out
|
||||
menus.
|
||||
|
||||
#### <% control AllChildren >%
|
||||
#### <% control AllChildren %>
|
||||
|
||||
This will show all children of a page even if the option 'show in menus?' is unchecked in the tab panel behaviour.
|
||||
|
||||
#### <% control Parent >% or $Parent.Title, $Parent.Content, etc
|
||||
#### <% control Parent %> or $Parent.Title, $Parent.Content, etc
|
||||
|
||||
This will return the parent page. The $ variable format lets us reference an attribute of the parent page directly.
|
||||
|
||||
### Site Navigation - Breadcrumbs
|
||||
|
||||
#### <% control Breadcrumbs >%
|
||||
#### <% control Breadcrumbs %>
|
||||
|
||||
This will return a breadcrumbs widgets for the given page. You can call this on any data-object, so, for example, you
|
||||
could display the breadcrumbs of every search result if you wanted. It has a few options.
|
||||
|
||||
#### <% control Breadcrumbs(3) >%
|
||||
#### <% control Breadcrumbs(3) %>
|
||||
|
||||
Will return a maximum of 3 pages in the breadcrumb list, this can be handy if you're wanting to put breadcrumbs in a
|
||||
place without spilling
|
||||
|
||||
#### <% control Breadcrumbs(3, true) >%
|
||||
#### <% control Breadcrumbs(3, true) %>
|
||||
|
||||
Will return the same, but without any links. This is handy if you're wanting to put the breadcrumb list into another
|
||||
link tag.
|
||||
@ -126,7 +126,7 @@ When viewed on the Home page it will render like this
|
||||
$LinkOrCurrent ignores the section status, returning link instead. $LinkOrSection ingores the current status, returning
|
||||
section instead. Both of these options can simplify your CSS when you only have 2 different cases to consider.
|
||||
|
||||
#### <% if LinkOrCurrent = current >%
|
||||
#### <% if LinkOrCurrent = current %>
|
||||
|
||||
This is an alternative way to set up your menus - if you want different HTML for the current menu item, you can do
|
||||
something like this:
|
||||
@ -139,12 +139,12 @@ something like this:
|
||||
<% end_if %>
|
||||
|
||||
|
||||
#### <% if LinkOrSection = section >%
|
||||
#### <% if LinkOrSection = section %>
|
||||
|
||||
Will return true if you are on the current page OR a child page of the page. Useful for menus which you only want to
|
||||
show a second level menu when you are on that page or a child of it
|
||||
|
||||
#### <% if InSection(page-url) >%
|
||||
#### <% if InSection(page-url) %>
|
||||
|
||||
This if block will pass if we're currently on the page-url page or one of its children.
|
||||
|
||||
@ -191,10 +191,10 @@ override `<% base_tag %>` with a specific piece of HTML, you can do something li
|
||||
|
||||
### Controlling Members and Visitors Data
|
||||
|
||||
#### <% control CurrentMember >%, <% if CurrentMember >% or $CurrentMember.FirstName
|
||||
#### <% control CurrentMember %>, <% if CurrentMember %> or $CurrentMember.FirstName
|
||||
|
||||
CurrentMember returns the currently logged in member, if there is one. All of their details or any special Member page
|
||||
controls can be called on this. Alternately, you can use `<% if CurrentMember %>` to detect whether someone has logged
|
||||
controls can be called on this. Alternately, you can use `<% if CurrentMember %>` to detect whether someone has logged
|
||||
in. To Display a welcome message you can do
|
||||
|
||||
:::ss
|
||||
@ -208,8 +208,8 @@ If the user is logged in this will print out
|
||||
:::ss
|
||||
Welcome Back, Admin
|
||||
|
||||
|
||||
#### <% if PastMember >%, <% if PastVisitor >%
|
||||
|
||||
#### <% if PastMember %>, <% if PastVisitor %>
|
||||
|
||||
These controls detect the visitor's previous experience with the site:
|
||||
|
||||
@ -221,7 +221,7 @@ These controls detect the visitor's previous experience with the site:
|
||||
#### $Now.Nice, $Now.Year
|
||||
|
||||
$Now returns the current date. You can call any of the methods from the `[api:Date]` class on
|
||||
it.
|
||||
it.
|
||||
|
||||
#### $Created.Nice, $Created.Ago
|
||||
|
||||
@ -237,11 +237,11 @@ call any of methods of the `[api:Date]` class on it.
|
||||
|
||||
If you are using a DataObjectSet you have a wide range of methods you can call on it from the templates
|
||||
|
||||
#### <% if Even >%, <% if Odd >%, $EvenOdd
|
||||
#### <% if Even %>, <% if Odd %>, $EvenOdd
|
||||
|
||||
These controls can be used to do zebra-striping. $EvenOdd will return 'even' or 'odd' as appropriate.
|
||||
|
||||
#### <% if First >%, <% if Last >%, <% if Middle >%, $FirstLast
|
||||
#### <% if First %>, <% if Last %>, <% if Middle %>, $FirstLast
|
||||
|
||||
These controls can be used to set up special behaviour for the first and last records of a datafeed. `<% if Middle %>` is
|
||||
set when neither first not last are set. $FirstLast will be 'first', 'last', or ''
|
||||
@ -270,14 +270,14 @@ that aren't accessible within `<% control SearchResults %>`. These can be used
|
||||
|
||||
### Search Results
|
||||
|
||||
#### <% if SearchResults.MoreThanOnePage >%
|
||||
#### <% if SearchResults.MoreThanOnePage %>
|
||||
|
||||
Returns true when we have a multi-page datafeed, restricted with a limit.
|
||||
|
||||
#### $SearchResults.NextLink, $SearchResults.PrevLink
|
||||
|
||||
This returns links to the next and previous page in a multi-page datafeed. They will return blank if there's no
|
||||
appropriate page to go to, so $PrevLink will return blank when you're on the first page. You can therefore use <% if
|
||||
appropriate page to go to, so $PrevLink will return blank when you're on the first page. You can therefore use <% if
|
||||
PrevLink %> to keep your template tidy.
|
||||
|
||||
#### $SearchResults.CurrentPage, $SearchResults.TotalPages
|
||||
@ -288,11 +288,11 @@ CurrentPage returns the number of the page you're currently on, and TotalPages r
|
||||
|
||||
This returns the total number of items across all pages.
|
||||
|
||||
#### <% control SearchResults.First >%, <% control SearchResults.Last >%
|
||||
#### <% control SearchResults.First %>, <% control SearchResults.Last %>
|
||||
|
||||
These controls return the first and last item on the current page of the datafeed.
|
||||
|
||||
#### <% control SearchResults.Pages >%
|
||||
#### <% control SearchResults.Pages %>
|
||||
|
||||
This will return another datafeed, listing all of the pages in this datafeed. It will have the following data
|
||||
available:
|
||||
|
Loading…
Reference in New Issue
Block a user