view default/blog/articles.html @ 44:580670430fa2

blog/item: expand/reduce improvments: - only expand_box is now clickable, not the whole article anymore, avoiding unwanted click - when in .clicked state, message is "Click to reduce" instead of "expand" - in .clicked state, expand_box is only visible on :hover - in .clicked state, and expand_box is available at top and bottom
author Goffi <goffi@goffi.org>
date Thu, 13 Jul 2017 19:23:02 +0200
parents f8798d691acf
children f19e9f5e43b0
line wrap: on
line source

{% if not embedded %}{% extends 'base/base.html' %}{% endif %}
{% import 'input/comment.html' as comment with context %}

{% macro show_items(items, comments=False) %}
    {# show items and comments items if present after each item,
       then post form if allow_commenting is set #}
    {% for item in items %}
        {% if not comments %}<div class="main_article">{% endif %}
            {% include 'blog/item.html' %}
        {% if not comments %}</div>{% endif %}

        {# we recursively display comments for all comments nodes (usually there's only one) #}
        {% for comments_items in item.comments_items_list %}
            <button class="comments_btn" onclick="clicked_mh_fix('{{comments_panel|next_gidx}}');clicked_cls(this)">
                <span class='show'>{% trans %}show comments{% endtrans %}</span>
                <span class='hide'>{% trans %}hide comments{% endtrans %}</span>
                ({{comments_items|count}})
            </button>
            <div id="{{comments_panel|cur_gidx}}" class="comments_panel">
                {% if allow_commenting %}
                    <div class="comment_post">
                        {{ comment.comment(service=comments_items.service, node=comments_items.node) }}
                    </div>
                {% endif %}

                <div class="comments">
                    {{show_items(comments_items, comments=True)}}
                </div>
            </div>

        {% endfor %}

    {% endfor %}
{% endmacro %}

{% block body %}
<div id="blog_items">
    {{ show_items(items) }}
</div>
{% endblock body %}