import gradio as gr import os from pdfitdown.pdfconversion import Converter converter = Converter(reader="docling") def convert_readme_to_pdf(markdown_file) -> str: """ Converts a markdown file to PDF format. Args: markdown_file: A file object representing the markdown file to be converted. Expected to have a 'name' attribute containing the file path. Returns: str: Path to the generated PDF file. The output filename is created by replacing the '.md' extension of the input file with '.pdf'. """ output_path = markdown_file.name.replace('.md', '.pdf') converter.convert(markdown_file.name, output_path) return output_path def convert_image_to_pdf(image_file) -> str: """ Convert an image file to PDF format. Args: image_file: A file object containing the image to be converted. The file must be in a format supported by the converter (e.g., PNG, JPG, JPEG). Returns: str: The file path of the generated PDF file. The output filename will be the same as the input filename but with a .pdf extension. """ output_path = image_file.name.replace(os.path.splitext(image_file.name)[1], '.pdf') converter.convert(image_file.name, output_path) return output_path # Create individual interfaces readme_to_pdf = gr.Interface( fn=convert_readme_to_pdf, inputs=gr.File(label="Upload README/Markdown file", file_types=[".md"]), outputs=gr.File(label="Converted PDF"), title="README to PDF Converter", description="Convert your markdown files to PDF format" ) image_to_pdf = gr.Interface( fn=convert_image_to_pdf, inputs=gr.File(label="Upload Image", file_types=["image"]), outputs=gr.File(label="Converted PDF"), title="Image to PDF Converter", description="Convert your images to PDF format" ) # Create tabbed interface demo = gr.TabbedInterface( [readme_to_pdf, image_to_pdf], ["README to PDF", "Image to PDF"], ) if __name__ == "__main__": demo.launch(server_name="0.0.0.0", server_port=7860, debug=True, mcp_server=True)