mirror of
https://github.com/Frooodle/Stirling-PDF.git
synced 2025-04-17 01:16:39 +02:00
169 lines
7.5 KiB
TypeScript
169 lines
7.5 KiB
TypeScript
import { organizeWaitOperations } from "./organizeWaitOperations";
|
|
import { Action, WaitAction } from "../../declarations/Action";
|
|
import { OperationsType } from "../../src/index";
|
|
import { PdfFile } from "../wrappers/PdfFile";
|
|
|
|
export async function * traverseOperations(operations: Action[], input: PdfFile[] | PdfFile, Operations: OperationsType): AsyncGenerator<string, PdfFile[], void> {
|
|
const waitOperations = organizeWaitOperations(operations);
|
|
let results: PdfFile[] = [];
|
|
yield* nextOperation(operations, input);
|
|
return results;
|
|
|
|
async function * nextOperation(actions: Action[] | undefined, input: PdfFile[] | PdfFile): AsyncGenerator<string, void, void> {
|
|
console.log("Next Operation");
|
|
if(actions === undefined || (Array.isArray(actions) && actions.length == 0)) { // isEmpty
|
|
console.log("Last Operation");
|
|
if(Array.isArray(input)) {
|
|
console.log("ArrayOut: ", input);
|
|
console.log("operation done: " + input[0].filename + (input.length > 1 ? "+" : ""));
|
|
results = results.concat(input);
|
|
return;
|
|
}
|
|
else {
|
|
console.log("operation done: " + input.filename);
|
|
results.push(input);
|
|
return;
|
|
}
|
|
}
|
|
|
|
for (let i = 0; i < actions.length; i++) {
|
|
yield* computeOperation(actions[i], Object.assign([], input)); // structuredClone-like for ts TODO: test if this really works
|
|
}
|
|
}
|
|
|
|
async function * computeOperation(action: Action, input: PdfFile|PdfFile[]): AsyncGenerator<string, void, void> {
|
|
console.log("Input: ", input);
|
|
yield "Starting: " + action.type;
|
|
switch (action.type) {
|
|
case "done": // Skip this, because it is a valid node.
|
|
break;
|
|
case "wait":
|
|
const waitOperation = waitOperations[(action as WaitAction).values.id];
|
|
|
|
if(Array.isArray(input)) {
|
|
waitOperation.input.concat(input); // TODO: May have unexpected concequences. Needs further testing!
|
|
}
|
|
else {
|
|
waitOperation.input.push(input);
|
|
}
|
|
|
|
waitOperation.waitCount--;
|
|
if(waitOperation.waitCount == 0 && waitOperation.doneOperation.actions) {
|
|
yield* nextOperation(waitOperation.doneOperation.actions, waitOperation.input);
|
|
}
|
|
break;
|
|
case "extract":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.extractPages({file: input, pageIndecies: action.values["pageIndecies"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "impose":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.impose({file: input, nup: action.values["nup"], format: action.values["format"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "merge":
|
|
yield* nToOne(input, action, async (inputs) => {
|
|
const newPdf = await Operations.mergePDFs({files: inputs});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "removeBlankPages":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.removeBlankPages({file: input, whiteThreashold: action.values["whiteThreashold"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "rotate":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.rotatePages({file: input, rotation: action.values["rotation"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "sortPagesWithPreset":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.arrangePages({file: input, arrangementConfig: action.values["arrangementConfig"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
case "split":
|
|
// TODO: A split might break the done condition, it may count multiple times. Needs further testing!
|
|
yield* oneToN(input, action, async (input) => {
|
|
const splitResult = await Operations.splitPdfByIndex({file: input, pageIndexes: action.values["splitAfterPageArray"]});
|
|
for (let j = 0; j < splitResult.length; j++) {
|
|
splitResult[j].filename = splitResult[j].filename + "_split" + j;
|
|
}
|
|
return splitResult;
|
|
});
|
|
break;
|
|
case "splitOn":
|
|
yield* oneToN(input, action, async (input) => {
|
|
const splitResult = await Operations.splitPagesByPreset({file: input, type: action.values["type"], whiteThreashold: action.values["whiteThreashold"]});
|
|
for (let j = 0; j < splitResult.length; j++) {
|
|
splitResult[j].filename = splitResult[j].filename + "_split" + j;
|
|
}
|
|
return splitResult;
|
|
});
|
|
break;
|
|
case "updateMetadata":
|
|
yield* nToN(input, action, async (input) => {
|
|
const newPdf = await Operations.updateMetadata({file: input, ...action.values["metadata"]});
|
|
return newPdf;
|
|
});
|
|
break;
|
|
default:
|
|
throw new Error(`${action.type} not implemented yet.`);
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param {PdfFile|PdfFile[]} input
|
|
* @param {JSON} action
|
|
* @returns {undefined}
|
|
*/
|
|
async function * nToOne(inputs: PdfFile|PdfFile[], action: Action, callback: (pdf: PdfFile[]) => Promise<PdfFile>): AsyncGenerator<string, void, void> {
|
|
const input = Array.isArray(inputs) ? inputs : [inputs]; // Convert single values to array, keep arrays as is.
|
|
|
|
const newInputs = await callback(input);
|
|
yield* nextOperation(action.actions, newInputs);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param {PdfFile|PdfFile[]} input
|
|
* @param {JSON} action
|
|
* @returns {undefined}
|
|
*/
|
|
async function * oneToN(input: PdfFile|PdfFile[], action: Action, callback: (pdf: PdfFile) => Promise<PdfFile[]>): AsyncGenerator<string, void, void> {
|
|
if(Array.isArray(input)) {
|
|
let output: PdfFile[] = [];
|
|
for (let i = 0; i < input.length; i++) {
|
|
output = output.concat(await callback(input[i]));
|
|
}
|
|
yield* nextOperation(action.actions, output);
|
|
}
|
|
else {
|
|
const nextInput = await callback(input);
|
|
yield* nextOperation(action.actions, nextInput);
|
|
}
|
|
}
|
|
|
|
async function * nToN(input: PdfFile|PdfFile[], action: Action, callback: (pdf: PdfFile) => Promise<PdfFile|PdfFile[]>): AsyncGenerator<string, void, void> {
|
|
if(Array.isArray(input)) {
|
|
console.log("inputs", input);
|
|
let nextInputs: PdfFile[] = []
|
|
for (let i = 0; i < input.length; i++) {
|
|
nextInputs = nextInputs.concat(await callback(input[i]));
|
|
}
|
|
console.log("nextInputs", nextInputs);
|
|
yield* nextOperation(action.actions, nextInputs);
|
|
}
|
|
else {
|
|
const nextInput = await callback(input);
|
|
yield* nextOperation(action.actions, nextInput);
|
|
}
|
|
}
|
|
} |