Collection of building blocks and viewhelpers for TYPO3 projects by tollwerk
<base:heading level="1" type="2" content="First headline on page"/>
The heading view helper aims to replace any hardcoded use of <h1>
, <h2>
, etc. with a dynamic creating of heading levels. It uses these attributes:
Attribute | Type | Mandatory | Description | Default |
---|---|---|---|---|
content |
Text | Yes | The heading text; may contain HTML markup | |
level |
Integer | No | If present and a positive number (1-6), this will be used as the technical heading level. If omitted or zero, the heading level will be determined automatically. Only one <h1> will be generated except when forced with non-zero level value. If a heading level is forcibly skipped, the CSS class Heading--semantic-error will be added to the heading. |
null |
type |
Integer | No | Visual heading type. If omitted or zero, the technical heading level will be used as visual type. The visual heading type will result in one of the type CSS classes. | 1 |
Heading--xx-large
(corresponds to<h1>
)Heading--x-large
(corresponds to<h2>
)Heading--large
(corresponds to<h3>
)Heading--medium
(corresponds to<h4>
)Heading--small
(corresponds to<h5>
)Heading--x-small
(corresponds to<h6>
)
In addition, the heading has the CSS class Heading--hidden
if it shouldn't be rendered visually (see below).
Both the technical heading level
as well as the visual heading type
can be set by editors in the backend:
The extension also introduces two different kind of hidden headings:
- Hidden, but in outline: These headings will be rendered but they'll carry the additional CSS class
Heading--hidden
to indicate that they should be visually hidden. You can use this to keep the heading outline in order without really displaying anything. - Hidden: These headings won't be rendered in the frontend but you will still see their content in the pages view in the TYPO3 backend.
This viewhelper returns the current heading context identifier (empty string if not available). Useful in combination with <base:heading.context.restore>
.
<f:variable name="headingContext" value="{base:heading.context.get()}"/>
Use this viewhelper to establish a new heading context for the following fluid operations.
<base:heading.context.create level="1" type="2"/>
The viewhelper returns the identifier of the previously active heading context. You may want to pass this to the <base:heading.context.restore>
viewhelper (see below).
Use this viewhelper to restore a heading context by identifier:
<f:variable name="previousContext" value="{base:heading.context.create()}"/>
<!-- ... -->
<base:heading.context.restore context="{$previousContext}"/>
Be aware that the root level (empty identifier = no active context) will not be restored by default. If you want to force this, you have to use the root
-Flag:
<base:heading.context.restore context="" root="1"/>
Use this viewhelper for temporarily shifting the heading context levels for nested fluid operations.
<base:heading content="Second-level heading (h2)"/>
<!-- The heading level is now 2 (default standard level) -->
<p>Some content ...</p>
<base:heading.context.shift by="1">
<!-- The heading level is now temporarily shifted to 3-->
<base:heading content="Third level heading (h3)"/>
</base:heading.context.shift>
Returns the current heading level (integer).
Returns the heading level the next heading would be assigned (integer). You may optionally pass a desired heading level which will be used if possible.
The next heading level will be: <base:heading.level.next level="2"/>
Returns the current heading's visual type (integer).