Greasy Fork is available in English.

GKD网页审查工具规则复制增强

在GKD网页审查工具复制规则后,弹出菜单,让用户自定义部分内容

安装此脚本?
作者推荐脚本

您可能也喜欢GKD网页审查工具自动showSize

安装此脚本
// ==UserScript==
// @name         GKD网页审查工具规则复制增强
// @namespace    https://blog.adproqwq.xyz
// @version      1.6.2
// @description  在GKD网页审查工具复制规则后,弹出菜单,让用户自定义部分内容
// @author       Adpro
// @match        https://i.gkd.li/*
// @exclude      https://i.gkd.li
// @icon         
// @grant        none
// @require      https://cdn.jsdelivr.net/npm/json5@2.2.3/dist/index.min.js
// @license      MIT
// ==/UserScript==

(function() {
  'use strict';
  // 初始化
  let layuiScript = document.createElement('script');
  layuiScript.src = 'https://www.layuicdn.com/layui/layui.js';
  let layuiCss = document.createElement('link');
  layuiCss.rel = 'stylesheet';
  layuiCss.href = 'https://www.layuicdn.com/layui/css/layui.css';
  document.body.appendChild(layuiScript);
  document.head.appendChild(layuiCss);
  if(window.localStorage.getItem('categories') === null) window.localStorage.setItem('categories','');
  window.modifyResult = '';

  const modifyEnd = new Event('modifyEnd');

  navigator.clipboard._writeText = navigator.clipboard.writeText;
  navigator.clipboard.writeText = async (arg) => {
    try{
      JSON5.parse(arg);
    }
    catch{
      await navigator.clipboard._writeText(arg);
      layer.msg('复制成功',{icon: 1});
    }
    modifyRule(arg);
    window.addEventListener('modifyEnd', () => {
      navigator.clipboard._writeText(window.modifyResult).then(() => {
        layer.msg('注入修改成功',{icon: 1});
      });
    });
  }

  var mode, cate = '';

  const modifyRule = (rawRule) => {
    var layer = layui.layer;
    var form = layui.form;
    var element = layui.element;
    mode = '1';
    let rule = JSON5.parse(rawRule);
    layer.open({
      type: 1,
      title: '菜单',
      area: 'auto',
      shadeClose: true,
      success: (layero, index, that) => {
        document.getElementsByName('copy')[0].onclick = () => {
          let rulePos = document.getElementsByName('Rpos')[0].value;
          let rulePreKeys = document.getElementsByName('Rprekeys')[0].value;
          let ruleName = document.getElementsByName('Rname')[0].value;
          let ruleDesc = document.getElementsByName('Rdesc')[0].value;

          if(rulePos != ''){
            if(rulePos.startsWith('{') == true && rulePos.endsWith('}') == true){
              let position = JSON5.parse(rulePos);
              let positionKeys = Object.keys(position);
              if(positionKeys.length == 2){
                if(positionKeys.indexOf('left') != -1 && positionKeys.indexOf('right') != -1){
                  layer.msg('坐标非法',{icon: 2});
                  return;
                }
                else if(positionKeys.indexOf('top') != -1 && positionKeys.indexOf('bottom') != -1){
                  layer.msg('坐标非法',{icon: 2});
                  return;
                }
                else if(positionKeys[0] == positionKeys[1]){
                  layer.msg('坐标非法',{icon: 2});
                  return;
                }
                else rule.groups[0].rules[0].position = position;
              }
              else{
                layer.msg('坐标非法',{icon: 2});
                return;
              }
            }
            else{
              layer.msg('你填写的坐标不是一个对象',{icon: 2});
              return;
            }
          }

          if (rulePreKeys != ''){
            let eachPreKey = rulePreKeys.split(',');
            let preKeysArray = [];
            eachPreKey.forEach((a)=>{
              preKeysArray.push(Number(a));
            });
            let rulePrekeysObj = {
              preKeys: preKeysArray,
            };
            rule.groups[0].rules[0] = {...rulePrekeysObj,...rule.groups[0].rules[0]};
          }

          if(cate == '开屏广告') delete rule.groups[0].rules[0].activityIds;

          if(ruleName != '' && cate != '') rule.groups[0].name = cate + '-' + ruleName;
          else if(ruleName != '' && cate == '') rule.groups[0].name = ruleName;
          else{
            if(cate != '') rule.groups[0].name = cate;
          }

          if(ruleDesc == '') delete rule.groups[0].desc;
          else rule.groups[0].desc = ruleDesc;

          layer.close(index);
          
          window.modifyResult = output(rule, mode);
          window.dispatchEvent(modifyEnd);
        };

        document.getElementsByName('saveSettings')[0].onclick = () => {
          let categories = document.getElementsByName('categories')[0].value;
          window.localStorage.setItem('categories',categories);
          layer.msg('保存成功,重新打开本窗口生效',{icon: 6});
        };

        let categories = window.localStorage.getItem('categories');
        if(categories && categories != '') document.getElementsByName('categories')[0].innerText = JSON5.stringify(JSON5.parse(categories));

        geneCategories();
      },
      content: `
        <div class="layui-tab layui-tab-brief" lay-filter="tab-filter">
          <ul class="layui-tab-title">
            <li class="layui-this" lay-id="info">信息配置</li>
            <li lay-id="settings">设置</li>
          </ul>
          <div class="layui-tab-content">
            <div class="layui-tab-item layui-show">
              <div class="layui-form">
                <div class="layui-form-item">
                  <label class="layui-form-label">选择模式:</label>
                  <input type="radio" name="mode" value="0" title="ts模式" lay-filter="mode-filter">
                  <input type="radio" name="mode" value="1" title="app模式" lay-filter="mode-filter" checked>
                  <input type="radio" name="mode" value="2" title="groups模式" lay-filter="mode-filter">
                  <input type="radio" name="mode" value="3" title="rules模式" lay-filter="mode-filter">
                </div>
                <div id="categories" class="layui-form-item">
                  <label class="layui-form-label">选择分类:</label>
                </div>
                <div class="layui-form-item">
                  <label class="layui-form-label">插入限制字段:</label>
                  <input type="radio" name="limit" value="yes" title="是" lay-filter="limit-filter">
                  <input type="radio" name="limit" value="no" title="否" lay-filter="limit-filter" checked>
                </div>
                <div class="layui-form-item">
                  <label class="layui-form-label">修改key为:</label>
                  <div class="layui-input-group">
                    <input type="number" name="Rkey" lay-affix="ok" lay-filter="ok" class="layui-input">
                    <div class="layui-input-suffix">
                      <i class="layui-icon layui-icon-tips"></i> ts模式、app模式和groups模式修改groups内的key;rules模式修改rules内的key。记得点勾!
                    </div>
                  </div>
                </div>
                <div class="layui-form-item">
                  <label name="preKeysLabel" class="layui-form-label layui-hide">修改preKeys为:</label>
                  <div class="layui-input-group">
                    <input type="text" name="Rprekeys" lay-affix="clear" class="layui-input layui-hide">
                    <div name="preKeysTips" class="layui-input-suffix layui-hide">
                      <i class="layui-icon layui-icon-tips"></i> 多个key用,号分割,不要加空格。没有不填。切换模式不会丢失填写的内容。因格式化问题,格式与GKD要求的有区别。
                    </div>
                  </div>
                </div>
                <div class="layui-form-item">
                  <label class="layui-form-label">坐标:</label>
                  <div class="layui-input-block">
                    <input type="text" name="Rpos" placeholder="一个合法的坐标对象,若无不填" autocomplete="off" lay-affix="clear" class="layui-input">
                  </div>
                </div>
                <div class="layui-form-item">
                  <label class="layui-form-label">规则组名称:</label>
                  <div class="layui-input-block">
                    <input type="text" name="Rname" placeholder="${rule.groups[0].name}" autocomplete="off" lay-affix="clear" class="layui-input">
                  </div>
                </div>
                <div class="layui-form-item">
                  <label class="layui-form-label">规则组描述:</label>
                  <div class="layui-input-block">
                    <input type="text" name="Rdesc" placeholder="没有描述不填" autocomplete="off" lay-affix="clear" class="layui-input">
                  </div>
                </div>
                <div class="layui-btn-container">
                  <button type="button" name="copy" class="layui-btn">确定</button>
                </div>
              </div>
            </div>
            <div class="layui-tab-item">
              <div class="layui-form">
                <div class="layui-form-item">
                  <label class="layui-form-label">分类:</label>
                  <div class="layui-input-block">
                    <textarea name="categories" cols=50 rows=15 placeholder="多个{key, name}组成的数组,支持JSON5语法" class="layui-textarea"></textarea>
                  </div>
                </div>
                <div class="layui-btn-container">
                  <button type="button" name="saveSettings" class="layui-btn">保存</button>
                </div>
              </div>
            </div>
          </div>
        </div>
      `,
    });
    layui.use(()=>{
      form.render();
      element.render('tab', 'tab-filter');
    });
    form.on('radio(mode-filter)', (data)=>{
      let elem = data.elem;
      mode = elem.value;
      if(mode == '3'){
        document.getElementsByName('Rprekeys')[0].classList.remove('layui-hide');
        document.getElementsByName('preKeysLabel')[0].classList.remove('layui-hide');
        document.getElementsByName('preKeysTips')[0].classList.remove('layui-hide');
      }
      else{
        document.getElementsByName('Rprekeys')[0].classList.add('layui-hide');
        document.getElementsByName('preKeysLabel')[0].classList.add('layui-hide');
        document.getElementsByName('preKeysTips')[0].classList.add('layui-hide');
      }
    });
    form.on('radio(cate-filter)', (data)=>{
      let elem = data.elem;
      cate = elem.value;
    });
    form.on('radio(limit-filter)', (data)=>{
      let elem = data.elem;
      let isInsert = elem.value;
      if(isInsert == 'yes'){
        if(mode != '3'){
          rule.groups[0].matchTime = 10000;
          rule.groups[0].resetMatch = 'app';
          rule.groups[0].actionMaximum = 1;
        }
        else{
          rule.groups[0].rules[0].matchTime = 10000;
          rule.groups[0].rules[0].resetMatch = 'app';
          rule.groups[0].rules[0].actionMaximum = 1;
        }
      }
    });
    form.on('input-affix(ok)', function(data){
      let elem = data.elem;
      let value = elem.value;
      if(value != ''){
        if(mode == '0' || mode == '1' || mode == '2') rule.groups[0].key = Number(value);
        else{
          let ruleKey = {
            key: Number(value)
          };
          rule.groups[0].rules[0] = {...ruleKey,...rule.groups[0].rules[0]};
        }
        layer.msg('修改成功',{icon: 1});
      }
    });
  };

  function output(rule, mode){
    if(mode == '0'){
      const tsFile = `import { defineGkdApp } from '@gkd-kit/define';\r\rexport default defineGkdApp(${JSON5.stringify(rule,null,2)});\r`;
      return tsFile;
    }
    else if(mode == '1') return JSON5.stringify(rule,null,2);
    else if(mode == '2') return JSON5.stringify(rule.groups[0],null,2);
    else if(mode == '3') return JSON5.stringify(rule.groups[0].rules[0],null,2);
  }

  function geneCategories(){
    let categories = window.localStorage.getItem('categories');
    let CateChoo = document.getElementById('categories');
    if(categories && categories != ''){
      categories = JSON5.parse(categories);
      categories.forEach((b)=>{
        let TInput = document.createElement('input');
        TInput.type = 'radio';
        TInput.name = 'RCate';
        TInput.value = b.name;
        TInput.title = b.name;
        TInput.setAttribute('lay-filter','cate-filter');
        CateChoo.appendChild(TInput);
      });
    }
  }

})();