CodeChef Tag Hiding

hide tags in CodeChef

2019-03-01 기준 버전입니다. 최신 버전을 확인하세요.

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

You will need to install an extension such as Tampermonkey to install this script.

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         CodeChef Tag Hiding
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  hide tags in CodeChef
// @author       luma
// @match        https://www.codechef.com/problems/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict'
    const $button = $("<span>")
    $button.addClass("button")
    $button.addClass("gray")
    $button.css("padding-left", "10px")
    $button.css("padding-right", "10px")

    let $tags
    let initiated = false
    let tagHidden = false

    const target = document.body;
    const observer = new MutationObserver((mutations) => {
        if(init()) {
            observer.disconnect()
        }
    });
    const config = { attributes: false, childList: true, characterData: false, subtree: true }
    observer.observe(target, config)

    function init() {
        if(initiated) return

        $tags = $("aside.problem-info").find("label").filter((i, e) => $(e).text().match(/Tags/)).parent().children("span")
        const ready = $tags.length === 1

        if(!ready) return false

        $tags.before($button)


        let tagHidden = false
        hideTags();
        return initiated = true
    }

    $button.on("click", () => {
        if(tagHidden) showTags();
        else hideTags();
    })

    function hideTags() {
        tagHidden = true
        $tags.hide()
        $button.text("show")
    }
    function showTags() {
        tagHidden = false
        $tags.show()
        $button.text("hide")
    }
})();