Skip to content

Twig: Example Component

Mike Mai edited this page Sep 18, 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 base_class = "c-bolt-example" %}
{% set attributes = create_attribute(attributes|default({})) %}
{% set inner_attributes = create_attribute({}) %}

{# Set up checks to validate that the component's prop values are allowed, based on the component's schema #}
{% set tag_options = schema.properties.tag.enum %}
{% set string_options = schema.properties.string.enum %}

{# Check that the component's current prop values are valid. if not, default to the schema default #}
{% set tag = tag in tag_options ? tag : schema.properties.tag.default %}
{% set string = string in string_options ? string : schema.properties.string.default %}
{% set boolean = boolean is sameas(true) or boolean is sameas(false) ? boolean : schema.properties.boolean.default %}

{# Array of classes based on the defined + default props #}
{% set classes = [
  base_class,
  string in string_options ? "#{base_class}--#{string}" : "",
] %}


{# Example component's custom element wrapper #}
<bolt-example
  {% if tag %} tag="{{ tag }}" {% endif %}
  {% if string %} string="{{ string }}" {% endif %}
  {% if boolean %} boolean {% endif %}
  {{ attributes }}
>
  <{{ tag }} {{ inner_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 base_class = "c-bolt-simple" %}
{% set attributes = create_attribute(attributes|default({})) %}
{% set inner_attributes = create_attribute({}) %}

{# Set up checks to validate that the component's prop values are allowed, based on the component's schema #}
{% set string_options = schema.properties.string.enum %}

{# Check that the component's current prop values are valid. if not, default to the schema default #}
{% set string = string in string_options ? string : schema.properties.string.default %}
{% set boolean = boolean is sameas(true) or boolean is sameas(false) ? boolean : schema.properties.boolean.default %}

{# Array of classes based on the defined + default props #}
{% set classes = [
  base_class,
  string in string_options ? "#{base_class}--#{string}" : "",
] %}

{# Simple component's custom element wrapper #}
<bolt-simple
  {% if string %} string="{{ string }}" {% endif %}
  {% if boolean %} boolean {% endif %}
  {{ attributes }}
>
  <div {{ inner_attributes.addClass(classes) }}>
    <div class="{{ base_class }}__inner">
      {{ content }}
    </div>
  </div>
</bolt-simple>
Clone this wiki locally