专利通知书下载器

用来下载专利局中国及多国专利审查信息查询系统的通知书

// ==UserScript==
// @name         专利通知书下载器
// @namespace    http://patenthomes.com
// @version      0.9
// @icon         
// @description  用来下载专利局中国及多国专利审查信息查询系统的通知书
// @author       北溟之鲲
// @match        *://cpquery.cponline.cnipa.gov.cn/*
// @grant        none
// @require https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js
// @license      MIT
// ==/UserScript==


(function() {
    'use strict';


    //恢复PDF格式通知书工具栏的下载按钮及其他按钮,且插入一个提取文件名的按钮,用来提取申请号和通知书名称并组合在一起作为文件名

    //恢复PDF格式通知书工具栏的下载按钮及其他按钮
    // Define the CSS selector for the elements you want to modify
    const targetSelector = '#download,#presentationMode,#viewFind,#print,#viewBookmark,#secondaryToolbarToggle,#openFile'; // Replace with your actual selector
    // Get all matching elements
    const elements = document.querySelectorAll(targetSelector);
    // Loop through each element and change its display property
    elements.forEach(element => {
        element.style.display = 'block';
    });

    //在通知书为PDF格式时,插入一个按钮,用来查看通知书的收件人信息
    //标记提取按钮未插入
    let viewbuttonInserted = false;
    //设定查看按钮相关的函数
    function checkIframe() {

        // 判断网页中是否存在iframe标签
        const iframes = document.querySelectorAll('#q-app > div > div > div.q-page-container > main > div > div.content > div.row.boxRow > div.table > div > div.tableList > div:nth-child(2) > div > div > div > div > iframe');

        //如果存在iframe标签且未插入提取按钮,则插入提取按钮
        if (iframes.length > 0 && !viewbuttonInserted) {

            // 创建下载按钮
            const viewButton = document.createElement('button');
            // 给按钮一个唯一的ID以便于识别和删除
            viewButton.id = 'myviewButton';
            // 按钮属性
            viewButton.textContent = '查看收件人信息';
            viewButton.style.position = 'fixed';
            viewButton.style.top = '80px';
            viewButton.style.right = '20px';
            //viewButton.style.transform = 'translateY(-50%)';
            viewButton.style.zIndex = '10000';
            //viewButton.style.backgroundColor = '#4CAF50';
            //viewButton.style.border = 'none';
            //viewButton.style.borderRadius = '5px';
            //viewButton.style.color = 'white';
            //viewButton.style.fontSize = '16px';
            //viewButton.style.padding = '2px 2px';
            viewButton.style.cursor = 'pointer';
            document.body.appendChild(viewButton);

            // 标记已插入按钮
            viewbuttonInserted = true;

            // 设置按钮动作
            viewButton.addEventListener('click', async () => {
                // 遍历所有iframe元素
                for (var i = 0; i < iframes.length; i++) {
                    // 获取iframe子页面的内容
                    var iframeContent = iframes[i].contentDocument;
                    // 获取收件人相关的信息
                    var value1 = iframeContent.querySelector('#viewer > div:nth-child(1) > div.textLayer > span:nth-child(10)').textContent;
                    var value2 = iframeContent.querySelector('#viewer > div:nth-child(1) > div.textLayer > span:nth-child(11)').textContent;
                    var value3 = iframeContent.querySelector('#viewer > div:nth-child(1) > div.textLayer > span:nth-child(12)').textContent;
                    var value4 = iframeContent.querySelector('#viewer > div:nth-child(1) > div.textLayer > span:nth-child(13)').textContent;
                    var value5 = iframeContent.querySelector('#viewer > div:nth-child(1) > div.textLayer > span:nth-child(14)').textContent;

                    // 创建弹出窗口并输出过滤后的值
                    var popupWindow = window.open('', 'popupWindow', 'width=800,height=500');
                    popupWindow.document.write('收件人信息: ' + '</p>');
                    popupWindow.document.write(value1 + '</p>');
                    popupWindow.document.write(value2 + '</p>');
                    popupWindow.document.write(value3 + '</p>');
                    popupWindow.document.write(value4 + '</p>');
                    popupWindow.document.write(value5 + '</p>');
                }
             });

         } else if (iframes.length == 0 && viewbuttonInserted) {
            // 如果选择器不存在且按钮已插入,删除按钮
            const viewbuttonToRemove = document.getElementById('myviewButton');
            if (viewbuttonToRemove) {
                viewbuttonToRemove.remove();
            }
            viewbuttonInserted = false;
        }
        // 无论是否插入或删除按钮,都在1秒后再次检查
        setTimeout(checkIframe, 1000);
    }

    // 首次调用函数
    checkIframe();


    // 监听是否点击了下载按钮
    document.addEventListener('click', function(e) {

        // 检查点击的元素是否为下载链接
        var target = e.target;
        //如果是下载链接,且下载链接为blob格式
        if (target.tagName === 'A' && target.href.startsWith('blob:')) {
            // 获取申请号
            const selector1 = window.parent.document.querySelector('#q-app > div > div > div.q-page-container > main > div > div.content > div.hm > strong').textContent.match(/\d+/).join('');
            // 获取通知书名称
            const selector2 = window.parent.document.querySelector('#q-app > div > div > div.q-page-container > main > div > div.content > div.row.boxRow > div.table > div > div:nth-child(1) > p').textContent.replace(/-/g, '').replace(/\[.*?\]/g, '').replace(/首页/g, '').match(/[\u4e00-\u9fa5-zA-Z]+/g).join('');
            // 合申请号和通知书名称作为文件名称
            const newFileName = `${selector1}-${selector2}`;
            //用输入的文件名对下载的文件命名
            target.download = newFileName || '专利通知书';

        }
    });


    //下载图片格式通知书并合并成PDF

    // 标记是否已插入按钮
    let buttonInserted = false;

    function checkSelector() {

        // 判断是否存在图片格式通知书
        const selectorExists = document.querySelector('#q-app > div > div > div.q-page-container > main > div > div.content > div.row.boxRow > div.table > div > div:nth-child(2) > div:nth-child(2) > div > div > div:nth-child(1) > img');

        //如果存在图片格式通知书且未插入按钮,则插入下载按钮
        if (selectorExists && !buttonInserted) {
            // 创建下载按钮
            const downloadButton = document.createElement('button');
            // 给按钮一个唯一的ID以便于识别和删除
            downloadButton.id = 'myCustomButton';
            // 按钮属性
            downloadButton.textContent = '下载通知书';
            downloadButton.style.position = 'fixed';
            downloadButton.style.top = '80px';
            downloadButton.style.right = '20px';
            //downloadButton.style.transform = 'translateY(-50%)';
            downloadButton.style.zIndex = '10000';
            //downloadButton.style.backgroundColor = '#4CAF50';
            //downloadButton.style.border = 'none';
            //downloadButton.style.borderRadius = '5px';
            //downloadButton.style.color = 'white';
            //downloadButton.style.fontSize = '16px';
            //downloadButton.style.padding = '2px 2px';
            downloadButton.style.cursor = 'pointer';
            document.body.appendChild(downloadButton);
            // 标记已插入按钮
            buttonInserted = true;

            // 设置按钮动作
            downloadButton.addEventListener('click', async () => {
                // 找到所有通知书图片
                const pngImages = document.querySelectorAll('#q-app > div > div > div.q-page-container > main > div > div.content > div.row.boxRow > div.table > div > div:nth-child(2) > div:nth-child(2) > div > div > div > img');
                // 提取页面上的申请号和通知书名称
                const filename1 = document.querySelector('#q-app > div > div > div.q-page-container > main > div > div.content > div.hm > strong').textContent.match(/\d+/).join('');
                const filename2 = document.querySelector('#q-app > div > div > div.q-page-container > main > div > div.content > div.row.boxRow > div.table > div > div:nth-child(1) > p').textContent.replace(/-/g, '').replace(/\[.*?\]/g, '').replace(/首页/g, '').match(/[\u4e00-\u9fa5-zA-Z]+/g).join('');
                // 执行合并为PDF的函数
                imagesToPDF(pngImages, filename1, filename2);

            });

        } else if (!selectorExists && buttonInserted) {
            // 如果选择器不存在且按钮已插入,删除按钮
            const buttonToRemove = document.getElementById('myCustomButton');
            if (buttonToRemove) {
                buttonToRemove.remove();
            }
            buttonInserted = false;
        }
        // 无论是否插入或删除按钮,都在1秒后再次检查
        setTimeout(checkSelector, 1000);
    }

    // 首次调用函数
    checkSelector();

    // 将所有加载的通知书图片合并为PDF
    async function imagesToPDF(srcList, filename1, filename2) {
       const pdf = new jspdf.jsPDF({ unit: 'px' });
       for (let i = 0; i < srcList.length; i++) {
         const imgSrc = srcList[i].src;
         try {
           const img = new Image();
           img.src =imgSrc;
           const pageWidth = pdf.internal.pageSize.getWidth();
           const pageHeight = pdf.internal.pageSize.getHeight();
           const imgAspectRatio = img.width / img.height;
           let imgWidth = pageWidth;
           let imgHeight = pageWidth / imgAspectRatio;
           pdf.addImage(img, 'PNG', 0, 0, imgWidth, imgHeight);
             if (i < srcList.length - 1) {
               pdf.addPage();
             }
        } catch (error) {
             console.error(`图片加载失败:${imgSrc}`, error);
        }
        }
      pdf.save(`${filename1}-${filename2}.pdf`);
    }


})();