created a PoC for the client

This commit is contained in:
Saud Fatayerji 2023-10-26 23:41:48 +03:00
parent 13c4f664c2
commit 6d505715e0
16 changed files with 168 additions and 90 deletions

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
node_modules/ node_modules/
*.code-workspace *.code-workspace
.idea/

View File

@ -0,0 +1,53 @@
declare module '@stirling-pdf/shared-operations/functions/editMetadata' {
export type Metadata = {
Title: string | null | undefined; // The title of the document.
Author: string | null | undefined; // The author of the document.
Subject: string | null | undefined; // The subject of the document.
Keywords: string[] | null | undefined; // An array of keywords associated with the document.
Producer: string | null | undefined; // The producer of the document.
Creator: string | null | undefined; // The creator of the document.
CreationDate: Date | null | undefined; // The date when the document was created.
ModificationDate: Date | null | undefined; // The date when the document was last modified.
}
export async function editMetadata(snapshot: string | Uint8Array | ArrayBuffer, metadata: Metadata): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/extractPages' {
export async function extractPages(snapshot: string | Uint8Array | ArrayBuffer, pagesToExtractArray: number[]): Promise<Uint8Array>;
export async function createSubDocument(pdfDoc: typeof import("pdf-lib").PDFDocument, pagesToExtractArray: number[])
}
declare module '@stirling-pdf/shared-operations/functions/mergePDFs' {
export async function mergePDFs(snapshots: (string | Uint8Array | ArrayBuffer)[]): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/organizePages' {
export async function organizePages(
snapshot: string | Uint8Array | ArrayBuffer,
operation: "CUSTOM_PAGE_ORDER" |
"REVERSE_ORDER" |
"DUPLEX_SORT" |
"BOOKLET_SORT" |
"ODD_EVEN_SPLIT" |
"REMOVE_FIRST" |
"REMOVE_LAST" |
"REMOVE_FIRST_AND_LAST",
customOrderString: string): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/rotatePages' {
export async function rotatePages(snapshot: string | Uint8Array | ArrayBuffer, rotation: number): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/scaleContent' {
export async function scaleContent(snapshot: string | Uint8Array | ArrayBuffer, scaleFactor: number): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/scalePage' {
export async function scalePage(snapshot: string | Uint8Array | ArrayBuffer, pageSize: {width:number,height:number}): Promise<Uint8Array>;
}
declare module '@stirling-pdf/shared-operations/functions/splitPDF' {
export async function splitPDF(snapshot: string | Uint8Array | ArrayBuffer, splitAfterPageArray: number[]): Promise<Uint8Array>;
}

View File

