Skip to content

Twig: Example Component

Mike Mai edited this page Aug 15, 2018 · 22 revisions

Main Benefits

  1. Customizable HTML tag in the initially rendered markup
  2. 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.
  3. Consistent formatting

Code

Example 1: "Example" Component

{% 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>

Example 2: "Simple" Component

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>
Clone this wiki locally