-
Notifications
You must be signed in to change notification settings - Fork 46
Twig: Example Component
Mike Mai edited this page Aug 15, 2018
·
22 revisions
- Customizable HTML tag in the initially rendered markup
- Allowing the component's inner content to be overwritten via a Twig
{% block block_name %}
or just{{content}}
. In either case, it's important to be agnostic about the details of the inner content. - Consistent formatting
{% set schema = bolt.data.components["@bolt-components-example"].schema %}
{% if enable_json_schema_validation %}
{{ validate_data_schema(schema, _self) | raw }}
{% endif %}
{# Variables #}
{% set baseClass = "c-bolt-example" %}
{% set attributes = create_attribute(attributes|default({})) %}
{# Set up checks to validate that the component's prop values are allowed, based on the component's schema #}
{% set tagOptions = schema.properties.tag.enum %}
{% set propNameOptions = schema.properties.propName.enum %}
{% set sizeOptions = schema.properties.size.enum %}
{# Check that the component's current prop values are valid. if not, default to the schema default #}
{% set tag = tag in tagOptions ? tag : schema.properties.tag.default %}
{% set propName = propName in propNameOptions ? propName : schema.properties.propName.default %}
{% set size = size in sizeOptions ? size : schema.properties.size.default %}
{# Array of classes based on the defined + default props #}
{% set classes = [
baseClass,
size in sizeOptions ? "#{baseClass}--#{size}" : "",
] %}
{# Example component's custom element wrapper #}
<bolt-example
{% if tag %} tag="{{ tag }}" {% endif %}
{% if propName %} propName="{{ propName }}" {% endif %}
{% if size %} size="{{ size }}" {% endif %}
>
<{{ tag }} {{ attributes.addClass(classes) }}>
{% block children %}
{{ content }}
{% endblock %}
</{{ tag }}>
</bolt-example>
Similar to the example above, only this time with deliberately more prescriptive initial HTML (for comparison).
{% set schema = bolt.data.components["@bolt-components-simple"].schema %}
{% if enable_json_schema_validation %}
{{ validate_data_schema(schema, _self) | raw }}
{% endif %}
{# Variables #}
{% set baseClass = "c-bolt-simple" %}
{% set attributes = create_attribute(attributes|default({})) %}
{# Set up checks to validate that the component's prop values are allowed, based on the component's schema #}
{% set propNameOptions = schema.properties.propName.enum %}
{# Check that the component's current prop values are valid. if not, default to the schema default #}
{% set propName = propName in propNameOptions ? propName : schema.properties.propName.default %}
{# Array of classes based on the defined + default props #}
{% set classes = [
baseClass,
propName in propNameOptions ? "#{baseClass}--#{propName}" : "",
] %}
{# Simple component's custom element wrapper #}
<bolt-simple
{% if propName %} propName="{{ propName }}" {% endif %}
>
<div {{ attributes.addClass(classes) }}>
<div class="{{ baseClass }}__inner">
{{ content }}
</div>
</div>
</bolt-simple>
- Basic A11y Checklist
- Get started with Bolt locally
- Bolt Specific Standards and Conventions
- How to save SVG graphics and SVG icons
- Upgrade to minor release
- Upgrade to 4.x
- Upgrade to 5.x
- Release Workflow
- VS Code Configuration
- Bolt Doc Writing Guide
- Prefixing Custom Attributes
- Standard Props for Passing Content in Twig
- Building Websites with Bolt in Drupal
- From Design Mockup to Code
- Override with Utility Classes