

Zbuduj Agenta AI do Prezentacji: Kompletny Przewodnik dla Deweloperów
Agenci AI zmieniają sposób, w jaki oprogramowanie tworzy treści. Agent AI do prezentacji może generować, dostosowywać i dostarczać profesjonalne zestawy slajdów jako część zautomatyzowanych procesów — od pipeline'ów CRM po wewnętrzne narzędzia raportowania.
Ten przewodnik przeprowadzi Cię przez budowanie gotowego do produkcji agenta prezentacji przy użyciu API 2Slides.
Przegląd Architektury
Agent prezentacji zazwyczaj działa według następującego schematu:
Żądanie Użytkownika → Logika Agenta → API 2Slides → Sprawdzanie Zadania → Dostarczenie Wyniku ↓ Zbieranie Kontekstu (dane, szablony, zasoby marki)
Główne Komponenty
- Moduł Obsługi Wejścia — odbiera żądania prezentacji (tekst, dane, pliki)
- Kreator Kontekstu — wzbogaca żądania o szablony, informacje o marce, dane
- Silnik Generowania — wywołuje API 2Slides w celu utworzenia slajdów
- Monitor Statusu — sprawdza status zadania do momentu ukończenia
- Warstwa Dostarczania — zwraca linki do pobrania, wysyła przez email, publikuje na Slack
Pierwsze kroki
1. Uzyskaj swój klucz API
Zarejestruj się na 2slides.com i utwórz klucz API na 2slides.com/api.
2. Zainstaluj zależności
npm install node-fetch dotenv
3. Podstawowa implementacja agenta
import fetch from 'node-fetch'; class PresentationAgent { constructor(apiKey) { this.apiKey = apiKey; this.baseUrl = 'https://2slides.com/api/v1'; } async generateSlides({ topic, themeId, language = 'en', resolution = '2K' }) { // Krok 1: Rozpocznij generowanie const response = await fetch(`${this.baseUrl}/slides/generate`, { method: 'POST', headers: { 'Authorization': `Bearer ${this.apiKey}`, 'Content-Type': 'application/json' }, body: JSON.stringify({ userInput: topic, themeId, responseLanguage: language, resolution, mode: 'async' }) }); const job = await response.json(); if (!response.ok) throw new Error(job.error || 'Generation failed'); // Krok 2: Odpytuj do momentu ukończenia return await this.waitForCompletion(job.jobId); } async waitForCompletion(jobId, maxWait = 300000) { const start = Date.now(); while (Date.now() - start < maxWait) { const response = await fetch(`${this.baseUrl}/jobs/${jobId}`, { headers: { 'Authorization': `Bearer ${this.apiKey}` } }); const status = await response.json(); if (status.status === 'success') return status; if (status.status === 'failed') throw new Error('Generation failed'); await new Promise(r => setTimeout(r, 3000)); } throw new Error('Generation timed out'); } async generateFromFile({ fileUrl, prompt, themeId }) { const response = await fetch(`${this.baseUrl}/slides/create-pdf-slides`, { method: 'POST', headers: { 'Authorization': `Bearer ${this.apiKey}`, 'Content-Type': 'application/json' }, body: JSON.stringify({ fileUrl, userInput: prompt, themeId, mode: 'async' }) }); const job = await response.json(); return await this.waitForCompletion(job.jobId); } async generateWithDesign({ topic, referenceImageUrl, resolution = '2K' }) { const response = await fetch(`${this.baseUrl}/slides/create-like-this`, { method: 'POST', headers: { 'Authorization': `Bearer ${this.apiKey}`, 'Content-Type': 'application/json' }, body: JSON.stringify({ userInput: topic, designStyle: { global: { referenceImageUrl } }, resolution, mode: 'async' }) }); const job = await response.json(); return await this.waitForCompletion(job.jobId); } async addNarration({ jobId, mode = 'single', voice = 'Charon' }) { const response = await fetch(`${this.baseUrl}/slides/generate-narration`, { method: 'POST', headers: { 'Authorization': `Bearer ${this.apiKey}`, 'Content-Type': 'application/json' }, body: JSON.stringify({ jobId, mode, voice, contentMode: 'concise' }) }); return await response.json(); } } // Użycie const agent = new PresentationAgent('sk-2slides-xxx'); const result = await agent.generateSlides({ topic: 'Przegląd biznesowy Q1 2026', themeId: 'mckinsey-theme-id', resolution: '2K' }); console.log('Pobierz:', result.downloadUrl);
Implementacja w Python
import requests import time class PresentationAgent: def __init__(self, api_key): self.api_key = api_key self.base_url = 'https://2slides.com/api/v1' self.headers = { 'Authorization': f'Bearer {api_key}', 'Content-Type': 'application/json' } def generate_slides(self, topic, theme_id=None, language='en', resolution='2K'): response = requests.post( f'{self.base_url}/slides/generate', headers=self.headers, json={ 'userInput': topic, 'themeId': theme_id, 'responseLanguage': language, 'resolution': resolution, 'mode': 'async' } ) response.raise_for_status() job = response.json() return self._wait_for_completion(job['jobId']) def generate_from_file(self, file_url, prompt, theme_id=None): response = requests.post( f'{self.base_url}/slides/create-pdf-slides', headers=self.headers, json={ 'fileUrl': file_url, 'userInput': prompt, 'themeId': theme_id, 'mode': 'async' } ) response.raise_for_status() job = response.json() return self._wait_for_completion(job['jobId']) def _wait_for_completion(self, job_id, max_wait=300): start = time.time() while time.time() - start < max_wait: response = requests.get( f'{self.base_url}/jobs/{job_id}', headers=self.headers ) status = response.json() if status['status'] == 'success': return status if status['status'] == 'failed': raise Exception('Generowanie nie powiodło się') time.sleep(3) raise TimeoutError('Przekroczono limit czasu generowania') # Użycie agent = PresentationAgent('sk-2slides-xxx') result = agent.generate_slides('Trendy AI 2026', resolution='4K') print(f"Pobierz: {result['downloadUrl']}")
Zaawansowane Wzorce
Wzorzec 1: Generowanie Oparte na Szablonach
Wstępnie skonfiguruj motywy dla różnych przypadków użycia:
const TEMPLATES = { 'pitch-deck': { themeId: 'apple-id', resolution: '2K' }, 'quarterly-review': { themeId: 'mckinsey-id', resolution: '2K' }, 'training': { themeId: 'corporate-id', resolution: '1K' }, 'social-media': { themeId: 'saul-bass-id', resolution: '4K', aspectRatio: '1:1' }, }; async function generateByType(type, topic) { const config = TEMPLATES[type]; return agent.generateSlides({ topic, ...config }); }
Wzorzec 2: Integracja z Pipeline'em Danych
Połącz się ze swoimi źródłami danych:
async function weeklyReport(dataSource) { // 1. Pobierz najnowsze dane const data = await dataSource.getWeeklyMetrics(); // 2. Sformatuj jako dane wejściowe prezentacji const topic = `Raport Tygodniowy: Przychód $${data.revenue}, Użytkownicy ${data.users}, Rezygnacje ${data.churn}%`; // 3. Wygeneruj slajdy const result = await agent.generateSlides({ topic, themeId: 'mckinsey-id' }); // 4. Dostarcz await slackBot.postMessage('#team-updates', `Raport tygodniowy gotowy: ${result.downloadUrl}`); }
Wzorzec 3: Wyjście w Wielu Formatach
Wygeneruj slajdy + narrację + wideo w jednym pipeline:
async function fullPresentation(topic) { // 1. Wygeneruj slajdy const slides = await agent.generateSlides({ topic }); // 2. Dodaj narrację głosową await agent.addNarration({ jobId: slides.jobId, mode: 'multi', voice: 'Charon' }); // 3. Pobierz z dźwiękiem const download = await fetch(`${agent.baseUrl}/slides/download-slides-pages-voices`, { method: 'POST', headers: agent.headers, body: JSON.stringify({ jobId: slides.jobId }) }); return download.json(); }
Uwagi Produkcyjne
Ograniczanie Szybkości
- Domyślnie: 60 żądań/minutę
- Obsługuj odpowiedzi 429 z wykładniczym wycofywaniem
- Używaj trybu asynchronicznego dla operacji wsadowych
Obsługa Błędów
- Opakowuj wszystkie wywołania API w try/catch
- Implementuj logikę ponownych prób dla przejściowych błędów
- Loguj ID zadań do debugowania
Zarządzanie Kosztami
- Śledź zużycie kredytów na generowanie
- Ustaw alerty budżetowe w panelu 2Slides
- Używaj niższych rozdzielczości dla wewnętrznych/wersji roboczych treści
Bezpieczeństwo
- Przechowuj klucze API w zmiennych środowiskowych, nigdy w kodzie
- Używaj wywołań API tylko po stronie serwera — nigdy nie ujawniaj kluczy klientom
- Implementuj podpisywanie żądań dla callbacków webhook
Najczęściej Zadawane Pytania
Czy mogę zbudować produkt SaaS w oparciu o API 2Slides?
Tak — API jest zaprojektowane do użytku produkcyjnego. Nie ma ograniczeń dla aplikacji komercyjnych.
Jaki jest maksymalny limit równoczesnych generowań?
API obsługuje równoczesne żądania poprzez ograniczanie szybkości. W przypadku potrzeb dużej liczby operacji, skontaktuj się z zespołem 2Slides w sprawie limitów korporacyjnych.
Czy istnieje webhook dla ukończenia zadania?
Obecnie używaj odpytywania poprzez endpoint zadań. Wsparcie webhook jest w planach rozwoju.
Zbuduj swojego agenta prezentacji — uzyskaj klucz API w 2Slides i zacznij generować slajdy programowo.
About 2Slides
Create stunning AI-powered presentations in seconds. Transform your ideas into professional slides with 2slides AI Agent.
Try For Free