content_planner-8.x-1.x-dev/modules/content_kanban/templates/content-state-statistic.html.twig

modules/content_kanban/templates/content-state-statistic.html.twig
{%
  set colors = [
    '#ffb2fc',
    '#fca747',
    '#0096d0',
    '#505050',
    '#99529a',
    '#5ebc68',
    '#d3d3d3',
  ]
%}
{# Calculate total #}
{% set total_count = 0 %}
{% for state in data %}
  {% set total_count = total_count + state.count %}
{% endfor %}

{# visual bar #}
<div class="content-states-visual-bar">

  {% set color_index = 1 %}
  {% for state in data %}

    {% set slice_percentage = total_count > 0 ? (state.count / total_count) * 100 : 0 %}

    <div class="content-state-slice" style="background-color: {{ colors[color_index] }}; width: {{ slice_percentage }}%;">&nbsp;</div>
    {% set color_index = color_index + 1 %}
  {% endfor %}
</div>

{# count list #}
<ul class="dashboard-content-status-counts">
  {% set color_index = 1 %}
  {% for state in data %}
    <li class="content-state">
      <span class="color" style="background-color: {{ colors[color_index] }}"></span>
      <span class="label">{{ state.label }} ({{ state.count }})</span>
    </li>
    {% set color_index = color_index + 1 %}
  {% endfor %}
</ul>
<strong>Total: {{ total_count }}</strong>

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc