Add visual workflow builder, fix critical bugs, and add Arabic i18n support

This commit is contained in:
alam00000
2026-02-08 17:05:40 +05:30
parent 36ebb3b429
commit 5d8b83e105
118 changed files with 14151 additions and 2357 deletions

View File

@@ -0,0 +1,51 @@
import { ClassicPreset } from 'rete';
import { BaseWorkflowNode } from './base-node';
import { pdfSocket } from '../sockets';
import type { SocketData } from '../types';
import { requirePdfInput, extractAllPdfs } from '../types';
import { downloadFile } from '../../utils/helpers.js';
import { loadPyMuPDF } from '../../utils/pymupdf-loader.js';
export class PdfToDocxNode extends BaseWorkflowNode {
readonly category = 'Output' as const;
readonly icon = 'ph-microsoft-word-logo';
readonly description = 'Convert PDF to Word document';
constructor() {
super('PDF to Word');
this.addInput('pdf', new ClassicPreset.Input(pdfSocket, 'PDF'));
}
async data(
inputs: Record<string, SocketData[]>
): Promise<Record<string, SocketData>> {
const pdfInputs = requirePdfInput(inputs, 'PDF to Word');
const allPdfs = extractAllPdfs(pdfInputs);
const pymupdf = await loadPyMuPDF();
if (allPdfs.length === 1) {
const blob = new Blob([new Uint8Array(allPdfs[0].bytes)], {
type: 'application/pdf',
});
const docxBlob = await pymupdf.pdfToDocx(blob);
const name = allPdfs[0].filename.replace(/\.pdf$/i, '') + '.docx';
downloadFile(docxBlob, name);
} else {
const JSZip = (await import('jszip')).default;
const zip = new JSZip();
for (const pdf of allPdfs) {
const blob = new Blob([new Uint8Array(pdf.bytes)], {
type: 'application/pdf',
});
const docxBlob = await pymupdf.pdfToDocx(blob);
const name = pdf.filename.replace(/\.pdf$/i, '') + '.docx';
const arrayBuffer = await docxBlob.arrayBuffer();
zip.file(name, arrayBuffer);
}
const zipBlob = await zip.generateAsync({ type: 'blob' });
downloadFile(zipBlob, 'docx_files.zip');
}
return {};
}
}