Today I Learned …

[Tistory] 티스토리에 깃허브처럼 잔디 깔기! | 블로그에 잔디 까는 방법 본문

Computer/취미

[Tistory] 티스토리에 깃허브처럼 잔디 깔기! | 블로그에 잔디 까는 방법

염베리 2022. 1. 5. 06:11

* 취미 활동을 기록한 글입니다.


! 업데이트 노트

 

[220106] CSS 수정 - 잔디밭을 드래그했을 때 innerText가 드러나지 않도록 calendar 영역에 대한 드래깅을 막았습니다.


티스토리에 깃허브처럼 잔디깔기!

 

계기

지난 10월에 첫 포스팅을 올린 이래로 이제 4개월 차,

언제부턴가 깃허브의 잔디가 부러워지기 시작했다 ㅠㅠㅠ

 

지금이라도 넘어갈까 고민도 잠시 해봤지만, 지금껏 함께해온 티스토리에 정도 많이 들었고...

편의성 부분에서 깃허브 페이지는 도무지 메인으로 사용하고 싶은 마음이 들지 않았다.

 

그렇다면, 깃허브의 잔디같은 시스템(?)을 티스토리에 구현해보면 어떨까하는 생각이 들었다.

조사 차 찾아보니 생각보다 어려울 것 같지 않았고, 반나절을 꼬박 들인 결과... 제법 만족스러운 그림이 나왔다!

 

그래서 공유해본다! 일명 티스토리에 잔디 깔기 대작전이다! ( ッ◕ ܫ◕)ッ' 

 

구현 방법

티스토리에는 포스팅 달력이라는 위젯이 있다.

https://tistory.noo9ya.com/67

포스팅을 올린 날짜에 주황색 표식이 생긴다고 이해하면 된다.

표식을 클릭하면 해당 포스팅으로 넘어가주는 기능까지 있다.

사실상 필요한 기능은 이 정도면 충분하기 때문에,

여기에 CSS를 추가해주고 JS로 HTML의 구조를 변조하여 깃의 잔디처럼 보이게 하는 것을 목표로 삼았다!


생김새 및 기능

 

완성본은 이렇게 생겼다

달력을 셀로 바꿔놨다고 생각하면 이해하기 편하다.

셀의 기본 색상은 회색이며, 포스팅을 올리면 해당 날짜의 셀이 녹색으로 변한다.

텀 없이 매일 게시글을 올리면 색이 점점 진해지게끔 해줬다.

(하루라도 놓치면 리셋이다 ㅎ)

 

깃허브 잔디의 색상은 컨트리뷰션 양을 기준으로 정해진다고 알고 있는데

되도록 비슷하게 가고 싶어서 해당 날짜의 포스팅 개수를 기준으로 색을 주려고 했었으나

몇 시간의 사투 끝에 결국 패배했다.

Ajax를 제대로 다룰 줄 알았다면 가능했을 것 같은 아쉬움이 자꾸 남아서 다음에 다시 한번 방법을 찾아봐야할 것 같다.

그러나 당분간은 눈 코 뜰 새가 없어서 이 정도에서 타협했다!

 

적용해놓고 보면 이런 느낌이다

제법 귀엽다.....ㅎ

원본 위젯의 기능을 그대로 유지하고 있기 때문에,

셀을 클릭할 시 해당 날짜에 작성한 포스팅 모음을 볼 수 있다.


티스토리 잔디 적용 방법

 

설명

지금부터는 적용 방법이다.

크게 복잡하지 않다!

 

주의사항

기존 스킨에 포함되어있는 달력 위젯이 있다면 깨끗하게 제거한 후 진행하는 것이 안전하다!

* HTML 내부의 달력 element 관련 코드를 삭제하고 CSS에서도 calendar 관련 코드를 삭제해주어야 한다.

 

스킨 편집창으로 들어가기

[1] 설정 화면 > 스킨 편집 을 클릭한다.

 

[2] html 편집 을 클릭한다.

 

[3] 여기서 현재 적용중인 스킨의 HTML/CSS 를 볼 수 있다.

 

HTML에 다음 코드를 추가한다

HTML 탭에 들어가서 코드를 훑어보면 중간에 <s_sidebar_element>들이 모여있는 구간이 있을 것이다.

해당 구간의 원하는 위치에 다음 코드를 복붙해주면 된다.

* 이 글은 사이드바가 있는 스킨을 기준으로 작성되었다. 사이드바가 없는 스킨을 사용하고 있다면 적절한 위치를 직접 선정하여 코드를 넣어준다.

