Rapidgator Auto Converter

在 Rapidgator 页面自动显示链接转换工具

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Rapidgator Auto Converter
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  在 Rapidgator 页面自动显示链接转换工具
// @match        https://rapidgator.net/file/*
// @match        https://*.rapidgator.net/file/*
// @grant        GM_xmlhttpRequest
// @grant        GM_setValue
// @grant        GM_getValue
// ==/UserScript==

(function() {
    'use strict';

    // 配置
    const CONFIG = {
        SERVER_URL: 'http://106.75.247.132:8000', 
        DEFAULT_KEY: '', // 默认 key,用户可以修改
        POSITION: 'top-right', // 面板位置: top-left, top-right, bottom-left, bottom-right
        CORS_PROXY: 'https://cors-anywhere.herokuapp.com/',
        XIANYU_URL: 'https://m.tb.cn/h.SxoRhAV?tk=osVIfNz9fPt', // 闲鱼购买链接
        XIANYU_LOGO: '' // 闲鱼logo (base64编码)
    };    // 密钥管理功能
    const KeyManager = {
        STORAGE_KEY: 'rapidgator_user_key',
        
        // 保存用户输入的密钥
        saveKey: function(key) {
            if (key && key.trim()) {
                GM_setValue(this.STORAGE_KEY, key.trim());
                console.log('密钥已保存:', key.trim());
            }
        },
        
        // 获取保存的密钥
        getSavedKey: function() {
            const savedKey = GM_getValue(this.STORAGE_KEY, '');
            return savedKey || CONFIG.DEFAULT_KEY;
        },
        
        // 清除保存的密钥
        clearKey: function() {
            GM_setValue(this.STORAGE_KEY, '');
            console.log('已清除保存的密钥');
        }
    };

    // 创建转换面板
    function createConverterPanel() {
        const panel = document.createElement('div');
        panel.id = 'rapidgator-converter';
        panel.innerHTML = `
            <div style="
                position: fixed;
                ${CONFIG.POSITION.includes('top') ? 'top: 20px;' : 'bottom: 20px;'}
                ${CONFIG.POSITION.includes('right') ? 'right: 20px;' : 'left: 20px;'}
                width: 320px;
                background: #fff;
                border: 2px solid #007bff;
                border-radius: 8px;
                box-shadow: 0 4px 12px rgba(0,0,0,0.15);
                z-index: 10000;
                font-family: Arial, sans-serif;
                font-size: 14px;
            ">
                <div style="
                    background: #007bff;
                    color: white;
                    padding: 12px;
                    border-radius: 6px 6px 0 0;
                    display: flex;
                    justify-content: space-between;
                    align-items: center;
                ">
                    <span style="font-weight: bold;">🚀 链接转换器</span>
                    <button id="close-converter" style="
                        background: none;
                        border: none;
                        color: white;
                        font-size: 18px;
                        cursor: pointer;
                        padding: 0;
                        width: 20px;
                        height: 20px;
                    ">×</button>
                </div>
                <div style="padding: 15px;">
                    <div style="margin-bottom: 12px;">
                        <label style="display: block; margin-bottom: 5px; font-weight: bold;">Key:</label>
                        <div style="display: flex; gap: 6px;">
                            <input type="text" id="converter-key" value="${KeyManager.getSavedKey()}" style="
                                flex: 1;
                                padding: 8px;
                                border: 1px solid #ddd;
                                border-radius: 4px;
                                box-sizing: border-box;
                            ">
                            <button id="clear-key-btn" title="清除保存的密钥" style="
                                padding: 8px 10px;
                                background: #6c757d;
                                color: white;
                                border: none;
                                border-radius: 4px;
                                cursor: pointer;
                                font-size: 12px;
                                font-weight: bold;
                            ">🗑️</button>
                            <button id="verify-key-btn" style="
                                padding: 8px 12px;
                                background: #ffc107;
                                color: #212529;
                                border: none;
                                border-radius: 4px;
                                cursor: pointer;
                                font-size: 12px;
                                font-weight: bold;
                                white-space: nowrap;
                            ">验证</button>
                        </div>
                        <div id="key-info" style="
                            margin-top: 3px;
                            font-size: 11px;
                            color: #666;
                            display: none;
                        "></div>
                        <div id="key-status" style="
                            margin-top: 5px;
                            font-size: 12px;
                            padding: 4px 8px;
                            border-radius: 3px;
                            display: none;
                        "></div>
                    </div>
                    <div style="margin-bottom: 12px;">
                        <label style="display: block; margin-bottom: 5px; font-weight: bold;">链接:</label>
                        <input type="text" id="converter-url" readonly style="
                            width: 100%;
                            padding: 8px;
                            border: 1px solid #ddd;
                            border-radius: 4px;
                            box-sizing: border-box;
                            background: #f8f9fa;
                        ">
                    </div>
                    <button id="convert-btn" style="
                        width: 100%;
                        padding: 10px;
                        background: #28a745;
                        color: white;
                        border: none;
                        border-radius: 4px;
                        cursor: pointer;
                        font-weight: bold;
                        margin-bottom: 10px;
                    ">转换链接</button>
                    <div id="result-area" style="
                        min-height: 60px;
                        padding: 10px;
                        background: #f8f9fa;
                        border-radius: 4px;
                        border: 1px solid #e9ecef;
                        display: none;
                    ">
                        <div id="result-content"></div>
                    </div>
                </div>
            </div>
        `;

        document.body.appendChild(panel);

        // 填充当前页面URL
        const urlInput = document.getElementById('converter-url');
        urlInput.value = window.location.href;

        // 绑定事件
        bindEvents();
        
        // 显示密钥信息
        updateKeyInfo();
        
        // 如果有保存的密钥且不是默认密钥,自动验证
        const savedKey = KeyManager.getSavedKey();
        if (savedKey && savedKey !== 'demo' && savedKey !== CONFIG.DEFAULT_KEY) {
            setTimeout(() => {
                verifyKey();
            }, 1000); // 延迟1秒自动验证
        }
    }

    // 绑定事件
    function bindEvents() {
        // 关闭按钮
        document.getElementById('close-converter').addEventListener('click', function() {
            document.getElementById('rapidgator-converter').style.display = 'none';
        });

        // 转换按钮
        document.getElementById('convert-btn').addEventListener('click', convertLink);

        // 验证密钥按钮
        document.getElementById('verify-key-btn').addEventListener('click', verifyKey);

        // 清除密钥按钮
        document.getElementById('clear-key-btn').addEventListener('click', function() {
            if (confirm('确定要清除保存的密钥吗?')) {
                KeyManager.clearKey();
                document.getElementById('converter-key').value = CONFIG.DEFAULT_KEY;
                clearKeyStatus();
                updateKeyInfo();
                showKeyStatus('已清除保存的密钥', 'info');
                setTimeout(() => {
                    clearKeyStatus();
                }, 2000);
            }
        });

        // 回车键转换
        document.getElementById('converter-key').addEventListener('keypress', function(e) {
            if (e.key === 'Enter') {
                convertLink();
            }
        });

        // Key输入框变化时清除状态
        document.getElementById('converter-key').addEventListener('input', function() {
            clearKeyStatus();
            updateKeyInfo();
        });
    }

    // 验证密钥
    function verifyKey() {
        const keyInput = document.getElementById('converter-key');
        const verifyBtn = document.getElementById('verify-key-btn');
        const keyStatus = document.getElementById('key-status');

        const key = keyInput.value.trim();

        if (!key) {
            showKeyStatus('请输入Key', 'error');
            return;
        }

        // 显示验证中状态
        verifyBtn.textContent = '验证中...';
        verifyBtn.disabled = true;
        showKeyStatus('正在验证密钥...', 'loading');

        // 方式1: 尝试发送一个测试转换请求来验证密钥
        const testUrl = 'https://rapidgator.net/file/test'; // 使用一个测试链接
        const formData = new FormData();
        formData.append('url', testUrl);
        
        const verifyUrl = `${CONFIG.SERVER_URL}/convert?key=${encodeURIComponent(key)}`;
        
        // 尝试直接请求验证
        fetch(verifyUrl, {
            method: 'POST',
            body: formData,
            mode: 'cors',
            headers: {
                'Content-Type': 'application/x-www-form-urlencoded'
            }
        }).catch(() => {
            // 如果fetch失败,使用GM_xmlhttpRequest
            return new Promise((resolve, reject) => {
                if (typeof GM_xmlhttpRequest !== 'undefined') {
                    GM_xmlhttpRequest({
                        method: 'POST',
                        url: verifyUrl,
                        data: new URLSearchParams(formData).toString(),
                        headers: {
                            'Content-Type': 'application/x-www-form-urlencoded'
                        },
                        onload: function(response) {
                            try {
                                const data = JSON.parse(response.responseText);
                                resolve({ 
                                    ok: true,
                                    json: () => Promise.resolve(data) 
                                });
                            } catch (e) {
                                resolve({
                                    ok: false,
                                    status: response.status,
                                    statusText: response.statusText
                                });
                            }
                        },
                        onerror: function() {
                            reject(new Error('请求失败'));
                        }
                    });
                } else {
                    reject(new Error('Tampermonkey API 不可用'));
                }
            });
        })
        .then(response => {
            if (response.ok) {
                return response.json();
            } else {
                throw new Error(`请求失败: ${response.status} ${response.statusText}`);
            }
        })
        .then(data => {
            // 分析API响应来判断密钥状态
            if (data.error) {
                if (data.error.includes('无效的密钥') || data.error.includes('invalid') || data.error.includes('key')) {
                    showKeyStatus('❌ 密钥无效或不存在', 'error');
                    // 显示购买提示
                    showPurchaseHint();
                    return;
                } else if (data.error.includes('无可用解析次数') || data.error.includes('次数')) {
                    // 密钥有效但无剩余次数
                    showKeyStatus(`⚠️ 密钥有效但无剩余次数`, 'warning');
                    // 显示购买提示
                    showPurchaseHint();
                    // 密钥有效,保存它
                    KeyManager.saveKey(key);
                    return;
                } else {
                    // 密钥有效,但可能是其他错误(如链接问题)
                    showKeyStatus('✅ 密钥有效 - 链接解析可能需要有效的Rapidgator链接', 'success');
                    // 密钥有效,保存它
                    KeyManager.saveKey(key);
                    return;
                }
            }
            
            // 如果有返回结果,说明密钥有效
            if (data.key && (data.total !== undefined || data.remaining !== undefined)) {
                const total = data.total || '未知';
                const used = data.used || '未知';
                const remaining = data.remaining !== undefined ? data.remaining : '未知';
                showKeyStatus(`✅ 密钥有效 - 总次数:${total} 已用:${used} 剩余:${remaining}`, 'success');
                // 验证成功后保存密钥
                KeyManager.saveKey(key);
            } else {
                showKeyStatus('✅ 密钥有效 - 服务器响应正常', 'success');
                // 验证成功后保存密钥
                KeyManager.saveKey(key);
            }
        })
        .catch(error => {
            console.error('验证失败:', error);
            showKeyStatus(`❌ ${error.message}`, 'error');
            // 网络错误或其他错误也显示购买提示,引导用户购买新密钥
            showPurchaseHint();
        })
        .finally(() => {
            verifyBtn.textContent = '验证';
            verifyBtn.disabled = false;
        });
    }

    // 从HTML中提取配额信息
    function extractQuotaFromHTML(html) {
        try {
            // 尝试匹配页面中可能包含的配额信息
            // 这可能需要根据实际页面结构调整
            const remainingMatch = html.match(/剩余[::]?\s*(\d+)/);
            const totalMatch = html.match(/总[配限额次数][::]?\s*(\d+)/);
            const usedMatch = html.match(/已用[::]?\s*(\d+)/);
            
            if (remainingMatch) {
                const remaining = parseInt(remainingMatch[1]);
                return {
                    remaining: remaining,
                    total: totalMatch ? parseInt(totalMatch[1]) : '未知',
                    used: usedMatch ? parseInt(usedMatch[1]) : '未知'
                };
            }
        } catch (e) {
            console.warn('解析配额信息失败:', e);
        }
        return null;
    }

    // 显示密钥状态
    function showKeyStatus(message, type) {
        const keyStatus = document.getElementById('key-status');
        keyStatus.textContent = message;
        keyStatus.style.display = 'block';

        // 根据类型设置样式
        switch (type) {
            case 'success':
                keyStatus.style.background = '#d4edda';
                keyStatus.style.color = '#155724';
                keyStatus.style.border = '1px solid #c3e6cb';
                break;
            case 'warning':
                keyStatus.style.background = '#fff3cd';
                keyStatus.style.color = '#856404';
                keyStatus.style.border = '1px solid #ffeaa7';
                break;
            case 'error':
                keyStatus.style.background = '#f8d7da';
                keyStatus.style.color = '#721c24';
                keyStatus.style.border = '1px solid #f5c6cb';
                break;
            case 'loading':
                keyStatus.style.background = '#d1ecf1';
                keyStatus.style.color = '#0c5460';
                keyStatus.style.border = '1px solid #bee5eb';
                break;
            case 'info':
                keyStatus.style.background = '#d4f6ff';
                keyStatus.style.color = '#004085';
                keyStatus.style.border = '1px solid #9fcdff';
                break;
            default:
                keyStatus.style.background = '#f8f9fa';
                keyStatus.style.color = '#495057';
                keyStatus.style.border = '1px solid #e9ecef';
        }
    }

    // 清除密钥状态
    function clearKeyStatus() {
        const keyStatus = document.getElementById('key-status');
        keyStatus.style.display = 'none';
    }

    // 更新密钥信息显示
    function updateKeyInfo() {
        const keyInfo = document.getElementById('key-info');
        const keyInput = document.getElementById('converter-key');
        const savedKey = GM_getValue(KeyManager.STORAGE_KEY, '');
        
        if (savedKey && keyInput && keyInput.value === savedKey) {
            keyInfo.textContent = '💾 使用已保存的密钥';
            keyInfo.style.display = 'block';
        } else if (savedKey) {
            keyInfo.textContent = '💾 有保存的密钥,当前使用其他密钥';
            keyInfo.style.display = 'block';
        } else {
            keyInfo.style.display = 'none';
        }
    }

    // 转换链接
    function convertLink() {
        const keyInput = document.getElementById('converter-key');
        const urlInput = document.getElementById('converter-url');
        const convertBtn = document.getElementById('convert-btn');
        const resultArea = document.getElementById('result-area');
        const resultContent = document.getElementById('result-content');

        const key = keyInput.value.trim();
        const url = urlInput.value.trim();

        if (!key) {
            showResult('错误:请输入 Key', 'error');
            return;
        }

        if (!url) {
            showResult('错误:链接为空', 'error');
            return;
        }

        // 显示加载状态
        convertBtn.textContent = '转换中...';
        convertBtn.disabled = true;
        showResult('正在转换链接,请稍候...', 'loading');

        // 发送转换请求
        const formData = new FormData();
        formData.append('url', url);

        // 尝试直接请求,如果失败则使用CORS代理
        const requestUrl = `${CONFIG.SERVER_URL}/convert?key=${encodeURIComponent(key)}`;
        
        fetch(requestUrl, {
            method: 'POST',
            body: formData,
            mode: 'cors',
            headers: {
                'Content-Type': 'application/x-www-form-urlencoded'
            }
        }).then(response => {
            // 处理HTTP错误状态码
            if (!response.ok) {
                return response.json().then(errorData => {
                    throw new Error(`HTTP ${response.status}: ${errorData.error || '请求失败'}`);
                }).catch(() => {
                    throw new Error(`HTTP ${response.status}: 请求失败`);
                });
            }
            return response.json();
        }).catch(() => {
            // 如果fetch失败,使用GM_xmlhttpRequest
            showResult('使用Tampermonkey内置请求...', 'loading');
            return new Promise((resolve, reject) => {
                if (typeof GM_xmlhttpRequest !== 'undefined') {
                    GM_xmlhttpRequest({
                        method: 'POST',
                        url: requestUrl,
                        data: new URLSearchParams(formData).toString(),
                        headers: {
                            'Content-Type': 'application/x-www-form-urlencoded'
                        },
                        onload: function(response) {
                            try {
                                const data = JSON.parse(response.responseText);
                                // 检查HTTP状态码
                                if (response.status >= 400) {
                                    reject(new Error(`HTTP ${response.status}: ${data.error || '请求失败'}`));
                                    return;
                                }
                                resolve(data);
                            } catch (e) {
                                if (response.status >= 400) {
                                    reject(new Error(`HTTP ${response.status}: 请求失败`));
                                } else {
                                    reject(new Error('解析响应失败'));
                                }
                            }
                        },
                        onerror: function() {
                            reject(new Error('请求失败'));
                        }
                    });
                } else {
                    reject(new Error('Tampermonkey API 不可用'));
                }
            });
        })
        .then(data => {
            handleConvertResponse(data);
        })
        .catch(error => {
            console.error('转换失败:', error);
            showResult(`网络错误: ${error.message}`, 'error');
        })
        .finally(() => {
            convertBtn.textContent = '转换链接';
            convertBtn.disabled = false;
        });
    }

    // 处理转换响应
    function handleConvertResponse(data) {
        if (data.error) {
            // 检查是否是次数耗尽错误或无效密钥错误
            if (data.error.includes('无可用解析次数') || data.error.includes('次数') || 
                data.error.includes('无效的密钥') || data.error.includes('invalid') || data.error.includes('key')) {
                showResult(`错误: ${data.error}`, 'error');
                showPurchaseHint();
            } else {
                showResult(`错误: ${data.error}`, 'error');
            }
            return;
        }

        if (!data.results || data.results.length === 0) {
            showResult('没有找到转换结果', 'error');
            return;
        }

        const result = data.results[0];
        if (result.direct_link) {
            // 转换成功,保存密钥
            const keyInput = document.getElementById('converter-key');
            if (keyInput && keyInput.value.trim()) {
                KeyManager.saveKey(keyInput.value.trim());
            }
            
            const resultHtml = `
                <div style="margin-bottom: 10px;">
                    <strong style="color: #28a745;">✅ 转换成功!</strong>
                </div>
                <div style="margin-bottom: 10px;">
                    <strong>直链:</strong><br>
                    <a href="${result.direct_link}" target="_blank" style="
                        color: #007bff;
                        text-decoration: underline;
                        word-break: break-all;
                        display: inline-block;
                        margin-top: 5px;
                        padding: 8px;
                        background: #e7f3ff;
                        border-radius: 5px;
                        width: 100%;
                        box-sizing: border-box;
                        border: 2px solid #007bff;
                        transition: all 0.2s ease;
                    " onmouseover="this.style.background='#cce7ff'; this.style.transform='scale(1.02)'" 
                       onmouseout="this.style.background='#e7f3ff'; this.style.transform='scale(1)'">${result.direct_link}</a>
                </div>
                <div style="
                    margin: 10px 0;
                    padding: 8px;
                    background: #fff3cd;
                    border: 1px solid #ffeaa7;
                    border-radius: 4px;
                    color: #856404;
                    font-size: 12px;
                    text-align: center;
                ">
                    � <strong>提示:</strong> 点击上方蓝色直链即可下载文件
                </div>
                ${result.filename ? `<div><strong>文件名:</strong> ${result.filename}</div>` : ''}
                ${result.size ? `<div><strong>大小:</strong> ${result.size}</div>` : ''}
                ${data.remaining !== undefined ? `<div style="margin-top: 10px; color: #666;"><strong>剩余次数:</strong> ${data.remaining}</div>` : ''}
            `;
            showResult(resultHtml, 'success');
        } else if (result.error) {
            showResult(`转换失败: ${result.error}`, 'error');
        } else {
            showResult('转换失败: 未知错误', 'error');
        }
    }

    // 显示结果
    function showResult(content, type) {
        const resultArea = document.getElementById('result-area');
        const resultContent = document.getElementById('result-content');
        
        resultContent.innerHTML = content;
        resultArea.style.display = 'block';

        // 根据类型设置样式
        switch (type) {
            case 'success':
                resultArea.style.background = '#d4edda';
                resultArea.style.borderColor = '#c3e6cb';
                break;
            case 'error':
                resultArea.style.background = '#f8d7da';
                resultArea.style.borderColor = '#f5c6cb';
                break;
            case 'loading':
                resultArea.style.background = '#d1ecf1';
                resultArea.style.borderColor = '#bee5eb';
                break;
            default:
                resultArea.style.background = '#f8f9fa';
                resultArea.style.borderColor = '#e9ecef';
        }
    }



    // 检测页面是否加载完成
    function init() {
        if (document.readyState === 'loading') {
            document.addEventListener('DOMContentLoaded', createConverterPanel);
        } else {
            createConverterPanel();
        }
    }

    // 初始化
    init();

    // 添加样式优化
    const style = document.createElement('style');
    style.textContent = `
        #rapidgator-converter button:hover:not(:disabled) {
            opacity: 0.9;
            transform: translateY(-1px);
        }
        #rapidgator-converter button:disabled {
            opacity: 0.6;
            cursor: not-allowed;
        }
        #rapidgator-converter input:focus {
            outline: none;
            border-color: #007bff;
            box-shadow: 0 0 0 2px rgba(0,123,255,0.25);
        }
        #verify-key-btn:hover:not(:disabled) {
            background: #e0a800 !important;
        }
        #clear-key-btn:hover:not(:disabled) {
            background: #5a6268 !important;
        }
        #key-status {
            transition: all 0.3s ease;
            animation: fadeIn 0.3s ease;
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(-5px); }
            to { opacity: 1; transform: translateY(0); }
        }
    `;
    document.head.appendChild(style);

    // 显示购买提示
    function showPurchaseHint() {
        // 获取转换面板的位置信息
        const converterPanel = document.getElementById('rapidgator-converter');
        const panelRect = converterPanel.getBoundingClientRect();
        
        // 计算提示框的位置
        let topPosition, leftPosition;
        if (CONFIG.POSITION.includes('top')) {
            topPosition = panelRect.bottom + 10; // 面板下方10px
        } else {
            topPosition = panelRect.top - 280; // 面板上方(估计提示框高度280px)
        }
        
        if (CONFIG.POSITION.includes('right')) {
            leftPosition = panelRect.right - 320; // 与面板右对齐
        } else {
            leftPosition = panelRect.left; // 与面板左对齐
        }
        
        // 确保不超出屏幕边界
        const maxTop = window.innerHeight - 300;
        const maxLeft = window.innerWidth - 340;
        topPosition = Math.min(Math.max(10, topPosition), maxTop);
        leftPosition = Math.min(Math.max(10, leftPosition), maxLeft);
        
        // 创建购买提示弹窗
        const hintDiv = document.createElement('div');
        hintDiv.id = 'purchase-hint';
        hintDiv.innerHTML = `
            <div style="
                position: fixed;
                top: ${topPosition}px;
                left: ${leftPosition}px;
                background: #fff;
                border: 3px solid #ff6b35;
                border-radius: 12px;
                box-shadow: 0 8px 25px rgba(0,0,0,0.3);
                z-index: 20000;
                font-family: Arial, sans-serif;
                width: 320px;
            ">
                <div style="
                    background: linear-gradient(135deg, #ff6b35, #f7931e);
                    color: white;
                    padding: 15px;
                    border-radius: 9px 9px 0 0;
                    text-align: center;
                    font-weight: bold;
                    font-size: 16px;
                ">
                    🛒 密钥次数已用完
                </div>
                <div style="padding: 20px; text-align: center;">
                    <div style="margin-bottom: 15px; font-size: 14px; color: #333;">
                        您的密钥使用次数已耗尽,请前往闲鱼购买新的卡密
                    </div>
                    <div style="margin: 15px 0;">
                        <a href="${CONFIG.XIANYU_URL}" target="_blank" style="
                            display: inline-block;
                            text-decoration: none;
                            transition: transform 0.2s ease;
                        " onmouseover="this.style.transform='scale(1.1)'" onmouseout="this.style.transform='scale(1)'">
                            <div style="
                                width: 60px;
                                height: 60px;
                                border-radius: 12px;
                                box-shadow: 0 4px 12px rgba(0,0,0,0.2);
                                border: 2px solid #ff6b35;
                                background: white;
                                display: flex;
                                align-items: center;
                                justify-content: center;
                                overflow: hidden;
                            ">
                                <img src="${CONFIG.XIANYU_LOGO}" alt="闲鱼" style="
                                    width: 50px;
                                    height: 50px;
                                    object-fit: contain;
                                ">
                            </div>
                        </a>
                    </div>
                    <div style="margin-bottom: 15px; font-size: 12px; color: #666;">
                        点击上方logo前往闲鱼店铺购买
                    </div>
                    <div style="display: flex; gap: 10px; justify-content: center;">
                        <button onclick="window.open('${CONFIG.XIANYU_URL}', '_blank')" style="
                            padding: 8px 15px;
                            background: #ff6b35;
                            color: white;
                            border: none;
                            border-radius: 5px;
                            cursor: pointer;
                            font-size: 12px;
                            font-weight: bold;
                        ">前往闲鱼</button>
                        <button onclick="document.getElementById('purchase-hint').remove()" style="
                            padding: 8px 15px;
                            background: #6c757d;
                            color: white;
                            border: none;
                            border-radius: 5px;
                            cursor: pointer;
                            font-size: 12px;
                        ">关闭</button>
                    </div>
                </div>
            </div>
        `;
        
        // 移除已存在的提示
        const existing = document.getElementById('purchase-hint');
        if (existing) {
            existing.remove();
        }
        
        document.body.appendChild(hintDiv);
        
        // 10秒后自动关闭
        setTimeout(() => {
            if (document.getElementById('purchase-hint')) {
                document.getElementById('purchase-hint').remove();
            }
        }, 10000);
    }

})();