[Github 블로그] minimal-mistake 블로그 카테고리 만들기 (+ 전체 글 수)

Date:     Updated:

Categories:

Tags:

🚀 서론

minimal-mistake 테마에서 위와 같은 UI 로 카테고리를 나열하는 방법에 대해 써보고자 한다.

들어가기에 앞서 https://ansohxxn.github.io/blog/jekyll-directory-structure/ minimal-mistake 의 디렉터리 구조에 대해 포스팅 한적이 있으니 이 포스트를 참고하면 도움이 될 것이다.

🔥 구조

  • 같은 카테고리의 글들을 모아둔 페이지
  • 이 페이지들을 모아둔 사이드바


1️⃣ 포스팅시 카테고리 등록

  • 포스트를 쓸 땐 머릿말에 아래와 같은 카테고리를 기록해야 한다. 예를 들어 나는 C++ 프로그래밍에 관한 포스트를 올릴 땐 Cpp 이라는 이름의 카테고리로 분류되도록 부여하였다.
categories:
  - Cpp

그러면 이렇게 글을 올릴 때 해당 글에 카테고리가 Cpp로 부여된 것을 확인할 수 있다.


2️⃣ 같은 카테고리만 모아두는 페이지

📜category-cpp.md

---
title: "C++ 프로그래밍"
layout: archive
permalink: categories/cpp
author_profile: true
sidebar_main: true
---


{% assign posts = site.categories.Cpp %}
{% for post in posts %} {% include archive-single.html type=page.entries_layout %} {% endfor %}

Cpp 라는 카테고리를 가진 포스트들만 모아서 한번에 보여줄 수 있는 위 사진같은 페이지를 만든다. minimal-mistake 에는 기본적으로 📂pages 폴더가 있는데, 나 같은 경우에는 여기 안에 📂categories 라는 폴더를 새로 만들었고 이 안에 📜category-cpp.md, 📜category-csharp.md.. 등등 이런 카테고리들만 가진 포스트들을 나열하여 보여 줄 수 있는 마크다운 파일을 만들어 정리해둔 상태이다.

머릿말을 설정해야 하는데 나의 C++ 글들을 모아둔 카테고리 페이지를 예로 설명해보겠다.

  • 이 페이지의 이름은 “C++ 프로그래밍” 가 된다.
  • 이 페이지의 layout은 archive 방식이다.
    • minimal-mistake 사용자라면 기본적으로 제공하는 카테고리, 태그 레이아웃 페이지를 알고 있을 것이다. 그 레이아웃 방식이 바로 archive 이다. 같은 카테고리의 글들을 나열하는 아카이브로 쓸 것이기 때문에 이와 같은 레이아웃을 설정한 것이다.
  • 이 페이지의 링크는 “categories/cpp”가 된다.
  • 이 페이지에서 author_profile 가 보이게 할 것인지에 대한 것이다. 당신의 프로필!
  • sidebar_main 는 내가 정한 변수값이다. 밑에서 후술!

{% assign posts = site.categories.Cpp %}
{% for post in posts %} {% include archive-single.html type=page.entries_layout %} {% endfor %}

minimal-mistake 는 📜archive-single.html 에서 같은 카테고리, 태그를 모아두는 역할을 하고 있다. 사실 나는 외적인 모습에 조금 변화를 주기 위해 📜archive-single2.html 파일을 따로 만들어 개인적으로 다르게 코딩을 하긴 했지만, 일반 minimal-mistake 를 그대로 사용하시는 분이라면 📜archive-single.html 를 for문 안에서 인클루딩 하면 된다.

image

이렇게 각각 카테고리를 대표하는 문서들을 만들면 된다.

주의 사항이 있다면, 카테고리명에 띄어쓰기가 들어가는 경우에는 site.categories.Unreal Engine 으로 할 수가 없어 site.categories[‘Unreal Engine’] 이런 식으로 해야했다는 것이다. 나도 왜인지는 모르겠다. 띄어 쓰기 들어간 카테고리를 어떤 방법으로 해야하나 방법이 없는 것인가 하고 이리저리 해보다가 우연히 됐다.. 😅 (+ 수정 : 올바르게 알려주신 @punsoo 님 감사드립니다. :)


