Skip to content
Snippets Groups Projects
paragraph--columns_three.html.twig 4.41 KiB
{#
/**
 * @file
 * Custom Paragraphs template for displaying a Three Column layout.
 *
 * Available variables:
 * - paragraph: Full paragraph entity.
 *   - id: The paragraph ID.
 *   - bundle: The type of the paragraph, for example, "image" or "text".
 *   - authorid: The user ID of the paragraph author.
 *   - createdtime: Formatted creation date. Preprocess functions can
 *     reformat it by calling format_date() with the desired parameters on
 *     $variables['paragraph']->getCreatedTime().
 * - content: All paragraph items. Use {{ content }} to print them all,
 *   or print a subset such as {{ content.field_example }}. Use
 *   {{ content|without('field_example') }} to temporarily suppress the printing
 *   of a given child element.
 * - attributes: HTML attributes for the containing element.
 *   The attributes.class element may contain one or more of the following
 *   classes:
 *   - paragraphs: The current template type (also known as a "theming hook").
 *   - paragraphs--type-[type]: The current paragraphs type. For example, if the paragraph is an
 *     "Image" it would result in "paragraphs--type--image". Note that the machine
 *     name will often be in a short form of the human readable label.
 *   - paragraphs--view-mode--[view_mode]: The View Mode of the paragraph; for example, a
 *     preview would result in: "paragraphs--view-mode--preview", and
 *     default: "paragraphs--view-mode--default".
 * - view_mode: View mode; for example, "preview" or "full".
 * - logged_in: Flag for authenticated user status. Will be true when the
 *   current user is a logged-in member.
 * - is_admin: Flag for admin user status. Will be true when the current user
 *   is an administrator.
 *
 * @see template_preprocess_paragraph()
 *
 */
#}

{# Setting up variables that determines the width for left, middle and right columns #}
{% if content.field_column_style_3['#items'].getString() == "paragraph--style--33-33-33" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-4', 'col-xs-12 col-md-4', 'col-xs-12 col-md-4' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--25-50-25" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-3', 'col-xs-12 col-md-6', 'col-xs-12 col-md-3' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--50-25-25" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-6', 'col-xs-12 col-md-3', 'col-xs-12 col-md-3' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--25-25-50" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-3', 'col-xs-12 col-md-3', 'col-xs-12 col-md-6' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--16-66-16" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-2', 'col-xs-12 col-md-8', 'col-xs-12 col-md-2' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--66-16-16" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-8', 'col-xs-12 col-md-2', 'col-xs-12 col-md-2' %}

{% elseif content.field_column_style_3['#items'].getString() == "paragraph--style--16-16-66" %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-2', 'col-xs-12 col-md-2', 'col-xs-12 col-md-8' %}

{% else %}

        {% set leftwidth, middlewidth, rightwidth = 'col-xs-12 col-md-4', 'col-xs-12 col-md-4', 'col-xs-12 col-md-4' %}

{% endif %}


{# Setting up variable that determines the background color for section #}
{% set bgcolor = content.field_background_color['#items'].getString() %}

{% if bgcolor == ''%}
  {% set bgcolor = 'transparent-bg' %}
{% endif %}

{# Prints div with classes, and content without Width and Background. #}
<div{{ attributes.addClass(classes) }}>
  <div class="paragraph__column {{ bgcolor }}">

{% if page_content_type == 'landing_page' %}
        <div class="container">
    {% endif %}

{% set thecont = [] %}
  {% for item in content|without('field_column_style_3')|without('field_background_color') %}
    {% set thecont = thecont|merge(item) %}
  {% endfor %}

    <div class="{{ leftwidth }} col-l">
      {{ thecont[0] }}
    </div>

    <div class="{{ middlewidth }} col-m">
      {{ thecont[1] }}
    </div>

    <div class="{{ rightwidth }} col-r">
      {{ thecont[2] }}
    </div>

    {% if page_content_type == 'landing_page' %}
        </div>
    {% endif %}

  </div>
</div>