<s_sidebar_element>
  <!-- 달력 -->
  <div class="calendar">
    <h1 class="sr-only"></h1>
    <!-- 티스토리 달력 모듈 -->
    
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
<script> // 포스팅 올린 날짜에 색 주기 passed = document.getElementsByClassName('cal_click'); for(i=0;i<passed.length;i++){ day = parseInt(passed[i].href.split('/')[4].slice(6)) // 연속으로 올렸는지 확인 if(i>0 && day==temp+1){ cnt += 1; } else { cnt = 0; } temp = day if(cnt<1){ color = "#C5E1A5" } else if(cnt<2){ color = "#AED581" } else if(cnt<3){ color = "#9CCC65" } else if(cnt<4){ color = "#8BC34A" } else if(cnt<5){ color = "#7CB342" } else if(cnt<6){ color = "#689F38" } else{ color = "#558B2F" } document.getElementsByClassName('cal_click')[i].style.color = color; document.getElementsByClassName('cal_click')[i].style.background = color; // 날짜가 두자릿수인 경우 모양이 깨져서 1로 고정시킴 passed[i].innerText=1; } // 아직 포스팅 하지 않은 날짜에도 모양을 주기 위해 <a> 삽입 후 1로 고정시킴 notyet = document.getElementsByClassName('cal_day') for(i=0;i<notyet.length;i++){ if(notyet[i].innerHTML.includes('</a>')){ continue; } else { document.getElementsByClassName('cal_day')[i].innerHTML="<a>1</a>"; } } // 이전 달로 가는 버튼 document.getElementsByClassName('cal_month')[0].children[0].innerText="◀ㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤ"; // 연월 확인 mth = document.getElementsByClassName('cal_month')[0].children[1].innerText.split('/'); if(mth[1][0]==0){ mth[1] = mth[1][1]; } if(parseInt(mth[1])-1==0){ premth = 12 preyear = parseInt(mth[0])-1 } else { premth = parseInt(mth[1])-1 preyear = parseInt(mth[0]) } if(parseInt(mth[1])+1==13){ postmth = 1 postyear = parseInt(mth[0])+1 } else { postmth = parseInt(mth[1])+1 postyear = parseInt(mth[0]) } // 월 표기 방식 switch(mth[1]){ case '1': thismth = 'Jan' break case '2': thismth = 'Feb' break case '3': thismth = 'Mar' break case '4': thismth = 'Apr' break case '5': thismth = 'May' break case '6': thismth = 'Jun' break case '7': thismth = 'Jul' break case '8': thismth = 'Aug' break case '9': thismth = 'Sep' break case '10': thismth = 'Oct' break case '11': thismth = 'Nov' break case '12': thismth = 'Dec' break } document.getElementsByClassName('cal_month')[0].children[1].innerText = thismth; // 다음 달로 가는 버튼 document.getElementsByClassName('cal_month')[0].children[2].innerText="ㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤ▶"; // 버튼 및 월에 커서 올렸을 시 안내 문구 수정 document.getElementsByClassName('cal_month')[0].children[0].setAttribute('title',preyear+'년 '+premth+'월의 잔디밭'); document.getElementsByClassName('cal_month')[0].children[1].setAttribute('title',mth[0]+'년 '+mth[1]+'월의 잔디밭'); document.getElementsByClassName('cal_month')[0].children[2].setAttribute('title',postyear+'년 '+postmth+'월의 잔디밭'); </script> </div> </s_sidebar_element>

복붙을 완료했다면 HTML 탭 우측 상단의 적용 버튼을 꼭 눌러주자!

 

CSS 가장 아래쪽에 다음 코드를 추가한다

CSS 탭에 들어간 후 스크롤바를 쭉 밑으로 내려준다.

가장 끝자리에 다음 코드를 추가해주면 된다.