🔥 제 블로그와 같은 모습으로 나열하고 싶은 분들 참고

image

나는 제목, 날짜, 카테고리, 태그가 위와 같이 한 줄로 붙은 상태로 나열하고 싶어 코드 파일을 따로 만들어 사용하고 있다. 혹시 제 방식과 비슷하게 나열하고 싶으신 분들은 아래 코드를 참고해주세요.

📜archive-single2.html (새로 만들기)


{% if post.header.teaser %}
  {% capture teaser %}{{ post.header.teaser }}{% endcapture %}
{% else %}
  {% assign teaser = site.teaser %}
{% endif %}

{% if post.id %}
  {% assign title = post.title | markdownify | remove: "<p>" | remove: "</p>" %}
{% else %}
  {% assign title = post.title %}
{% endif %}

<div class="{{ include.type | default: "list" }}__item">
    <article class="archive-item">
        <div>
            <span>
              <a href="{{ post.url }}">{{post.title}}</a>
            </span>
            <small> 
              <i class="fas fa-fw fa-calendar-alt" aria-hidden="true"> </i>{{ post.date | date: " %Y.%m.%d" }}
              {% if site.category_archive.type and post.categories[0] and site.tag_archive.type and post.tags[0] %}
                {%- include post__taxonomy.html -%}
              {% endif %}
            </small>
        </div>
      </article>
</div>

📜post__taxonomy.html (새로 만들기. 이름 언더바 두 개입니다!!!)


<!--Archive page 용-: (post -> page)-->
<!--page__taxonomy.html에서 가져 옴-->

{%- if site.category_archive.type and post.categories[0] -%}
    {%- case site.category_archive.type -%}
        {%- when "liquid" -%}
        {%- assign path_type = "#" -%}
        {%- when "jekyll-archives" -%}
        {%- assign path_type = nil -%}
    {%- endcase -%}

    {% case site.tag_archive.type %}
        {% when "liquid" %}
            {% assign path_type = "#" %}
        {% when "jekyll-archives" %}
            {% assign path_type = nil %}
    {% endcase %}

    {%- if site.category_archive.path and site.tag_archive.path -%}
        {%- capture post_categories -%}{%- for category in post.categories -%}{{ category | downcase }}|{{ category }}{%- unless forloop.last -%},{%- endunless -%}{%- endfor -%}{%- endcapture -%}
        {%- assign category_hashes = post_categories | split: ',' | sort -%}
        {% capture post_tags %}{% for tag in post.tags %}{{ tag | downcase }}|{{ tag }}{% unless forloop.last %},{% endunless %}{% endfor %}{% endcapture %}
        {% assign tag_hashes = post_tags | split: ',' | sort %}
        <span class="page__taxonomy">
            <span itemprop="keywords">
                {%- for hash in category_hashes -%}
                    {%- assign keyValue = hash | split: '|' -%}
                    {%- capture category_word -%}{{ keyValue[1] | strip_newlines }}{%- endcapture -%}
                    <a href="{{ category_word | slugify | prepend: path_type | prepend: site.category_archive.path | relative_url }}" class="page__taxonomy-item-category" rel="tag">{{ category_word }}</a>{%- unless forloop.last -%}<span class="sep"> </span>{%- endunless -%}
                {%- endfor -%}
                {% for hash in tag_hashes %}
                    {% assign keyValue = hash | split: '|' %}
                    {% capture tag_word %}{{ keyValue[1] | strip_newlines }}{% endcapture %}
                    <a href="{{ tag_word | slugify | prepend: path_type | prepend: site.tag_archive.path | relative_url }}" class="page__taxonomy-item-tag" rel="tag">{{ tag_word }}</a>{% unless forloop.last %}<span class="sep"> </span>{% endunless %}
                {% endfor %}
            </span>
        </span>
    {%- endif -%}
{%- endif -%}

📜카테고리 페이지


