Greasy Fork

Greasy Fork is available in English.

快速查包

快速跳转至指定包或指定分支

目前为 2022-11-16 提交的版本。查看 最新版本

// ==UserScript==
// @name         快速查包
// @namespace    fsh
// @version      1.7
// @description  快速跳转至指定包或指定分支
// @author       05128
// @match        *://ci.meitu.city/*
// @match        *://ios.meitu-int.com/ipa/*
// @match        *://jira.meitu.com/*
// @grant        GM_xmlhttpRequest
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @require      https://cdn.staticfile.org/jquery/3.3.1/jquery.min.js
// @license MIT
// ==/UserScript==

(function() {
    'use strict';
    // 设置刷新时间
    const refreshTime = 1000;
    // 添加CSS
    $('head').append($(`
  <style>
  .search{
    position: relative;
    width: 220px;
  }
  .search input{
    height: 42px;
    width: 220px;
    border-radius: 42px;
    border: 2px solid #324B4E;
    background: #F9F0DA;
    transition: .3s linear;
    float: left;
    text-indent: 10px;
  }

  .search input:focus::placeholder{
    opacity: 0;
  }
  .search button{
    height: 42px;
    border-radius: 42px;
    border-right: 1px solid #324B4E;
    border-left: 0px;
    background: #F9F0DA;
    right: 0;
    position: absolute;
  }

  .btn_find_build{
    width: 42px;
    text-align: center;
  }

  .search_span{
    /*border: 1px dashed #000;*/
    cursor: pointer;
    height: 16px;
    margin: 0px 10px;
    padding: 3px;
    border-radius: 25px;
  }

  .btn_copy_build{
    height: 30px;
    width: 120px;
    border-radius: 42px;
    border: 1px solid #324B4E;
    background: #fff;
    transition: .3s linear;
    color: #544d4d;
    margin: 0px 10px;
    font-size:14px;
  }

  img{
    height:16px;
  }

  </style>`));
    // 当是ci域名时,才触发后续的操作,如果不是则不触发
    // CI
    // CI
    // CI
    if (location.href.indexOf('ci.meitu.city') > 0) {
        clearInterval(refreshTime);
        setInterval(function () {
            let input_find_build = document.getElementById('input_find_build');
            let btn_copy_build = document.getElementById('btn_copy_build');
            // 如果不存在则添加
            if (!input_find_build) {
                addFindButtonCicity();
                $('#btn_find_build').unbind("click").click(function () {
                    let input_build_content = document.getElementById("input_find_build").value.trim()
                    if(input_build_content===""){
                        return false;
                    }
                    let targetUrl = ""
                    // 如果输入的是纯数字,视为build id
                    if(/^\d+$/.test(input_build_content)){
                        let baseUrl = 'https://ci.meitu.city/build/Meitu/number/'
                        targetUrl = baseUrl + input_build_content
                    }else{// 否则按输入的是分支处理
                        let baseUrl = 'https://ci.meitu.city/build/Meitu/branch/'
                        input_build_content = input_build_content.replaceAll("/","%2F")
                        targetUrl = baseUrl + input_build_content
                    }
                    // 跳转到指定页面
                    window.location.href=targetUrl
                });
            }

            if(!btn_copy_build){
                addCopyButtonCicity();
                $('.btn_copy_build').unbind("click").click(function(){
                    let full_build_name = this.parentNode.children[0].innerText.trim()
                    let targetUrl = ""
                    let baseUrl = 'https://ci.meitu.city/build/Meitu/branch/'
                    full_build_name = full_build_name.replaceAll("/","%2F")
                    targetUrl = baseUrl + full_build_name
                    // 跳转到指定页面
                    window.location.href=targetUrl
                });
            }
        }, refreshTime);
    }

    // 进入CI页面时添加输入框和跳转按钮
    function addFindButtonCicity() {
        let span = $('<span class="search"></span>')
        let input_find_build = $('<input type="text" class="text" id="input_find_build" placeholder="  输入Build id或分支名">');
        let btn_find_build = $('<button type="submit" class="btn_find_build" id="btn_find_build">🔍</button>');
        //let btn_find_build = $('<input type="button" class="aui-button btn_find_build" value="✔" id="btn_find_build">');
        span.append(input_find_build);
        span.append(btn_find_build);
        $(".project-label__name").after(span);
    }
    // 进入CI页面时,在分支名后方添加复制按钮
    function addCopyButtonCicity(){
        let btn_copy_build = $('<button type="submit" class="btn_copy_build" id="btn_copy_build">跳转至最新➔</button>');
        $(".message-card__subtitle").after(btn_copy_build);
    }

    // 当是granary域名时,才触发后续的操作,如果不是则不触发
    // Granary
    // Granary
    // Granary
    if (location.href.indexOf('ios.meitu-int.com') > 0) {
        clearInterval(refreshTime);
        setInterval(function () {
            let input_find_build = document.getElementById('input_find_build');
            // 如果不存在则添加
            if (!input_find_build) {
                addFindButtonGranary();
            }
            $('#btn_find_build').unbind("click").click(function () {
                let input_build_content = document.getElementById("input_find_build").value.trim()
                if(input_build_content===""){
                    return false;
                }
                let targetUrl = ""
                // 如果输入的是纯数字,视为build id
                if(/^\d+$/.test(input_build_content)){
                    let baseUrl = 'http://ios.meitu-int.com/ipa/mtxx/build/'
                    targetUrl = baseUrl + input_build_content
                }else{// 否则按分支处理
                    let baseUrl = 'http://ios.meitu-int.com/ipa/mtxx/'
                    input_build_content = input_build_content.replaceAll("/","%2F")
                    targetUrl = baseUrl + input_build_content
                }
                // 跳转到指定页面
                window.location.href=targetUrl
            });
        }, refreshTime);
    }

    // 进入granary页面时添加输入框和跳转按钮
    function addFindButtonGranary() {
        let span = $('<span class="search"></span>')
        let input_find_build = $('<input type="text" class="text" id="input_find_build" placeholder=" 输入Build id或分支名">');
        let btn_find_build = $('<button type="submit" class="btn_find_build" id="btn_find_build">🔍</button>');
        //let btn_find_build = $('<input type="button" class="aui-button btn_find_build" value="✔" id="btn_find_build">');

        span.append(input_find_build);
        span.append(btn_find_build);
        //$("#home-tab").after(span);
        $("#myTab").append(span);
    }

    // 当是jira域名时,才触发后续的操作,如果不是则不触发
    // Jira
    // Jira
    // Jira
    if (location.href.indexOf('jira.meitu.com') > 0) {
        clearInterval(refreshTime);
        setInterval(function () {
            let search_span = document.getElementById('search_span_create');
            // 因为切至iOS按钮和切至Android按钮一般都会成对出现,所以这里只获取iOS按钮,用于判断按钮是否已存在
            let change_side_button = document.getElementById('change_side_ios');
            let create_issue_dialog = document.getElementById('create-issue-dialog');
            // 如果不存在则添加
            if (!search_span) {
                addButtonJira();
                // 存储bug平台
                GM_setValue('platform',document.getElementById('customfield_10301-val').textContent.trim())
            }
            if (create_issue_dialog){
                // 加个计时避免按钮显示不出来
                let temp = setInterval(function () {
                    if(change_side_button == undefined || change_side_button.length == 0){
                        addChangeSideButton();
                        clearInterval(temp);
                    }
                },500)
            }
            // 跳转到创建分支
            $('#search_span_create').unbind("click").click(function () {
                let create_build_content = document.getElementById("customfield_10303-val").textContent.trim()
                // 写一个正则表达式
                let reg = /#?[0-9]{5}/
                let build_id_array = create_build_content.match(reg)
                let build_id = ''
                if (build_id_array == null || build_id_array.length==0 ){
                    console.log("未识别到build号")
                }else{
                    build_id = build_id_array[0]
                    // TODO: 待修改reg正则匹配,直接识别出数字部分,去掉下方的再次识别操作
                    let reg_num = /[0-9]{5}/
                    build_id = build_id.match(reg_num)[0]

                }
                // 根据bug平台,使用不同的baseurl
                let baseUrl = '';
                if(GM_getValue('platform')==='iOS'){
                    baseUrl = 'http://ios.meitu-int.com/ipa/mtxx/build/'
                }else if(GM_getValue('platform')==='Android'){
                    baseUrl = 'https://ci.meitu.city/build/Meitu/number/'
                }
                let targetUrl = baseUrl + build_id
                console.log(targetUrl)
                // 跳转到指定页面
                window.open(targetUrl)
            });
            // 跳转到解决分支
            $('#search_span_solved').unbind("click").click(function () {
                let create_build_content = document.getElementById("customfield_10304-val").textContent.trim()
                let reg = /#?[0-9]{5}/
                let build_id_array = create_build_content.match(reg)
                let build_id = ''
                if (build_id_array == null || build_id_array.length==0 ){
                    console.log("未识别到build号")
                }else{
                    build_id = build_id_array[0]
                    // TODO: 待修改reg正则匹配,直接识别出数字部分,去掉下方的再次识别操作
                    let reg_num = /[0-9]{5}/
                    build_id = build_id.match(reg_num)[0]
                    console.log(build_id)
                }
                // 根据bug平台,使用不同的baseurl
                let baseUrl = '';
                if(GM_getValue('platform')==='iOS'){
                    baseUrl = 'http://ios.meitu-int.com/ipa/mtxx/build/'
                }else if(GM_getValue('platform')==='Android'){
                    baseUrl = 'https://ci.meitu.city/build/Meitu/number/'
                }
                let targetUrl = baseUrl + build_id
                // 跳转到指定页面
                window.open(targetUrl)
            });

            // 切换到iOS bug模版
            $('.ios').unbind("click").click(function () {
                changeBugPlatform('iOS')
            });

            // 切换到Androidbug模版
            $('.android').unbind("click").click(function () {
                changeBugPlatform('Android')
            });
        }, refreshTime);
    }

    //在jira页面添加跳转按钮
    function addButtonJira(){
        // 创建分支按钮添加
        let span_create = $('<span class="search_span" id="search_span_create" style=""></span>')
        // 添加图片
        let search_image = ""
        let img = document.createElement('img');
        img.src = search_image;
        span_create.append(img);
        $("#customfield_10303-val").after(span_create);
        // 解决分支按钮添加
        let span_solved = $('<span class="search_span" id="search_span_solved"></span>')
        let img2 = document.createElement('img');
        img2.src = search_image;
        span_solved.append(img2);
        $("#customfield_10304-val").after(span_solved);
    }

    // 在jira页面添加更换平台按钮
    function addChangeSideButton(){
        // 创建分支按钮添加
        let span_ios = $('<button class="ios" id="change_side_ios" type="button" style="">iOS</button>')
        let spab_android = $('<button class="android" id="change_side_android" type="button" style="">Android</button>')
        let create_issue_dialog = document.getElementById('create-issue-dialog');
        $(".form-footer").append(span_ios)
        $(".form-footer").append(spab_android)
    }

    // 获取当前月份有多少天
    function getDuration () {
        let dt = new Date()
        var month = dt.getMonth()
        dt.setMonth(dt.getMonth() + 1)
        dt.setDate(0)
        return dt.getDate()
    }
    // sleep方法
    function sleep (time) {
        return new Promise((resolve) => setTimeout(resolve, time));
    }
    // 更改Bug平台
    function changeBugPlatform(platform){
        // 点击dropmenu,获取未发布版本字段
        let dropmenu = document.getElementsByClassName("drop-menu")[6]
        dropmenu.click()
        if(platform == "iOS"){
            document.getElementById('customfield_12903-1').checked = true
            document.getElementById('customfield_10301-2').checked = true
        }else if(platform == "Android"){
            document.getElementById('customfield_12903-1').checked = true
            document.getElementById('customfield_10301-1').checked = true
        }
        // 获取当前的月份和日期
        const date = new Date()
        const today = date.getDate()
        const curmonth = date.getMonth()+1
        // 获取大于且最接近当前日期的版本
        let ularr = document.getElementById("未发布版本")
        let aarr = ularr.getElementsByTagName('a')
        let minNum = 99
        let similarDate = ""
        for(let i=0;i<aarr.length;i++){
            if(aarr[i].text.indexOf(platform)<0){
                continue;
            }else{
                let startNum = aarr[i].text.lastIndexOf("(")
                let endNum = aarr[i].text.lastIndexOf(")")
                let theDateStr = aarr[i].text.slice(startNum + 1, endNum)
                // theDateStr是形似「1109」的日期形式,下面拆分出月份和日期
                let theMonth = theDateStr.slice(0,2)
                let theDate = theDateStr.slice(2)
                if(theMonth<curmonth){
                    continue;
                }else if (theMonth==curmonth){
                    if(theDate-today>=0 && theDate-today<minNum){
                        similarDate = theDateStr
                        minNum = theDate-today
                    }
                }else if (theMonth==curmonth+1){
                    let monthDuration = getDuration()
                    let daysToEnd = monthDuration-today
                    if((theDate+daysToEnd) < minNum){
                        similarDate = theDateStr
                        minNum = theDate+daysToEnd
                    }
                }

            }
        }
        // 删掉「影响版本」文本框中的内容
        let div = document.getElementsByClassName('representation')[0]
        let emarr = div.getElementsByTagName('em')
        for(let i=0;i<emarr.length;i++){
            // 这里全部都点击的emmarr[0],是因为第一个节点被删除掉之后,后面的素材会顶上来成为新的第0位节点,加个200ms延时,避免点击不到
            sleep(200).then(() => {
                emarr[0].click()
            })
        }
        // 在「影响版本」文本框填入内容
        for(let i=0;i<aarr.length;i++){
            // 如果a节点当中,存在目标日期字段,且平台与点击的一致,就把a节点的text填入到文本框中
            if(aarr[i].text.indexOf(similarDate)>0 && aarr[i].text.indexOf(platform)>0){
                document.getElementById('versions-textarea').value = aarr[i].text
            }
        }

    }

    // Your code here...
})();