Fix and auto hide GitHub top bar

Fix and Auto Hide GitHub Top Bar w/ Ocototree caused headerbar displacement fix

2017-12-12 기준 버전입니다. 최신 버전을 확인하세요.

이 스크립트를 설치하려면 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         Fix and auto hide GitHub top bar
// @namespace    https://ccoooss.com/
// @version      0.1.9
// @description  Fix and Auto Hide GitHub Top Bar w/ Ocototree caused headerbar displacement fix
// @author       Yukino Song
// @match        https://github.com
// @match        https://github.com/*/*
// @match        https://gist.github.com/*
// @grant        none
// ==/UserScript==

const style = `
body {
	padding-top: 54px;
}
.Header {
	position: fixed;
	width: 100%;
	min-width: 1020px;
	top: 0;
	left: 0;
	z-index: 50;
	transform: translate3d(0, 0, 0);
	transition: transform .3s;
}

.Header.hidden {
	transform: translate3d(0, -54px, 0);
}

@media screen and (max-width: 1480px) {
    .octotree-show .Header {
        min-width: 1246px;
    	padding-left: 226px;
    }

    .octotree-show .Header .container-lg {
        margin-left: 0;
    }
}
`;

function getScrollHeight() {
    return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
}

(function() {
    'use strict';
    // Your code here...
    // Inject style
    document.querySelector('head').insertAdjacentHTML('beforeend', `<style>${style}</style>`);

    var topBar = document.querySelector('.Header');

    var previousHeight = getScrollHeight();

    function updateScroll() {
        const prev = previousHeight;
        const height = getScrollHeight();
        previousHeight = height;

        // Always show on top
        if (height < 54) {
            topBar.classList.remove('hidden');
            return;
        }

        if (height > prev) topBar.classList.add('hidden');
        else topBar.classList.remove('hidden');
    }

    function smoothScrollTop() {
        // Use native smooth scrolling method (Chrome >= 61, Firefox >= 36)
        window.scroll({
            top: 0,
            behavior: 'smooth'
        });
    }

    window.addEventListener('scroll', updateScroll);
    topBar.addEventListener('dblclick', smoothScrollTop);
})();