{% assign posts = site.categories.Cpp %}
{% for post in posts %} {% include archive-single2.html type=page.entries_layout %} {% endfor %}

제 카테고리 목록과 같은 모습으로 적용하기 위해 📜archive-single2.html 를 적용하실 분이라면 include archive-single2.html 이렇게 해주셔야 함에 주의해주세요!!


3️⃣ 위 페이지들을 모아 사이드바로 띄우자.

이 곳에 “2️⃣ 같은 카테고리만 모아두는 페이지” 들을 모두 나열할 것

  • minimal-mistake의 📂_include 폴더에 📜nav_list_main 문서를 만든다. 주의할점은 이 파일은 마크다운 파일도, HTML 파일도 아니다. 나는 이름을 nav_list_main 로 했지만 이름을 마음대로 지정해도 상관 없다.
    • 📂_include 폴더에 만든 이유는 사이드바를 담당하는 📜sidebar.html에서 이를 “포함”시켜 화면에 나타내기 위해서다. 즉, 📜sidebar.html 안에서 이 코드를 짜도 되지만 그러면 📜sidebar.html 코드가 너무 복잡하고 길어지기 때문에 이렇게 따로 파일을 빼서 만들었다.
<!--전체 글 수를 세기 위한 연산. sum 변수에 전체 글 수 저장-->

{% assign sum = site.posts | size %}

<nav class="nav__list">
  <input id="ac-toc" name="accordion-toc" type="checkbox" />
  <label for="ac-toc">{{ site.data.ui-text[site.locale].menu_label }}</label>
  <ul class="nav__items" id="category_tag_menu">
      <!--전체 글 수-->
      <li>
            📂 <span style="font-family:'Cafe24Oneprettynight';">전체 글 수</style> <span style="font-family:'Coming Soon';">{{sum}}</style> <span style="font-family:'Cafe24Oneprettynight';"></style> 
      </li>
      <li>
        <!--span 태그로 카테고리들을 크게 분류 ex) C/C++/C#-->
        <span class="nav__sub-title">C/C++/C#</span>
            <!--ul 태그로 같은 카테고리들 모아둔 페이지들 나열-->
            <ul>
                <!--Cpp 카테고리 글들을 모아둔 페이지인 /categories/cpp 주소의 글로 링크 연결-->
                <!--category[1].size 로 해당 카테고리를 가진 글의 개수 표시--> 
                {% for category in site.categories %}
                    {% if category[0] == "Cpp" %}
                        <li><a href="/categories/cpp" class="">C ++ ({{category[1].size}})</a></li>
                    {% endif %}
                {% endfor %}
            </ul>
            <ul>
                {% for category in site.categories %}
                    {% if category[0] == "STL" %}
                        <li><a href="/categories/stl" class="">C++ STL & 표준 ({{category[1].size}})</a></li>
                    {% endif %}
                {% endfor %}
            </ul>
        <span class="nav__sub-title">Coding Test</span>
            <ul>
                {% for category in site.categories %}
                    {% if category[0] == "Algorithm" %}
                        <li><a href="/categories/algorithm" class="">알고리즘 구현 (with C++) ({{category[1].size}})</a></li>
                    {% endif %}
                {% endfor %}
            </ul>
            <ul>
                {% for category in site.categories %}
                    {% if category[0] == "Programmers" %}
                        <li><a href="/categories/programmers" class="">프로그래머스 ({{category[1].size}})</a></li>
                    {% endif %}
                {% endfor %}
            </ul>
      </li>
  </ul>
