You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
101 lines
3.9 KiB
Twig
101 lines
3.9 KiB
Twig
{% extends 'layouts/app.twig' %}
|
|
{% import 'macros/base.twig' as m %}
|
|
|
|
{% set only_meetings = only_meetings|default(false) %}
|
|
{% block title %}{{ not only_meetings ? __('news.title') : __('news.title.meetings') }}{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="container">
|
|
<h1>
|
|
{{ block('title') }}
|
|
{%- if has_permission_to('admin_news') and is_overview|default(false) -%}
|
|
{{ m.button(m.icon('plus-lg'), url('admin/news', only_meetings ? {'meeting': 1} : {}), 'secondary') }}
|
|
{%- endif %}
|
|
</h1>
|
|
|
|
{% include 'layouts/parts/messages.twig' %}
|
|
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
{% block news %}
|
|
{% for news in news %}
|
|
{{ _self.news(news, true, is_overview) }}
|
|
{% endfor %}
|
|
{% endblock %}
|
|
</div>
|
|
|
|
{% block comments %}
|
|
{% endblock %}
|
|
|
|
{% block pagination %}
|
|
{% if pages|default(0) > 1 %}
|
|
<div class="col-md-12 text-center">
|
|
<ul class="pagination">
|
|
{% for p in range(1, pages) %}
|
|
<li{% if p == page %} class="active"{% endif %}>
|
|
<a href="{{ url('news', p == 1 ? {} : {'page': p}) }}">{{ p }}</a>
|
|
</li>
|
|
{% endfor %}
|
|
</ul>
|
|
</div>
|
|
{% endif %}
|
|
{% endblock %}
|
|
|
|
{% block write_comment %}
|
|
{% endblock %}
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% macro news(news, show_comments_link, is_overview) %}
|
|
<div class="card {% if news.is_meeting %}bg-info{% else %}{% if theme.type =='light' %}bg-light{% else %}bg-dark{% endif %}{% endif %} mb-4">
|
|
{% if is_overview|default(false) %}
|
|
<div class="card-header {% if news.is_meeting and theme.type == 'dark' %}text-white{% endif %}">
|
|
<a href="{{ url('news/' ~ news.id) }}" class="text-inherit">
|
|
{% if news.is_pinned %}{{ m.icon('pin-angle') }}{% endif %}
|
|
{% if news.is_meeting %}{{ __('news.is_meeting') }}{% endif %}
|
|
{{ news.title }}
|
|
</a>
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="card-body bg-body">
|
|
{{ news.text|raw|markdown(false) }}
|
|
</div>
|
|
|
|
<div class="card-footer {% if theme.type =='light' %}bg-light{% else %}bg-dark{% endif %} text-muted">
|
|
{% if news.updated_at != news.created_at and not is_overview %}
|
|
<div class="d-flex align-items-center">
|
|
<div class="me-3">
|
|
{{ m.icon('clock') }} {{ news.created_at.format(__('Y-m-d H:i')) }}
|
|
</div>
|
|
{{ __('news.updated') }}
|
|
</div>
|
|
{% endif %}
|
|
<div class="d-flex align-items-center">
|
|
<div class="me-3">
|
|
{{ m.icon('clock') }} {{ news.updated_at.format(__('Y-m-d H:i')) }}
|
|
</div>
|
|
|
|
<div class="me-3">
|
|
{{ m.user(news.user) }}
|
|
</div>
|
|
|
|
{% if show_comments_link|default(false) %}
|
|
<a href="{{ url('news/' ~ news.id) }}" class="me-1">
|
|
{{ m.icon('chat-left-text') }} {{ __('news.comments') }}
|
|
</a>
|
|
<span class="badge bg-primary">{{ news.comments.count() }}</span>
|
|
{{ m.icon('chevron-double-right', 'primary') }}
|
|
{% endif %}
|
|
|
|
{% if has_permission_to('admin_news') %}
|
|
<div class="ms-auto">
|
|
{{ m.button(m.icon('pencil-square'), url('admin/news/' ~ news.id), 'secondary', 'sm') }}
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endmacro %}
|