Pretty print your GitLab Snippet

try to take over the world!

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Pretty print your GitLab Snippet
// @namespace    dkt.pprint.gitlabsnippet
// @version      0.1
// @description  try to take over the world!
// @author       You
// @match        *://*/snippets/*
// @run-at       document-end
// ==/UserScript==

(function() {
    'use strict';

    if (!document.querySelector('.navbar-gitlab')) return;

    const buttonWrapper = unsafeWindow.document.querySelector('.detail-page-header-actions > div');
    const activateBtn = document.createElement('a');
    activateBtn.className = 'btn btn-grouped';
    activateBtn.href = '#';
    activateBtn.textContent = 'Pretty Print';
    buttonWrapper.append(activateBtn);

    activateBtn.addEventListener('click', (e) => {
        e.preventDefault();

        document.querySelector('.navbar-gitlab').remove();
        document.querySelector('.layout-page > .content-wrapper > .alert-wrapper').remove();
        document.querySelector('#content-body > .detail-page-header').remove();
        document.querySelector('#content-body small.edited-text').remove();
        document.querySelector('#content-body .content-component-block').remove();
        document.querySelector('#content-body .personal-snippets').remove();
        document.querySelector('#content-body #notes').remove();

        window.print()
    });

})();