</nav>

  • <ul class = "nav__items">
    • 이 태그 안에 카테고리들을 모아둔 페이지들 링크를 나열하게 될 것이다. (위에서 페이지마다 설정했던 permalink)
    • CSS 에서 “nav__items” 영역을 꾸미도록 하면 된다.
  • <li> 태그로 영역을 나눈다.
    • 나같은 경우엔 3 개의 영역으로 나누었다.
      • 전체 글 수
      • 카테고리 사이드바
      • 방문자수
  • <span class="nav__sub-title"> 태그로 카테고리들을 분류하는 큰 제목을 표시했다.
    • CSS 에서 “nav__sub-title” 영역을 폰트, 색상 등등을 꾸미도록 하면 된다.
  • <ul>
    • ul 태그 하나하나로 텍스트에다가 2️⃣에서 만들었던 같은 카테고리의 글들을 나열해 모아두었던 그 페이지로 가는 링크를 건다. 설정해뒀었던 permalink 로!
      • {{category[1].size}} 로 해당 카테고리를 가진 글의 개수를 표시할 수도 있다.
                    
              <ul>
                        
                  {% for category in site.categories %}
                      {% if category[0] == "STL" %}
                          <li><a href="/categories/stl" class="">C++ STL & 표준 ({{category[1].size}})</a></li>
                      {% endif %}
                  {% endfor %}
              </ul>
                    
        


전체 글 수


{% assign sum = site.posts | size %}

      <li>
            📂 <span style="font-family:'Cafe24Oneprettynight';">전체 글 수</style> <span style="font-family:'Coming Soon';">{{sum}}</style> <span style="font-family:'Cafe24Oneprettynight';"></style> 
      </li>

site.posts | size로 전체 포스트 수를 구할 수 있다. 이를 sum 변수에 저장한다. 그리고 “전체 글 수”, “개” 텍스트 사이에 {{sum}}을 넣어주면 끝! 폰트가 저리 지저분한 이유는 내가 “전체 글 수”, “개” 텍스트에만 다른 폰트를 지정했기 때문이다. 그냥 CSS 에서 안하고 여기서 바로 해줌..


📜sidebar.html


{% if page.author_profile or layout.author_profile or page.sidebar %}
  <div class="sidebar sticky">
  {% if page.author_profile or layout.author_profile %}{% include author-profile.html %}{% endif %}
  {% if page.sidebar %}
    {% for s in page.sidebar %}
      {% if s.image %}
        <img src="{{ s.image | relative_url }}"
             alt="{% if s.image_alt %}{{ s.image_alt }}{% endif %}">
      {% endif %}
      {% if s.title %}<h3>{{ s.title }}</h3>{% endif %}
      {% if s.text %}{{ s.text | markdownify }}{% endif %}
      {% if s.nav %}{% include nav_list nav=s.nav %}{% endif %}
    {% endfor %}
    {% if page.sidebar.nav %}
      {% include nav_list nav=page.sidebar.nav %}
    {% endif %}
  {% endif %}

  {% if page.sidebar_main %}
    {% include nav_list_main %}
  {% endif %}

  </div>
{% endif %}

minimal-mistake 에서 제공하는 사이드바에 관한 html 문서이다. 이 곳에

  
  {% if page.sidebar_main %}
    {% include nav_list_main %}
  {% endif %}
  

코드를 넣는다. 위에서 작성한 📜nav_list_main 을 사이드바에 반영하는 것이다. sidebar_main 값이 True 라면 이 사이드 바를 활성화시키도록 할 것이다. (그래서 위에서 sidebar_main : true 가 등장했던 것이다!)


📜_config.yml

# Defaults
defaults:
  # _posts
  - scope:
      path: ""
      type: posts
    values:
      layout: single
      author_profile: true
      read_time: true
      comments: true
      share: true
      related: true
      mathjax: true
      sidebar_main: true

📜_config.yml 에 sidebar_main: true를 추가하여 블로그 전체 페이지에서 위에서 만든 사이드바가 활성화되게끔 해주면 끝!

📜index.html

layout: home
sidebar_main: true    # 요거 추가
author_profile: true

혹시 메인 페이지에 사이드바가 반영이 안된다면 메인 페이지를 담당하는 📜index.html 의 머릿말에 sidebar_main: true 를 추가해주면 된다. 참고로 📜index.html 는 📜_config.yml 가 있는 가장 상위 폴더에 있다.



🌜 개인 공부 기록용 블로그입니다. 오류나 틀린 부분이 있을 경우 
언제든지 댓글 혹은 메일로 지적해주시면 감사하겠습니다! 😄

맨 위로 이동하기

Blog 카테고리 내 다른 글 보러가기

Leave a comment