mirror of
https://github.com/peter-tanner/peter-tanner.github.io.git
synced 2024-12-02 21:10:17 +08:00
139 lines
4.8 KiB
HTML
139 lines
4.8 KiB
HTML
---
|
|
layout: page
|
|
# All the Categories of posts
|
|
---
|
|
|
|
{% include lang.html %}
|
|
|
|
{% assign HEAD_PREFIX = 'h_' %}
|
|
{% assign LIST_PREFIX = 'l_' %}
|
|
|
|
{% assign group_index = 0 %}
|
|
|
|
{% assign sort_categories = site.categories | sort %}
|
|
|
|
{% for category in sort_categories %}
|
|
{% assign category_name = category | first %}
|
|
{% assign posts_of_category = category | last %}
|
|
{% assign first_post = posts_of_category | first %}
|
|
|
|
{% if category_name == first_post.categories[0] %}
|
|
{% assign sub_categories = '' | split: '' %}
|
|
|
|
{% for post in posts_of_category %}
|
|
{% assign second_category = post.categories[1] %}
|
|
{% if second_category %}
|
|
{% unless sub_categories contains second_category %}
|
|
{% assign sub_categories = sub_categories | push: second_category %}
|
|
{% endunless %}
|
|
{% endif %}
|
|
{% endfor %}
|
|
|
|
{% assign sub_categories = sub_categories | sort %}
|
|
{% assign sub_categories_size = sub_categories | size %}
|
|
|
|
<div class="card categories">
|
|
<!-- top-category -->
|
|
<div
|
|
id="{{ HEAD_PREFIX }}{{ group_index }}"
|
|
class="card-header d-flex justify-content-between hide-border-bottom"
|
|
>
|
|
<span class="ms-2">
|
|
<i class="far fa-folder{% if sub_categories_size > 0 %}-open{% endif %} fa-fw"></i>
|
|
|
|
{% capture _category_url %}/categories/{{ category_name | slugify | url_encode }}/{% endcapture %}
|
|
<a href="{{ _category_url | relative_url }}" class="mx-2">{{ category_name }}</a>
|
|
|
|
<!-- content count -->
|
|
{% assign top_posts_size = site.categories[category_name] | size %}
|
|
<span class="text-muted small font-weight-light">
|
|
{% if sub_categories_size > 0 %}
|
|
{{ sub_categories_size }}
|
|
{% if sub_categories_size > 1 %}
|
|
{{
|
|
site.data.locales[lang].categories.category_measure.plural
|
|
| default: site.data.locales[lang].categories.category_measure
|
|
}}
|
|
{% else %}
|
|
{{
|
|
site.data.locales[lang].categories.category_measure.singular
|
|
| default: site.data.locales[lang].categories.category_measure
|
|
}}
|
|
{% endif -%}
|
|
,
|
|
{% endif %}
|
|
|
|
{{ top_posts_size }}
|
|
|
|
{% if top_posts_size > 1 %}
|
|
{{
|
|
site.data.locales[lang].categories.post_measure.plural
|
|
| default: site.data.locales[lang].categories.post_measure
|
|
}}
|
|
{% else %}
|
|
{{
|
|
site.data.locales[lang].categories.post_measure.singular
|
|
| default: site.data.locales[lang].categories.post_measure
|
|
}}
|
|
{% endif %}
|
|
</span>
|
|
</span>
|
|
|
|
<!-- arrow -->
|
|
{% if sub_categories_size > 0 %}
|
|
<a
|
|
href="#{{ LIST_PREFIX }}{{ group_index }}"
|
|
data-bs-toggle="collapse"
|
|
aria-expanded="true"
|
|
aria-label="{{ HEAD_PREFIX }}{{ group_index }}-trigger"
|
|
class="category-trigger hide-border-bottom"
|
|
>
|
|
<i class="fas fa-fw fa-angle-down"></i>
|
|
</a>
|
|
{% else %}
|
|
<span data-bs-toggle="collapse" class="category-trigger hide-border-bottom disabled">
|
|
<i class="fas fa-fw fa-angle-right"></i>
|
|
</span>
|
|
{% endif %}
|
|
</div>
|
|
<!-- .card-header -->
|
|
|
|
<!-- Sub-categories -->
|
|
{% if sub_categories_size > 0 %}
|
|
<div id="{{ LIST_PREFIX }}{{ group_index }}" class="collapse show" aria-expanded="true">
|
|
<ul class="list-group">
|
|
{% for sub_category in sub_categories %}
|
|
<li class="list-group-item">
|
|
<i class="far fa-folder fa-fw"></i>
|
|
|
|
{% capture _sub_ctg_url %}/categories/{{ sub_category | slugify | url_encode }}/{% endcapture %}
|
|
<a href="{{ _sub_ctg_url | relative_url }}" class="mx-2">{{ sub_category }}</a>
|
|
|
|
{% assign posts_size = site.categories[sub_category] | size %}
|
|
<span class="text-muted small font-weight-light">
|
|
{{ posts_size }}
|
|
|
|
{% if posts_size > 1 %}
|
|
{{
|
|
site.data.locales[lang].categories.post_measure.plural
|
|
| default: site.data.locales[lang].categories.post_measure
|
|
}}
|
|
{% else %}
|
|
{{
|
|
site.data.locales[lang].categories.post_measure.singular
|
|
| default: site.data.locales[lang].categories.post_measure
|
|
}}
|
|
{% endif %}
|
|
</span>
|
|
</li>
|
|
{% endfor %}
|
|
</ul>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
<!-- .card -->
|
|
|
|
{% assign group_index = group_index | plus: 1 %}
|
|
{% endif %}
|
|
{% endfor %}
|