保存测试

测试

目前为 2024-06-28 提交的版本。查看 最新版本

// ==UserScript==
// @name         保存测试
// @namespace    http://tampermonkey.net/
// @version      8.2
// @license MIT
// @description  测试
// @author       从前跟你一样
// @grant        unsafeWindow
// @match        *://*/*
// @require      https://cdn.staticfile.org/jquery/3.4.1/jquery.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/jszip/3.7.1/jszip.min.js
// @connect      vagrantup.com
// @grant        unsafeWindow
// @grant         GM_xmlhttpRequest
// @connect       192.168.10.2
// @connect       novelai.net
// @match        *://*/*
// @description  Save user settings
// @grant        GM_xmlhttpRequest
// @grant        GM_setValue
// @grant        GM_getValue
// ==/UserScript==
// ==/UserScript==

(function() {
    'use strict';
    let isDragging = null;

    const ICON_URL = 'https://internal-api-drive-stream-sg.larksuite.com/space/api/box/stream/download/v2/cover/QHspbh93roP3BtxYKSelqvZvgGf/?fallback_source=1&height=1280&mount_node_token=A76Yd1rjgo4Bavxu183lE7j7gIh&mount_point=docx_image&policy=equal&width=1280';
   // let iconData = GM_getValue('iconData', null);
     let iconData = ""    // 下载并保存图标
    function downloadAndSaveIcon() {
        GM_xmlhttpRequest({
            method: 'GET',
            url: ICON_URL,
            responseType: 'blob',
            onload: function(response) {
                let reader = new FileReader();
                reader.onloadend = function() {
                    iconData = reader.result;
                    GM_setValue('iconData', iconData);
                    createSettingsIcon(iconData);
                };
                reader.readAsDataURL(response.response);
            }
        });
    }

   function createSettingsIcon(iconSrc) {
    const icon = document.createElement('img');
    icon.src = iconSrc;
    icon.style.position = 'fixed';
    icon.style.top = '50%';
    icon.style.right = '0';
    icon.style.transform = 'translateY(-50%)';
    icon.style.width = '30px';
    icon.style.height = '30px';
    icon.style.cursor = 'pointer';
    icon.style.zIndex = '9999';
    icon.style.transition = 'right 0.3s';

    let hideTimeout;


    function snapToRight() {
        icon.style.right = '0';
        icon.style.left = 'auto';
        clearTimeout(hideTimeout);
        hideTimeout = setTimeout(() => {
            icon.style.right = '-20px';
        }, 2000);
    }

    function showIcon() {
        icon.style.right = '0';
        clearTimeout(hideTimeout);
    }

    function hideIcon() {
        hideTimeout = setTimeout(() => {
            icon.style.right = '-20px';
        }, 1000);
    }

    icon.addEventListener('mouseenter', showIcon);
    icon.addEventListener('mouseleave', hideIcon);
    icon.addEventListener('mousedown', (e) => {

         isDragging = e.clientX;

    })
    // 修改点击事件处理
    icon.addEventListener('mouseup', (e) => {
        if (e.clientX==isDragging) {
            openSettingsPanel();
        }
    }) ;

    makeDraggable(icon, () => {
        snapToRight();
    });

    function makeDraggable(element, callback) {
        let pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
        element.onmousedown = dragMouseDown;

        function dragMouseDown(e) {
            e = e || window.event;
            e.preventDefault();
            pos3 = e.clientX;
            pos4 = e.clientY;
            document.onmouseup = closeDragElement;
            document.onmousemove = elementDrag;
        }

        function elementDrag(e) {
            e = e || window.event;
            e.preventDefault();
            pos1 = pos3 - e.clientX;
            pos2 = pos4 - e.clientY;
            pos3 = e.clientX;
            pos4 = e.clientY;
            element.style.top = (element.offsetTop - pos2) + "px";
            element.style.left = (element.offsetLeft - pos1) + "px";
            element.style.right = 'auto';
        }

        function closeDragElement() {

            document.onmouseup = null;
            document.onmousemove = null;
            if (callback) callback();
        }
    }

    document.body.appendChild(icon);
    hideIcon(); // 初始状态为隐藏
}

    // 创建设置面板
    function createSettingsPanel() {
        const panel = document.createElement('div');
        panel.style.position = 'fixed';
        panel.style.top = '50%';
        panel.style.left = '50%';
        panel.style.transform = 'translate(-50%, -50%)';
        panel.style.backgroundColor = 'white';
        panel.style.padding = '20px';
        panel.style.border = '1px solid black';
        panel.style.zIndex = '10000';
        panel.style.display = 'none';

        const input = document.createElement('input');
        input.type = 'text';
        input.value = GM_getValue('userSetting', '');

        const saveButton = document.createElement('button');
        saveButton.textContent = '保存设置';
        saveButton.onclick = saveSetting;

        panel.appendChild(input);
        panel.appendChild(saveButton);

        document.body.appendChild(panel);
        return panel;
    }

    // 打开设置面板
    function openSettingsPanel() {
        settingsPanel.style.display = 'block';
    }

    // 保存设置
    function saveSetting() {
        const input = settingsPanel.querySelector('input');
        GM_setValue('userSetting', input.value);
        settingsPanel.style.display = 'none';
    }

    // 初始化
    if (iconData) {
        createSettingsIcon(iconData);
    } else {
        downloadAndSaveIcon();
    }

    const settingsPanel = createSettingsPanel();
    // Your code here...
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址