Jenkins - Better select boxes

enlarge & sort selects

이 스크립트를 설치하려면 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         Jenkins - Better select boxes
// @namespace    http://tampermonkey.net/
// @version      0.3
// @description  enlarge & sort selects
// @author       You
// @match        https://jenkins.niji.fr/**
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    console.log('bsb - better select box for jenkins init');

    var selects = document.querySelectorAll('select.select');
    selects.forEach(function(select) {
        select.style.height = '400px';
        select.addEventListener('mouseover', function() {
            if (select.classList.contains('bsb-sorted') || select.children.length <= 1) {
                return;
            } else {
                select.classList.add('bsb-sorted');
            }
            console.log('bsb - sorting select options');
            var html = '';
            select.childElements()
                .sort(function(a,b) {
                return a.text == b.text ? 0 : a.text < b.text ? -1 : 1;
            })
                .forEach(function(el) { html += el.outerHTML;});
            select.innerHTML = html;
        });
    });

})();