@ -17,14 +17,15 @@
"@capawesome/capacitor-file-picker": "^5.1.1", "@capawesome/capacitor-file-picker": "^5.1.1",
"@ionic/react": "^7.0.0", "@ionic/react": "^7.0.0",
"@ionic/react-router": "^7.0.0", "@ionic/react-router": "^7.0.0",
"@stirling-pdf/shared-operations": "*",
"@types/react-router": "^5.1.20", "@types/react-router": "^5.1.20",
"@types/react-router-dom": "^5.3.3", "@types/react-router-dom": "^5.3.3",
"ionicons": "^7.0.0", "ionicons": "^7.0.0",
"pdf-lib": "^1.17.1",
"react": "^18.2.0", "react": "^18.2.0",
"react-dom": "^18.2.0", "react-dom": "^18.2.0",
"react-router": "^5.3.4", "react-router": "^5.3.4",
"react-router-dom": "^5.3.4", "react-router-dom": "^5.3.4"
"@stirling-pdf/shared-operations": "*"
}, },
"devDependencies": { "devDependencies": {
"@testing-library/jest-dom": "^5.16.5", "@testing-library/jest-dom": "^5.16.5",

View File

@ -1,23 +1,28 @@
import { IonContent, IonHeader, IonPage, IonTitle, IonToolbar, IonButton } from '@ionic/react'; import { IonContent, IonHeader, IonPage, IonTitle, IonToolbar, IonButton } from '@ionic/react';
import ExploreContainer from '../components/ExploreContainer';
import './Home.css'; import './Home.css';
import "../../../server-node/public/wasm/pdfcpu-wrapper-browser.js" import { rotatePages } from '../utils/pdf-operations.js';
import { splitPDF } from '../utils/pdf-operations.js';
import { FilePicker } from '@capawesome/capacitor-file-picker'; import { FilePicker } from '@capawesome/capacitor-file-picker';
async function testFunction() { console.log(rotatePages);
console.log("Test Function for Button Click"); async function rotate90() {
console.log(splitPDF); console.log("Test rotate 90 with Button Click");
const result = await FilePicker.pickFiles({ const pickedFiles = await FilePicker.pickFiles({
types: ['application/pdf'], types: ['application/pdf'],
multiple: true, multiple: false,
}); });
const file = pickedFiles.files[0];
console.log(result); const buffer = await file.blob?.arrayBuffer();
if (!buffer) return;
const rotated = await rotatePages(buffer, 90)
console.log(rotated);
} }
const Home: React.FC = () => { const Home: React.FC = () => {
return ( return (
<IonPage> <IonPage>
@ -32,7 +37,7 @@ const Home: React.FC = () => {
<IonTitle size="large">Blank</IonTitle> <IonTitle size="large">Blank</IonTitle>
</IonToolbar> </IonToolbar>
</IonHeader> </IonHeader>
<IonButton onClick={testFunction}>Default</IonButton> <IonButton onClick={rotate90}>Rotate 90</IonButton>
</IonContent> </IonContent>
</IonPage> </IonPage>
); );

View File

@ -1,48 +0,0 @@
// PDFLib gets importet via index.html script-tag
import * as pdfcpuWraopper from "../../../server-node/public/wasm/pdfcpu-wrapper-browser.js";
import { editMetadata as dependantEditMetadata} from "@stirling-pdf/shared-operations/functions/editMetadata.js";
import { extractPages as dependantExtractPages } from "@stirling-pdf/shared-operations/functions/extractPages.js";
import { impose as dependantImpose } from '@stirling-pdf/shared-operations/functions/impose.js';
import { mergePDFs as dependantMergePDFs } from '@stirling-pdf/shared-operations/functions/mergePDFs.js';
import { organizePages as dependantOrganizePages } from '@stirling-pdf/shared-operations/functions/organizePages.js';
import { rotatePages as dependantRotatePages } from '@stirling-pdf/shared-operations/functions/rotatePages.js';
import { scaleContent as dependantScaleContent} from '@stirling-pdf/shared-operations/functions/scaleContent.js';
import { scalePage as dependantScalePage } from '@stirling-pdf/shared-operations/functions/scalePage.js';
import { splitPDF as dependantSplitPDF } from '@stirling-pdf/shared-operations/functions/splitPDF.js';
export async function editMetadata(snapshot, metadata) {
return dependantEditMetadata(snapshot, metadata, PDFLib);
}
export async function extractPages(snapshot, pagesToExtractArray) {
return dependantExtractPages(snapshot, pagesToExtractArray, PDFLib);
}
export async function impose(snapshot, nup, format) {
return dependantImpose(snapshot, nup, format, pdfcpuWraopper);
}
export async function mergePDFs(snapshots) {
return dependantMergePDFs(snapshots, PDFLib);
}
export async function organizePages(snapshot, operation, customOrderString) {
return dependantOrganizePages(snapshot, operation, customOrderString, PDFLib);
}
export async function rotatePages(snapshot, rotation) {
return dependantRotatePages(snapshot, rotation, PDFLib);
}
export async function scaleContent(snapshot, scaleFactor) {
return dependantScaleContent(snapshot, scaleFactor, PDFLib);
}
export async function scalePage(snapshot, pageSize) {
return dependantScalePage(snapshot, pageSize, PDFLib);
}
export async function splitPDF(snapshot, splitAfterPageArray) {
return dependantSplitPDF(snapshot, splitAfterPageArray, PDFLib);
}

View File

@ -0,0 +1,53 @@
// Import injected libraries here!
import { Metadata, editMetadata as dependantEditMetadata} from "@stirling-pdf/shared-operations/functions/editMetadata";
import { extractPages as dependantExtractPages } from "@stirling-pdf/shared-operations/functions/extractPages";
import { mergePDFs as dependantMergePDFs } from '@stirling-pdf/shared-operations/functions/mergePDFs';
import { organizePages as dependantOrganizePages } from '@stirling-pdf/shared-operations/functions/organizePages';
import { rotatePages as dependantRotatePages } from '@stirling-pdf/shared-operations/functions/rotatePages';
import { scaleContent as dependantScaleContent} from '@stirling-pdf/shared-operations/functions/scaleContent';
import { scalePage as dependantScalePage } from '@stirling-pdf/shared-operations/functions/scalePage';
import { splitPDF as dependantSplitPDF } from '@stirling-pdf/shared-operations/functions/splitPDF';
export async function editMetadata(snapshot: string | Uint8Array | ArrayBuffer, metadata: Metadata) {
return dependantEditMetadata(snapshot, metadata);
}
export async function extractPages(snapshot: string | Uint8Array | ArrayBuffer, pagesToExtractArray: number[]) {
return dependantExtractPages(snapshot, pagesToExtractArray);
}
export async function mergePDFs(snapshots: (string | Uint8Array | ArrayBuffer)[]) {
return dependantMergePDFs(snapshots);
}
export async function organizePages(
snapshot: string | Uint8Array | ArrayBuffer,
operation: "CUSTOM_PAGE_ORDER" |
"REVERSE_ORDER" |
"DUPLEX_SORT" |
"BOOKLET_SORT" |
"ODD_EVEN_SPLIT" |
"REMOVE_FIRST" |
"REMOVE_LAST" |
"REMOVE_FIRST_AND_LAST",
customOrderString: string) {
return dependantOrganizePages(snapshot, operation, customOrderString);
}
export async function rotatePages(snapshot: string | Uint8Array | ArrayBuffer, rotation: number) {
return dependantRotatePages(snapshot, rotation);
}
export async function scaleContent(snapshot: string | Uint8Array | ArrayBuffer, scaleFactor: number) {
return dependantScaleContent(snapshot, scaleFactor);
}
export async function scalePage(snapshot: string | Uint8Array | ArrayBuffer, pageSize: { width: number; height: number; }) {
return dependantScalePage(snapshot, pageSize);
}
export async function splitPDF(snapshot: string | Uint8Array | ArrayBuffer, splitAfterPageArray: number[]) {
return dependantSplitPDF(snapshot, splitAfterPageArray);
}

View File

@ -16,6 +16,9 @@
"noEmit": true, "noEmit": true,
"jsx": "react-jsx" "jsx": "react-jsx"
}, },
"include": ["src", "../shared-operations/packages/wasm", "../server-node/public/utils/pdfcpu-wrapper-node.js"], "include": [
"src",
"declarations/*.d.ts"
],
"references": [{ "path": "./tsconfig.node.json" }] "references": [{ "path": "./tsconfig.node.json" }]
} }

10
package-lock.json generated
View File

@ -19,6 +19,7 @@
"version": "0.0.0", "version": "0.0.0",
"dependencies": { "dependencies": {
"@capacitor/core": "^5.5.0", "@capacitor/core": "^5.5.0",
"@capacitor/filesystem": "^5.1.4",
"@capawesome/capacitor-file-picker": "^5.1.1", "@capawesome/capacitor-file-picker": "^5.1.1",
"@ionic/react": "^7.0.0", "@ionic/react": "^7.0.0",
"@ionic/react-router": "^7.0.0", "@ionic/react-router": "^7.0.0",
@ -26,6 +27,7 @@
"@types/react-router": "^5.1.20", "@types/react-router": "^5.1.20",
"@types/react-router-dom": "^5.3.3", "@types/react-router-dom": "^5.3.3",
"ionicons": "^7.0.0", "ionicons": "^7.0.0",
"pdf-lib": "^1.17.1",
"react": "^18.2.0", "react": "^18.2.0",
"react-dom": "^18.2.0", "react-dom": "^18.2.0",
"react-router": "^5.3.4", "react-router": "^5.3.4",
@ -1967,6 +1969,14 @@
"resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
"integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q=="
}, },
"node_modules/@capacitor/filesystem": {
"version": "5.1.4",
"resolved": "https://registry.npmjs.org/@capacitor/filesystem/-/filesystem-5.1.4.tgz",
"integrity": "sha512-10EM1KvFMs+pTzxkcflspzxBWcX9sOnS9nTP5Afjr5hn4OxLrwTFySw2Z12Uv6jdN4OnhY3jXtDKXPljXvXILg==",
"peerDependencies": {
"@capacitor/core": "^5.1.1"
}
},
"node_modules/@capawesome/capacitor-file-picker": { "node_modules/@capawesome/capacitor-file-picker": {
"version": "5.1.1", "version": "5.1.1",
"resolved": "https://registry.npmjs.org/@capawesome/capacitor-file-picker/-/capacitor-file-picker-5.1.1.tgz", "resolved": "https://registry.npmjs.org/@capawesome/capacitor-file-picker/-/capacitor-file-picker-5.1.1.tgz",

View File

@ -1,5 +1,6 @@
import PDFLib from 'pdf-lib'; import { PDFDocument, ParseSpeeds } from 'pdf-lib';
/** /**
* @typedef {Object} Metadata * @typedef {Object} Metadata
@ -17,13 +18,12 @@ import PDFLib from 'pdf-lib';
* *
* @param {Uint16Array} snapshot * @param {Uint16Array} snapshot
* @param {Metadata} metadata - Set property to null or "" to clear, undefined properties will be skipped. * @param {Metadata} metadata - Set property to null or "" to clear, undefined properties will be skipped.
* @param {PDFLib} PDFLib * @returns Promise<Uint8Array>
* @returns
*/ */
export async function editMetadata(snapshot, metadata) { export async function editMetadata(snapshot, metadata) {
// Load the original PDF file // Load the original PDF file
const pdfDoc = await PDFLib.PDFDocument.load(snapshot, { const pdfDoc = await PDFDocument.load(snapshot, {
parseSpeed: PDFLib.ParseSpeeds.Fastest, parseSpeed: ParseSpeeds.Fastest,
}); });
if(metadata.Title !== undefined) if(metadata.Title !== undefined)

View File

@ -1,15 +1,15 @@
import PDFLib from 'pdf-lib'; import { PDFDocument } from 'pdf-lib';
export async function extractPages(snapshot, pagesToExtractArray) { export async function extractPages(snapshot, pagesToExtractArray) {
const pdfDoc = await PDFLib.PDFDocument.load(snapshot) const pdfDoc = await PDFDocument.load(snapshot)
// TODO: invent a better format for pagesToExtractArray and convert it. // TODO: invent a better format for pagesToExtractArray and convert it.
return createSubDocument(pdfDoc, pagesToExtractArray); return createSubDocument(pdfDoc, pagesToExtractArray);
}; };
export async function createSubDocument(pdfDoc, pagesToExtractArray) { export async function createSubDocument(pdfDoc, pagesToExtractArray) {
const subDocument = await PDFLib.PDFDocument.create(); const subDocument = await PDFDocument.create();
// Check that array max number is not larger pdf pages number // Check that array max number is not larger pdf pages number
if(Math.max(...pagesToExtractArray) >= pdfDoc.getPageCount()) { if(Math.max(...pagesToExtractArray) >= pdfDoc.getPageCount()) {

View File

@ -1,12 +1,12 @@
import PDFLib from 'pdf-lib'; import { PDFDocument } from 'pdf-lib';
export const mergePDFs = async (snapshots) => { export const mergePDFs = async (snapshots) => {
const mergedPdf = await PDFLib.PDFDocument.create(); const mergedPdf = await PDFDocument.create();
for (let i = 0; i < snapshots.length; i++) { for (let i = 0; i < snapshots.length; i++) {
const pdfToMerge = await PDFLib.PDFDocument.load(snapshots[i]); const pdfToMerge = await PDFDocument.load(snapshots[i]);
const copiedPages = await mergedPdf.copyPages(pdfToMerge, pdfToMerge.getPageIndices()); const copiedPages = await mergedPdf.copyPages(pdfToMerge, pdfToMerge.getPageIndices());
copiedPages.forEach((page) => mergedPdf.addPage(page)); copiedPages.forEach((page) => mergedPdf.addPage(page));

View File

@ -1,5 +1,5 @@
import PDFLib from 'pdf-lib'; import { PDFDocument } from 'pdf-lib';
/** /**
* @typedef {"CUSTOM_PAGE_ORDER"|"REVERSE_ORDER"|"DUPLEX_SORT"|"BOOKLET_SORT"|"ODD_EVEN_SPLIT"|"REMOVE_FIRST"|"REMOVE_LAST"|"REMOVE_FIRST_AND_LAST"} OrderOperation * @typedef {"CUSTOM_PAGE_ORDER"|"REVERSE_ORDER"|"DUPLEX_SORT"|"BOOKLET_SORT"|"ODD_EVEN_SPLIT"|"REMOVE_FIRST"|"REMOVE_LAST"|"REMOVE_FIRST_AND_LAST"} OrderOperation
@ -14,8 +14,8 @@ import PDFLib from 'pdf-lib';
* @returns * @returns
*/ */
export async function organizePages(snapshot, operation, customOrderString) { export async function organizePages(snapshot, operation, customOrderString) {
const pdfDoc = await PDFLib.PDFDocument.load(snapshot); const pdfDoc = await PDFDocument.load(snapshot);
let subDocument = await PDFLib.PDFDocument.create(); let subDocument = await PDFDocument.create();
const copiedPages = await subDocument.copyPages(pdfDoc, pdfDoc.getPageIndices()); const copiedPages = await subDocument.copyPages(pdfDoc, pdfDoc.getPageIndices());

View File

@ -1,17 +1,17 @@
import PDFLib from 'pdf-lib'; import { PDFDocument, ParseSpeeds, degrees } from 'pdf-lib';
export async function rotatePages(snapshot, rotation) { export async function rotatePages(snapshot, rotation) {
// Load the original PDF file // Load the original PDF file
const pdfDoc = await PDFLib.PDFDocument.load(snapshot, { const pdfDoc = await PDFDocument.load(snapshot, {
parseSpeed: PDFLib.ParseSpeeds.Fastest, parseSpeed: ParseSpeeds.Fastest,
}); });
const pages = pdfDoc.getPages(); const pages = pdfDoc.getPages();
pages.forEach(page => { pages.forEach(page => {
// Change page size // Change page size
page.setRotation(PDFLib.degrees(rotation)) page.setRotation(degrees(rotation))
}); });
// Serialize the modified document // Serialize the modified document

View File

@ -1,10 +1,10 @@
import PDFLib from 'pdf-lib'; import { PDFDocument, ParseSpeeds } from 'pdf-lib';
export async function scaleContent(snapshot, scaleFactor) { export async function scaleContent(snapshot, scaleFactor) {
// Load the original PDF file // Load the original PDF file
const pdfDoc = await PDFLib.PDFDocument.load(snapshot, { const pdfDoc = await PDFDocument.load(snapshot, {
parseSpeed: PDFLib.ParseSpeeds.Fastest, parseSpeed: ParseSpeeds.Fastest,
}); });
const pages = pdfDoc.getPages(); const pages = pdfDoc.getPages();

View File

@ -1,10 +1,10 @@
import PDFLib from 'pdf-lib'; import { PDFDocument, ParseSpeeds } from 'pdf-lib';
export async function scalePage(snapshot, pageSize) { export async function scalePage(snapshot, pageSize) {
// Load the original PDF file // Load the original PDF file
const pdfDoc = await PDFLib.PDFDocument.load(snapshot, { const pdfDoc = await PDFDocument.load(snapshot, {
parseSpeed: PDFLib.ParseSpeeds.Fastest, parseSpeed: ParseSpeeds.Fastest,
}); });
const new_size = pageSize; const new_size = pageSize;

View File

@ -1,10 +1,10 @@
import PDFLib from 'pdf-lib'; import { PDFDocument } from 'pdf-lib';
import { createSubDocument } from "./extractPages.js"; import { createSubDocument } from "./extractPages.js";
export async function splitPDF(snapshot, splitAfterPageArray) { export async function splitPDF(snapshot, splitAfterPageArray) {
const pdfDoc = await PDFLib.PDFDocument.load(snapshot) const pdfDoc = await PDFDocument.load(snapshot)
const numberOfPages = pdfDoc.getPages().length; const numberOfPages = pdfDoc.getPages().length;