Greasy Fork

Greasy Fork is available in English.

专利通知书下载器

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

当前为 2024-03-09 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         专利通知书下载器
// @namespace    http://patenthomes.com
// @version      0.6
// @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==


//恢复PDF格式通知书下载按钮
(function() {
    'use strict';

    // 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
(function() {
  'use strict';

    // 标记是否已插入按钮
    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, '').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`);
    }

})();