Skip to content

Latest commit

 

History

History
 
 

Folders and files

NameName
Last commit message
Last commit date
 
 

README.md

Google-Drive-View-Only-PDF-Script-Downloader

Here you can use this script to download view only pdf file from Google Drive. This script works like a screenshot capturing all pdf pages to bulk of images with better resolution quality and combine it all into one pdf file.

Big-Note: Use this script wisely!

Instruction

  1. Open the PDF from Google Drive,
  2. Click Preview,
  3. Then on top right page click on three vertical dots menu -> Open in new window,
  4. Scroll down pdf to end of content and make sure all of content is loaded,
  5. Inspect element your browser,
  6. Copy and paste script below on console tab,
    (function () {
      console.log("Loading script ...");
    
      let script = document.createElement("script");
      script.onload = function () {
        const { jsPDF } = window.jspdf;
    
        // Generate a PDF from images with "blob:" sources.
        let pdf = null;
        let imgElements = document.getElementsByTagName("img");
        let validImgs = [];
        let initPDF = true;
    
        console.log("Scanning content ...");
        for (let i = 0; i < imgElements.length; i++) {
          let img = imgElements[i];
    
          let checkURLString = "blob:https://drive.google.com/";
          if (img.src.substring(0, checkURLString.length) !== checkURLString) {
            continue;
          }
    
          //   if (!/^blob:/.test(img.src)) {
          //     continue;
          //   }
    
          validImgs.push(img);
        }
    
        console.log(`${validImgs.length} content found!`);
        console.log("Generating PDF file ...");
        for (let i = 0; i < validImgs.length; i++) {
          let img = validImgs[i];
          let canvasElement = document.createElement("canvas");
          let con = canvasElement.getContext("2d");
          canvasElement.width = img.naturalWidth;
          canvasElement.height = img.naturalHeight;
          con.drawImage(img, 0, 0, img.naturalWidth, img.naturalHeight);
          let imgData = canvasElement.toDataURL();
    
          let orientation;
          if (img.naturalWidth > img.naturalHeight) {
            //console.log("Landscape");
            orientation = "l";
            //ratio = img.naturalWidth/img.naturalHeight
          } else {
            //console.log("Portrait");
            orientation = "p";
            //ratio = img.naturalWidth/img.naturalHeight
          }
    
          let pageWidth = img.naturalWidth;
          let pageHeight = img.naturalHeight;
    
          if (initPDF) {
            pdf = new jsPDF({
              orientation: orientation,
              unit: "px",
              format: [pageWidth, pageHeight],
            });
            initPDF = false;
          }
    
          if (!initPDF) {
            pdf.addImage(imgData, "PNG", 0, 0, pageWidth, pageHeight, "", "SLOW");
            if (i !== validImgs.length - 1) {
              pdf.addPage();
            }
          }
    
          const percentages = Math.floor(((i + 1) / validImgs.length) * 100);
          console.log(`Processing content ${percentages}%`);
        }
    
        // check if title contains .pdf in end of the title
        // Use optional chaining to avoid errors if the meta tag isn't present.
        // Fall back to document.title when necessary. Note: if the PDF is inside a cross-origin iframe,
        // parent scripts cannot access the iframe document due to same-origin policy.
        let title = document.querySelector('meta[itemprop="name"]')?.content || document.title || 'download.pdf';
        if ((title.split(".").pop() || "").toLowerCase() !== "pdf") {
          title = title + ".pdf";
        }
    
        // Download the generated PDF.
        console.log("Downloading PDF file ...");
        pdf.save(title, { returnPromise: true }).then(() => {
          document.body.removeChild(script);
          console.log("PDF downloaded!");
        });
      };
    
      // Load the jsPDF library using the trusted URL.
      let scriptURL = "https://unpkg.com/jspdf@latest/dist/jspdf.umd.min.js";
      let trustedURL;
      if (window.trustedTypes && trustedTypes.createPolicy) {
        const policy = trustedTypes.createPolicy("myPolicy", {
          createScriptURL: (input) => {
            return input;
          },
        });
        trustedURL = policy.createScriptURL(scriptURL);
      } else {
        trustedURL = scriptURL;
      }
    
      script.src = trustedURL;
      document.body.appendChild(script);
    })();
  7. Wait script processing and downloading pdf file,
  8. Fast or slow pdf processing based on the pdf content it self,
  9. Enjoyy....

Source Reference

This script is modified with source from :