NSFC_conclusion_downloader

帮助你直接下载国自然结题报告

目前为 2021-02-05 提交的版本。查看 最新版本

// ==UserScript==
// @name         NSFC_conclusion_downloader
// @namespace    https://blog.rhilip.info/
// @version      0.3
// @description  帮助你直接下载国自然结题报告
// @author       Rhilip
// @match        http://output.nsfc.gov.cn/conclusionProject/*
// @require      https://unpkg.com/axios/dist/axios.min.js
// @require      https://unpkg.com/jspdf@latest/dist/jspdf.umd.min.js
// ==/UserScript==

(function() {
    'use strict';

    // 加载图片获得图片的width, height 属性
    function asyncImageLoader(url){
        return new Promise((resolve, reject) => {
            var image = new Image();
            image.src = url;
            image.onload = () => resolve(image);
            image.onerror = () => reject(new Error('could not load image'));
        })
    }

    const conclusionReportTab = $('#conclusion-report-tab'); // 定位结题报告窗口
    const downloadBtn = $('<button id="download_report" type="button" class="btn btn-link pull-right text-nowrap">(下载全文PDF)</button>'); // 准备交互按钮
    conclusionReportTab.before(downloadBtn); // 添加交互按钮

    downloadBtn.click((async () => {
        downloadBtn.prop('disabled', true);
        if (!/该项目暂无结题报告/.test(conclusionReportTab.text())) {
            // 获得项目信息: 编号(加密后)、批准号、项目名称
            const dependUintID = location.pathname.match(/conclusionProject\/(.+)/)[1];
            const projectID = $('#basic-tab > div:nth-child(1) > div.col-md-10').text();
            const projectName = $('#basic-tab > div:nth-child(2) > div.col-md-10').text();

            const { jsPDF } = jspdf; // 从 jspdf 库中获得jsPDF
            const doc = new jsPDF(); // 准备 jsPDF 对象
            doc.deletePage(1); // 删除第一页

            // 核心下载方法
            let i = 1;
            let should_loop = true;
            while (should_loop) {
                downloadBtn.text(`正在下载第 ${i} 页`);
                const postData = new URLSearchParams({id: dependUintID, index: i});
                const req = await axios.post('http://output.nsfc.gov.cn/baseQuery/data/completeProjectReport', postData);
                const image = await asyncImageLoader(req.data.data.url);
                doc.addPage([image.width, image.height], image.width < image.height ? 'p' : 'l');
                doc.addImage(image, "JPEG", 0, 0, image.width, image.height);

                should_loop = req.data.data.hasnext !== false;
                i++;
            }

            // 我们并没法 await 保存过程,所以直接显示下载完成就好,浏览器处理好会自动显示下载文件
            doc.save(`${projectID} ${projectName}.pdf`);
            downloadBtn.text('下载完成');
        }
    }))
})();

QingJ © 2025

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