{"id":35331120,"url":"https://github.com/presenton/presenton","last_synced_at":"2026-04-09T21:31:14.673Z","repository":{"id":293807673,"uuid":"981177285","full_name":"presenton/presenton","owner":"presenton","description":"Open-Source AI Presentation Generator and API (Gamma, Beautiful AI, Decktopus Alternative)","archived":false,"fork":false,"pushed_at":"2026-03-06T13:23:32.000Z","size":789649,"stargazers_count":4251,"open_issues_count":73,"forks_count":827,"subscribers_count":39,"default_branch":"main","last_synced_at":"2026-03-06T16:30:33.171Z","etag":null,"topics":["ai-agent","ai-presentation","api","gamma","powerpoint-automation","powerpoint-free","powerpoint-generation","presentation"],"latest_commit_sha":null,"homepage":"https://presenton.ai","language":"HTML","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/presenton.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":"NOTICE","maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":["presenton"],"patreon":null,"open_collective":null,"ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"lfx_crowdfunding":null,"polar":null,"buy_me_a_coffee":null,"thanks_dev":null,"custom":null}},"created_at":"2025-05-10T14:12:46.000Z","updated_at":"2026-03-06T08:32:37.000Z","dependencies_parsed_at":"2025-09-10T06:16:31.275Z","dependency_job_id":"6417281d-0a5d-4dcd-b7e9-fb2924c6ac0c","html_url":"https://github.com/presenton/presenton","commit_stats":null,"previous_names":["presenton/presenton"],"tags_count":43,"template":false,"template_full_name":null,"purl":"pkg:github/presenton/presenton","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/presenton%2Fpresenton","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/presenton%2Fpresenton/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/presenton%2Fpresenton/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/presenton%2Fpresenton/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/presenton","download_url":"https://codeload.github.com/presenton/presenton/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/presenton%2Fpresenton/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30208730,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-07T03:24:23.086Z","status":"ssl_error","status_checked_at":"2026-03-07T03:23:11.444Z","response_time":53,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ai-agent","ai-presentation","api","gamma","powerpoint-automation","powerpoint-free","powerpoint-generation","presentation"],"created_at":"2025-12-31T10:00:30.679Z","updated_at":"2026-04-09T21:31:14.667Z","avatar_url":"https://github.com/presenton.png","language":"HTML","funding_links":["https://github.com/sponsors/presenton"],"categories":["\u003cimg src=\"./assets/satellite.svg\" width=\"16\" height=\"16\" style=\"vertical-align: middle;\"\u003e Satellites","Tools","6 つのトラック","AI Agent Frameworks \u0026 SDKs","Repos","12. Miscellaneous","A01_文本生成_文本对话","TypeScript"],"sub_categories":["Miscellaneous","Tier 6：Skill Discovery / Agent Infrastructure","Orchestration Frameworks","Data \u0026 Alignment Tools","大语言对话模型及数据"],"readme":"\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./readme_assets/images/logo.png\" alt=\"Presenton\" /\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://presenton.ai/download\"\u003e\u003cstrong\u003eQuickstart\u003c/strong\u003e\u003c/a\u003e \u0026middot;\n  \u003ca href=\"https://docs.presenton.ai/\"\u003e\u003cstrong\u003eDocs\u003c/strong\u003e\u003c/a\u003e \u0026middot;\n  \u003ca href=\"https://www.youtube.com/@presentonai\"\u003e\u003cstrong\u003eYoutube\u003c/strong\u003e\u003c/a\u003e \u0026middot;\n  \u003ca href=\"https://discord.gg/9ZsKKxudNE\"\u003e\u003cstrong\u003eDiscord\u003c/strong\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/presenton/presenton/blob/main/LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/badge/License-Apache%202.0-blue?style=flat\" alt=\"Apache2.0\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/presenton/presenton\"\u003e\u003cimg src=\"https://img.shields.io/github/stars/presenton/presenton?style=flat\" alt=\"Stars\" /\u003e\u003c/a\u003e\n  \u003ca href=\"https://presenton.ai/\"\u003e\u003cimg src=\"https://img.shields.io/badge/Platform-Windows%20%7C%20macOS%20%7C%20Linux-lightgrey?style=flat\" alt=\"Platform\" /\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n# Open-Source AI Presentation Generator and API (Gamma, Beautiful AI, Decktopus Alternative)\n\n### ✨ Why Presenton\n\nNo SaaS lock-in · No forced subscriptions · Full control over models and data\n\nWhat makes Presenton different?\n\n- Fully **self-hosted**; Web (Docker) \u0026 Desktop (Mac, Windows \u0026 Linux)\n- Works with OpenAI, Gemini, Anthropic, Ollama, or custom models\n- API deployable\n- Fully open-source (Apache 2.0)\n- Use your **existing PPTX files as templates** _(coming soon)_\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./readme_assets/images/banner_bg.gif\" alt=\"Presenton\" /\u003e\n\u003c/p\u003e\n\n#\n\n### 🎛 Features\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./readme_assets/images/features-1.png\" alt=\"Presenton Features\" /\u003e\n\u003c/p\u003e\n\n#\n\n### 💻 Presenton Desktop\n\nCreate AI-powered presentations using your own model provider (BYOK) or run everything locally on your own machine for full control and data privacy.\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://presenton.ai/download\"\u003e\n    \u003cimg src=\"./readme_assets/images/banner.png\" alt=\"Cloud deployment\" /\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n**Available Platforms**\n\n\u003ctable\u003e\n\u003ctr\u003e\n\u003cth align=\"left\"\u003ePlatform\u003c/th\u003e\n\u003cth align=\"left\"\u003eArchitecture\u003c/th\u003e\n\u003cth align=\"left\"\u003ePackage\u003c/th\u003e\n\u003cth align=\"left\"\u003eDownload\u003c/th\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003cb\u003emacOS\u003c/b\u003e\u003c/td\u003e\n\u003ctd\u003eApple Silicon / Intel\u003c/td\u003e\n\u003ctd\u003e\u003ccode\u003e.dmg\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003e\u003ca href=\"https://presenton.ai/download\"\u003eDownload ↗\u003c/a\u003e\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003cb\u003eWindows\u003c/b\u003e\u003c/td\u003e\n\u003ctd\u003ex64\u003c/td\u003e\n\u003ctd\u003e\u003ccode\u003e.exe\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003e\u003ca href=\"https://presenton.ai/download\"\u003eDownload ↗\u003c/a\u003e\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003cb\u003eLinux\u003c/b\u003e\u003c/td\u003e\n\u003ctd\u003ex64\u003c/td\u003e\n\u003ctd\u003e \u003ccode\u003e.deb\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003e\u003ca href=\"https://presenton.ai/download\"\u003eDownload ↗\u003c/a\u003e\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003c/table\u003e\n\nPresenton gives you complete control over your AI presentation workflow. Choose your models, customize your experience, and keep your data private.\n\n- Custom Templates \u0026 Themes — Create unlimited presentation designs with HTML and Tailwind CSS\n- AI Template Generation — Create presentation templates from existing Powerpoint documents.\n- Flexible Generation — Build presentations from prompts or uploaded documents\n- Export Ready — Save as PowerPoint (PPTX) and PDF with professional formatting\n- Built-In MCP Server — Generate presentations over Model Context Protocol\n- Bring Your Own Key — Use your own API keys for OpenAI, Google Gemini, Anthropic Claude, or any compatible provider. Only pay for what you use, no hidden fees or subscriptions.\n- Ollama Integration — Run open-source models locally with full privacy\n- OpenAI API Compatible — Connect to any OpenAI-compatible endpoint with your own models\n- Multi-Provider Support — Mix and match text and image generation providers\n- Versatile Image Generation — Choose from DALL-E 3, Gemini Flash, Pexels, or Pixabay\n- Rich Media Support — Icons, charts, and custom graphics for professional presentations\n- Runs Locally — All processing happens on your device, no cloud dependencies\n- API Deployment — Host as your own API service for your team\n- Fully Open-Source — Apache 2.0 licensed, inspect, modify, and contribute\n- Docker Ready — One-command deployment with GPU support for local models\n- Electron Desktop App — Run Presenton as a native desktop application on Windows, macOS, and Linux (no browser required)\n- Sign in with ChatGPT — Use your free or paid ChatGPT account to sign in and start creating presentations instantly — no separate API key required\n\n#\n\n### ☁️ Presenton Cloud\n\nRun Presenton directly in your browser — no installation, no setup required. Start creating presentations instantly from anywhere.\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://presenton.ai\"\u003e\n    \u003cimg src=\"./readme_assets/images/cloud-banner.png\" alt=\"Presenton Cloud\" /\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n#\n\n### ⚡ Running Presenton\n\n  \u003cp\u003e\n    You can run Presenton in two ways:\n    \u003cstrong\u003eDocker\u003c/strong\u003e for a one-command setup without installing a local dev\n    stack, or the \u003cstrong\u003eElectron desktop app\u003c/strong\u003e for a native app\n    experience (ideal for development or offline use).\n  \u003c/p\u003e\n\n**Option 1: Electron (Desktop App)**\n\n   \u003cp\u003e\n    Run Presenton as a native desktop application. LLM and image provider\n    (API keys, etc.) can be configured in the app. The same environment variables\n    used for Docker apply when running the bundled backend.\n  \u003c/p\u003e\n\n  \u003cp\u003e\n    \u003cstrong\u003ePrerequisites:\u003c/strong\u003e Node.js (LTS), npm, Python 3.11, and\n    \u003ca href=\"https://docs.astral.sh/uv/\"\u003euv\u003c/a\u003e\n    (for the Electron FastAPI backend in\n    \u003ccode\u003eelectron/servers/fastapi\u003c/code\u003e).\n  \u003c/p\u003e\n\n- Setup (First Time)\n  \u003cpre\u003e\u003ccode class=\"language-bash\"\u003ecd electron\n  npm run setup:env\u003c/code\u003e\u003c/pre\u003e\n\n  This installs Node dependencies, runs \u003ccode\u003euv sync\u003c/code\u003e in the FastAPI\n  server, and installs Next.js dependencies.\n\n- Run in Development\n  \u003cpre\u003e\u003ccode class=\"language-bash\"\u003enpm run dev\u003c/code\u003e\u003c/pre\u003e\n  \u003cp\u003e\n  This compiles TypeScript and starts Electron. The backend and UI run locally\n  inside the desktop window.\n  \u003c/p\u003e\n\n- Build Distributable (Optional)\n  To create installers for Windows, macOS, or Linux:\n  \u003cpre\u003e\u003ccode class=\"language-bash\"\u003enpm run build:all\n  npm run dist\u003c/code\u003e\u003c/pre\u003e\n  \u003cp\u003e\n  Output files are written to \u003ccode\u003eelectron/dist\u003c/code\u003e\n  (or as configured in your \u003ccode\u003eelectron-builder\u003c/code\u003e settings).\n  \u003c/p\u003e\n\n**Option 2: Docker**\n\n- Start Presenton\n  Linux/MacOS (Bash/Zsh Shell):\n  \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n  Windows (PowerShell):\n  \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -v \"${PWD}\\app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Open Presenton\n  \u003cp\u003e\n  Open \u003ca href=\"http://localhost:5000\"\u003ehttp://localhost:5000\u003c/a\u003e in the browser\n  of your choice to use Presenton.\n  \u003c/p\u003e\n\n  \u003cblockquote\u003e\n  \u003cp\u003e\n    \u003cstrong\u003eNote:\u003c/strong\u003e You can replace \u003ccode\u003e5000\u003c/code\u003e with any other port\n    number of your choice to run Presenton on a different port number.\n  \u003c/p\u003e\n  \u003c/blockquote\u003e\n\n#\n\n### ⚙️ Deployment Configurations\n\nThese settings apply to both Docker and the Electron app's backend. You may want to directly provide your API KEYS as environment variables and keep them hidden. You can set these environment variables to achieve it.\n\n- CAN_CHANGE_KEYS=[true/false]: Set this to **false** if you want to keep API Keys hidden and make them unmodifiable.\n- LLM=[openai/google/anthropic/ollama/custom]: Select **LLM** of your choice.\n- OPENAI_API_KEY=[Your OpenAI API Key]: Provide this if **LLM** is set to **openai**\n- OPENAI_MODEL=[OpenAI Model ID]: Provide this if **LLM** is set to **openai** (default: \"gpt-4.1\")\n- GOOGLE_API_KEY=[Your Google API Key]: Provide this if **LLM** is set to **google**\n- GOOGLE_MODEL=[Google Model ID]: Provide this if **LLM** is set to **google** (default: \"models/gemini-2.0-flash\")\n- ANTHROPIC_API_KEY=[Your Anthropic API Key]: Provide this if **LLM** is set to **anthropic**\n- ANTHROPIC_MODEL=[Anthropic Model ID]: Provide this if **LLM** is set to **anthropic** (default: \"claude-3-5-sonnet-20241022\")\n- OLLAMA_URL=[Custom Ollama URL]: Provide this if you want to custom Ollama URL and **LLM** is set to **ollama**\n- OLLAMA_MODEL=[Ollama Model ID]: Provide this if **LLM** is set to **ollama**\n- CUSTOM_LLM_URL=[Custom OpenAI Compatible URL]: Provide this if **LLM** is set to **custom**\n- CUSTOM_LLM_API_KEY=[Custom OpenAI Compatible API KEY]: Provide this if **LLM** is set to **custom**\n- CUSTOM_MODEL=[Custom Model ID]: Provide this if **LLM** is set to **custom**\n- TOOL_CALLS=[Enable/Disable Tool Calls on Custom LLM]: If **true**, **LLM** will use Tool Call instead of Json Schema for Structured Output.\n- DISABLE_THINKING=[Enable/Disable Thinking on Custom LLM]: If **true**, Thinking will be disabled.\n- WEB_GROUNDING=[Enable/Disable Web Search for OpenAI, Google And Anthropic]: If **true**, LLM will be able to search web for better results.\n\nYou can also set the following environment variables to customize the image generation provider and API keys:\n\n- DISABLE_IMAGE_GENERATION: If **true**, Image Generation will be disabled for slides.\n- IMAGE_PROVIDER=[dall-e-3/gpt-image-1.5/gemini_flash/nanobanana_pro/pexels/pixabay/comfyui]: Select the image provider of your choice.\n  - Required if **DISABLE_IMAGE_GENERATION** is not set to **true**.\n- OPENAI_API_KEY=[Your OpenAI API Key]: Required if using **dall-e-3** or **gpt-image-1.5** as the image provider.\n- DALL_E_3_QUALITY=[standard/hd]: Optional quality setting for **dall-e-3** (default: `standard`).\n- GPT_IMAGE_1_5_QUALITY=[low/medium/high]: Optional quality setting for **gpt-image-1.5** (default: `medium`).\n- GOOGLE_API_KEY=[Your Google API Key]: Required if using **gemini_flash** or **nanobanana_pro** as the image provider.\n- PEXELS_API_KEY=[Your Pexels API Key]: Required if using **pexels** as the image provider.\n- PIXABAY_API_KEY=[Your Pixabay API Key]: Required if using **pixabay** as the image provider.\n- COMFYUI_URL=[Your ComfyUI server URL] and COMFYUI_WORKFLOW=[Workflow JSON]: Required if using **comfyui** to route prompts to a self-hosted ComfyUI workflow.\n\nYou can disable anonymous telemetry using the following environment variable:\n\n- DISABLE_ANONYMOUS_TRACKING=[true/false]: Set this to **true** to disable anonymous telemetry.\n\n\u003e Note: You can freely choose both the LLM (text generation) and the image provider. Supported image providers: **dall-e-3**, **gpt-image-1.5** (OpenAI), **gemini_flash**, **nanobanana_pro** (Google), **pexels**, **pixabay**, and **comfyui** (self-hosted).\n\n\u003cbr\u003e\n\u003cbr\u003e\n\n**Docker Run Examples by Provider**\n\n- Using OpenAI\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -e LLM=\"openai\" -e OPENAI_API_KEY=\"******\" -e IMAGE_PROVIDER=\"dall-e-3\" -e CAN_CHANGE_KEYS=\"false\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Using Google\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -e LLM=\"google\" -e GOOGLE_API_KEY=\"******\" -e IMAGE_PROVIDER=\"gemini_flash\" -e CAN_CHANGE_KEYS=\"false\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Using Ollama\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -e LLM=\"ollama\" -e OLLAMA_MODEL=\"llama3.2:3b\" -e IMAGE_PROVIDER=\"pexels\" -e PEXELS_API_KEY=\"*******\" -e CAN_CHANGE_KEYS=\"false\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Using Anthropic\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton -p 5000:80 -e LLM=\"anthropic\" -e ANTHROPIC_API_KEY=\"******\" -e IMAGE_PROVIDER=\"pexels\" -e PEXELS_API_KEY=\"******\" -e CAN_CHANGE_KEYS=\"false\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Using OpenAI Compatible API\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it -p 5000:80 -e CAN_CHANGE_KEYS=\"false\"  -e LLM=\"custom\" -e CUSTOM_LLM_URL=\"http://*****\" -e CUSTOM_LLM_API_KEY=\"*****\" -e CUSTOM_MODEL=\"llama3.2:3b\" -e IMAGE_PROVIDER=\"pexels\" -e  PEXELS_API_KEY=\"********\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n- Running Presenton with GPU Support\n  To use GPU acceleration with Ollama models, you need to install and configure the NVIDIA Container Toolkit. This allows Docker containers to access your NVIDIA GPU.\n  Once the NVIDIA Container Toolkit is installed and configured, you can run Presenton with GPU support by adding the `--gpus=all` flag:\n    \u003cpre\u003e\u003ccode class=\"language-bash\"\u003edocker run -it --name presenton --gpus=all -p 5000:80 -e LLM=\"ollama\" -e OLLAMA_MODEL=\"llama3.2:3b\" -e IMAGE_PROVIDER=\"pexels\" -e PEXELS_API_KEY=\"*******\" -e CAN_CHANGE_KEYS=\"false\" -v \"./app_data:/app_data\" ghcr.io/presenton/presenton:latest\u003c/code\u003e\u003c/pre\u003e\n\n#\n\n### ✨ Generate Presentation via API\n\n**Generate Presentation**\n\n\u003cp\u003e\n\u003cstrong\u003eEndpoint:\u003c/strong\u003e \u003ccode\u003e/api/v1/ppt/presentation/generate\u003c/code\u003e\u003cbr\u003e\n\u003cstrong\u003eMethod:\u003c/strong\u003e \u003ccode\u003ePOST\u003c/code\u003e\u003cbr\u003e\n\u003cstrong\u003eContent-Type:\u003c/strong\u003e \u003ccode\u003eapplication/json\u003c/code\u003e\n\u003c/p\u003e\n\n**Request Body**\n\n\u003ctable\u003e\n\u003cthead\u003e\n\u003ctr\u003e\n\u003cth\u003eParameter\u003c/th\u003e\n\u003cth\u003eType\u003c/th\u003e\n\u003cth\u003eRequired\u003c/th\u003e\n\u003cth\u003eDescription\u003c/th\u003e\n\u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003econtent\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eYes\u003c/td\u003e\n\u003ctd\u003eMain content used to generate the presentation.\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003eslides_markdown\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring[] | null\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eProvide custom slide markdown instead of auto-generation.\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003einstructions\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring | null\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eAdditional generation instructions.\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003etone\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003e\nText tone (default: \u003ccode\u003e\"default\"\u003c/code\u003e).  \nOptions: \u003ccode\u003edefault\u003c/code\u003e, \u003ccode\u003ecasual\u003c/code\u003e, \u003ccode\u003eprofessional\u003c/code\u003e, \n\u003ccode\u003efunny\u003c/code\u003e, \u003ccode\u003eeducational\u003c/code\u003e, \u003ccode\u003esales_pitch\u003c/code\u003e\n\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003everbosity\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003e\nContent density (default: \u003ccode\u003e\"standard\"\u003c/code\u003e).  \nOptions: \u003ccode\u003econcise\u003c/code\u003e, \u003ccode\u003estandard\u003c/code\u003e, \u003ccode\u003etext-heavy\u003c/code\u003e\n\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003eweb_search\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003eboolean\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eEnable web search grounding (default: \u003ccode\u003efalse\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003en_slides\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003einteger\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eNumber of slides to generate (default: \u003ccode\u003e8\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003elanguage\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003ePresentation language (default: \u003ccode\u003e\"English\"\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003etemplate\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eTemplate name (default: \u003ccode\u003e\"general\"\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003einclude_table_of_contents\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003eboolean\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eInclude table of contents slide (default: \u003ccode\u003efalse\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003einclude_title_slide\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003eboolean\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003eInclude title slide (default: \u003ccode\u003etrue\u003c/code\u003e).\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003efiles\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring[] | null\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003e\nFiles to use in generation.  \nUpload first via \u003ccode\u003e/api/v1/ppt/files/upload\u003c/code\u003e.\n\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003ctr\u003e\n\u003ctd\u003e\u003ccode\u003eexport_as\u003c/code\u003e\u003c/td\u003e\n\u003ctd\u003estring\u003c/td\u003e\n\u003ctd\u003eNo\u003c/td\u003e\n\u003ctd\u003e\nExport format (default: \u003ccode\u003e\"pptx\"\u003c/code\u003e).  \nOptions: \u003ccode\u003epptx\u003c/code\u003e, \u003ccode\u003epdf\u003c/code\u003e\n\u003c/td\u003e\n\u003c/tr\u003e\n\n\u003c/tbody\u003e\n\u003c/table\u003e\n\n**Response**\n\n\u003cpre\u003e\u003ccode class=\"language-json\"\u003e{\n  \"presentation_id\": \"string\",\n  \"path\": \"string\",\n  \"edit_path\": \"string\"\n}\u003c/code\u003e\u003c/pre\u003e\n\n**Example Request**\n\n\u003cpre\u003e\u003ccode class=\"language-bash\"\u003ecurl -X POST http://localhost:5000/api/v1/ppt/presentation/generate \\\n  -H \"Content-Type: application/json\" \\\n  -d '{\n    \"content\": \"Introduction to Machine Learning\",\n    \"n_slides\": 5,\n    \"language\": \"English\",\n    \"template\": \"general\",\n    \"export_as\": \"pptx\"\n  }'\u003c/code\u003e\u003c/pre\u003e\n\n**Example Response**\n\n\u003cpre\u003e\u003ccode class=\"language-json\"\u003e{\n  \"presentation_id\": \"d3000f96-096c-4768-b67b-e99aed029b57\",\n  \"path\": \"/app_data/d3000f96-096c-4768-b67b-e99aed029b57/Introduction_to_Machine_Learning.pptx\",\n  \"edit_path\": \"/presentation?id=d3000f96-096c-4768-b67b-e99aed029b57\"\n}\u003c/code\u003e\u003c/pre\u003e\n\n\u003cblockquote\u003e\n\u003cstrong\u003eNote:\u003c/strong\u003e  \nPrepend your server’s root URL to \u003ccode\u003epath\u003c/code\u003e and \n\u003ccode\u003eedit_path\u003c/code\u003e to construct valid links.\n\u003c/blockquote\u003e\n\n**Documentation \u0026 Tutorials**\n\n\u003cul\u003e\n  \u003cli\u003e\n    \u003ca href=\"https://docs.presenton.ai/using-presenton-api\"\u003e\n      Full API Documentation\n    \u003c/a\u003e\n  \u003c/li\u003e\n  \u003cli\u003e\n    \u003ca href=\"https://docs.presenton.ai/tutorial/generate-presentation-over-api\"\u003e\n      Generate Presentations via API in 5 Minutes\n    \u003c/a\u003e\n  \u003c/li\u003e\n  \u003cli\u003e\n    \u003ca href=\"https://docs.presenton.ai/tutorial/generate-presentation-from-csv\"\u003e\n      Create Presentations from CSV using AI\n    \u003c/a\u003e\n  \u003c/li\u003e\n  \u003cli\u003e\n    \u003ca href=\"https://docs.presenton.ai/tutorial/create-data-reports-using-ai\"\u003e\n      Create Data Reports Using AI\n    \u003c/a\u003e\n  \u003c/li\u003e\n\u003c/ul\u003e\n\n#\n\n### 🚀 Roadmap\n\n- [x] Support for custom HTML templates by developers\n- [x] Support for accessing custom templates over API\n- [x] Implement MCP server\n- [ ] Ability for users to change system prompt\n- [x] Support external SQL database\n\n#\n\n### 🚀 Roadmap\n\nTrack the public roadmap on GitHub Projects: [https://github.com/orgs/presenton/projects/2](https://github.com/orgs/presenton/projects/2)\n\n#\n\n\u003cp align=\"left\"\u003e\n  \u003ca href=\"https://www.youtube.com/@presentonai?sub_confirmation=1\"\u003e\n    \u003cimg src=\"https://img.shields.io/badge/Subscribe-6C47FF?style=for-the-badge\u0026logo=cloud\u0026logoColor=white\" /\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpresenton%2Fpresenton","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fpresenton%2Fpresenton","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpresenton%2Fpresenton/lists"}