/* calendar */
.calendar {-ms-user-select: none;-moz-user-select: -moz-none;-khtml-user-select: none;-webkit-user-select: none;user-select: none;}
.calendar .tt-calendar {margin-top:8%;margin-bottom:10%;width:280px !important;border-collapse:collapse;}
.calendar .tt-calendar caption {font-size:1em;margin-bottom:10px;height:100%}
.calendar .tt-calendar caption a:first-child, .calendar .tt-calendar caption a:last-child {color:#DB8EB5; font-size:0.375em}
.calendar .tt-calendar caption a {vertical-align:middle;color:black;}
.calendar .tt-calendar th, .calendar .tt-calendar td {padding:5px 0; text-align:center;}
.calendar .tt-calendar th {display:none;}
.calendar .tt-calendar td {font-size:1.3em; color:#bbb;}
.calendar .tt-calendar .cal_click {display:inline-block; padding:2px 8px; border-radius:2px;}
.calendar .tt-calendar td a {display:inline-block; padding:2px 8px; background:#E0E0E0; color:#E0E0E0; border-radius:2px;}

복붙을 완료했다면 이번에도 CSS 탭 우측 상단의 적용 버튼을 눌러준다.

 

새로고침

블로그를 새로고침하면 아마 어딘가 좀 이상한 모양의 잔디밭을 볼 수 있을 것이다.

* 만약 잔디밭 모양이 정상적으로 출력된다면 운이 좋은 케이스이고 여기서 끝이다! 👏🏻

새로고침해도 잔디밭이 보이지 않는다면?

설정 화면 > 사이드바 에 들어가서 달력 모듈을 기본 설정에 추가해준다.

달력 위젯에 관한 대부분의 포스팅에서 모듈 추가를 우선적으로 해주고 있는데, 내 경우에는 따로 추가해주지 않아도 정상적으로 나타났기 때문에 생략하고 넘어온 부분이다.

여기까지 똑같이 했는데도 잔디밭이 보이지 않는다면 달력 모듈을 한번 추가해보도록 하자.

* 그래도 안된다면 댓글로 문의를... 함께 고민해봅시다!

 

잔디밭의 너비와 높이를 스킨에 맞게 수정한다

위 CSS는 내가 사용하고 있는 스킨에 맞게 너비와 높이를 고정값으로 짜놓은 것이라

나와 다른 스킨을 사용하고 있다면 십중팔구 잔디밭이 꾸겨져 있을 것이다 ㅠㅠ

물론 반응형으로 짜고 싶었지만... 잘 안됐다 ㅎ

따라서 CSS를 조금 수정하여 자신의 스킨에 맞게 조정해주어야 한다.

아까 추가했던 CSS 내부에서 다음 두 부분을 찾은 후, 너비와 높이를 수정하여 각 셀이 정사각형 모양을 띄게끔 만들어주면 된다.

값 수정 → 적용 → 새로고침 순으로 테스트하며 적정한 값을 찾아주자!

/* width = 너비를 결정하는 값이다 */
.calendar .tt-calendar {margin-top:8%;margin-bottom:10%;width:280px !important;border-collapse:collapse;}

/* font-size = 높이를 결정하는 값이다 */
.calendar .tt-calendar td {font-size:1.3em; color:#bbb;}

* 잔디밭 모양은 잡았는데, 캡션 부분이 너무 길어서 줄바꿈되어버린다면 추가했던 HTML 코드 내의 이전 달로 가는 버튼다음 달로 가는 버튼에 포함된 공백 특수문자의 개수를 줄여주면 된다. (해당 부분에 주석을 달아놨으므로 Ctrl+F 하여 찾아준다.)

 

끝!

수정이 성공적으로 끝났다면 드디어 푸릇푸릇한 잔디밭을 볼 수 있다!


추가적으로 커스터마이징하고 싶다면?

 

참고

커스터마이징을 하고 싶다면 가장 먼저 해당 위젯의 구조를 파악하여야 한다.

다음 포스팅에 달력 위젯의 소스 코드와 클래스 관련 정보가 깔끔하게 정리되어있다.

https://tistory.noo9ya.com/67

 

Section 23 - 티스토리 반응형 스킨 만들기 - [사이드바] 달력

이번 시간에는 "사이드바 달력" 모듈입니다. 제 경험상 티스토리 블로그에 달력을 노출하는 사람은 많이 못 봤지만 그래도 없는것보단 있는게 낫지 않을까 싶어서 달력도 만들어 보도록하겠습

tistory.noo9ya.com

 

잔디의 색상을 바꾸고 싶다면?

위에 첨부했던 HTML 코드를 살펴보면 중간에 cnt의 값에 따라 color에 각기 다른 값을 할당하는 구간이 있음을 확인할 수 있다.

이 부분의 color에 원하는 색상을 넣어주면 된다!

    if(cnt<1){
        color = "#C5E1A5"  // 여기!
    } else if(cnt<2){
        color = "#AED581"  // 여기!
    } else if(cnt<3){
        color = "#9CCC65"  // 여기!
    } else if(cnt<4){
        color = "#8BC34A"  // 여기!
    } else if(cnt<5){
        color = "#7CB342"  // 여기!
    } else if(cnt<6){
        color = "#689F38"  // 여기!
    } else{
        color = "#558B2F"  // 여기!
    }

 

그외

그외에도 커스터마이징할 수 있는 요소는 많다!

흥미로운 커마 결과가 있다면 공유를 ✦‿✦


소감

 

지금까지 티스토리에 잔디 심는 포스팅이었다 ㅎ

별건 아니지만 요래조래 맹글어서 잘 보이는 곳에 뙇 배치해주고나니 티스토리에 대한 은은한 권태가 싹 씻겨져 내려가는 것 같다.

이제 더 이상 깃허브에 눈독 들이지 않고 여기에 뼈를 묻을(?) 수 있을 것 같다 ㅎ

이상으로 오늘의 취미 활동은 끝이다!

프로필사진
berry
FE Developer, loves React & better DX
Comments