Github News Unfold

A user script that unfolds GitHub news.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         Github News Unfold
// @namespace    http://tampermonkey.net/
// @version      0.3
// @description  A user script that unfolds GitHub news.
// @author       LovelyWei
// @match        https://github.com/
// @grant        none
// ==/UserScript==

const unfold = () =>{
    const detailsContainerSelector = 'div.Details.js-details-container.js-news-feed-event-group';
    const detailsContainer = Array.from(document.querySelectorAll(detailsContainerSelector));

    if (detailsContainer.length !== 0) {
        for (let i = 0; i < detailsContainer.length; i += 1) {
            const element = detailsContainer[i];
            element.classList.add('Details--on');
        }
    }
}

const init = () => {
    const target = document.getElementsByClassName('news')[0];

    const observer = new MutationObserver(() => {
        unfold();
    });

    observer.observe(target, {
        childList: true,
        subtree: true
    });
};

(function() {
    'use strict';
    init();
})();