Transform PDF documents into editable CE.SDK designs. All formatting preserved.

Prerequisites#
Before you begin, make sure you have the following:
- Node.js v20+ and npm installed locally – Download Node.js
- A supported browser – Chrome 114+, Edge 114+, Firefox 115+, Safari 15.6+
See Browser Support for the full list.
Get Started#
Start fresh with a standalone PDF Template Import project. This creates a complete, ready-to-run application.
Step 1: Clone the Repository#
git clone https://github.com/imgly/starterkit-pdf-template-import-react-web.gitgit clone https://github.com/imgly/starterkit-pdf-template-import-react-web.gitnpx degit imgly/starterkit-pdf-template-import-react-web starterkit-pdf-template-import-react-webnpx degit imgly/starterkit-pdf-template-import-react-web starterkit-pdf-template-import-react-webThe src/ folder contains the application code:
src/├── app/ # Demo application├── imgly/│ ├── config/│ │ ├── actions.ts # Export/import actions│ │ ├── features.ts # Feature toggles│ │ ├── i18n.ts # Translations│ │ ├── plugin.ts # Main configuration plugin│ │ ├── settings.ts # Engine settings│ │ └── ui/│ │ ├── canvas.ts # Canvas configuration│ │ ├── components.ts # Custom component registration│ │ ├── dock.ts # Dock layout configuration│ │ ├── index.ts # Combines UI customization exports│ │ ├── inspectorBar.ts # Inspector bar layout│ │ ├── navigationBar.ts # Navigation bar layout│ │ └── panel.ts # Panel configuration│ ├── index.ts # Editor initialization function│ └── plugins/│ └── pdf-importer.ts└── index.tsx # Application entry pointStep 2: Install Dependencies#
Install the required packages:
cd starterkit-pdf-template-import-react-web
npm installcd starterkit-pdf-template-import-react-web
npm installcd starterkit-pdf-template-import-react-web
pnpm installcd starterkit-pdf-template-import-react-web
pnpm installcd starterkit-pdf-template-import-react-web
yarncd starterkit-pdf-template-import-react-web
yarnStep 3: Download Assets#
CE.SDK requires engine assets (fonts, icons, UI elements) to function. These must be served as static files from your project’s public/ directory.
curl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.76.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipcurl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.76.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipconst config = { // ... baseURL: '/assets' // ...};Step 4: Run the Development Server#
npm run devnpm run devpnpm run devpnpm run devyarn devyarn devOpen http://localhost:5173 in your browser.
Get Started#
Integrate the PDF Template Import into an existing Svelte application. This adds the editor configuration to your current project structure.
Step 1: Clone#
cd your-projectcd your-projectClone the starter kit and copy the editor configuration to your project:
git clone https://github.com/imgly/starterkit-pdf-template-import-react-web.git
cp -r starterkit-pdf-template-import-react-web/src/imgly ./src/imgly
rm -rf starterkit-pdf-template-import-react-webgit clone https://github.com/imgly/starterkit-pdf-template-import-react-web.git
cp -r starterkit-pdf-template-import-react-web/src/imgly ./src/imgly
rm -rf starterkit-pdf-template-import-react-webnpx degit imgly/starterkit-pdf-template-import-react-web/src/imgly ./src/imglynpx degit imgly/starterkit-pdf-template-import-react-web/src/imgly ./src/imglyThe imgly/ folder contains the editor configuration:
imgly/├── config/│ ├── actions.ts # Export/import actions│ ├── features.ts # Feature toggles│ ├── i18n.ts # Translations│ ├── plugin.ts # Main configuration plugin│ ├── settings.ts # Engine settings│ └── ui/│ ├── canvas.ts # Canvas configuration│ ├── components.ts # Custom component registration│ ├── dock.ts # Dock layout configuration│ ├── index.ts # Combines UI customization exports│ ├── inspectorBar.ts # Inspector bar layout│ ├── navigationBar.ts # Navigation bar layout│ └── panel.ts # Panel configuration├── index.ts # Editor initialization function└── plugins/ └── pdf-importer.tsStep 2: Install Dependencies#
Install the required packages for the editor:
Core Editor#
Install the Creative Editor SDK:
npm install @cesdk/cesdk-js@1.76.0npm install @cesdk/cesdk-js@1.76.0pnpm add @cesdk/cesdk-js@1.76.0pnpm add @cesdk/cesdk-js@1.76.0yarn add @cesdk/cesdk-js@1.76.0yarn add @cesdk/cesdk-js@1.76.0Headless Engine#
Install the headless engine for server-side and batch processing:
npm install @cesdk/engine@1.76.0npm install @cesdk/engine@1.76.0pnpm add @cesdk/engine@1.76.0pnpm add @cesdk/engine@1.76.0yarn add @cesdk/engine@1.76.0yarn add @cesdk/engine@1.76.0Import Plugin#
Add file format import support:
npm install @imgly/pdf-importernpm install @imgly/pdf-importerpnpm add @imgly/pdf-importerpnpm add @imgly/pdf-importeryarn add @imgly/pdf-importeryarn add @imgly/pdf-importerStep 3: Download Assets#
CE.SDK requires engine assets (fonts, icons, UI elements) to function. These must be served as static files from your project’s public/ directory.
curl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.76.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipcurl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.76.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipStep 4: Create the Editor Component#
Create a Svelte component using the CE.SDK imperative API (e.g., src/DesignEditor.svelte):
<script> import { onMount, onDestroy } from 'svelte'; import CreativeEditorSDK from '@cesdk/cesdk-js'; import { initPdfTemplateImportEditor } from './imgly';
let container; let cesdk = null;
onMount(async () => { cesdk = await CreativeEditorSDK.create(container, { baseURL: '/assets' }); await initPdfTemplateImportEditor(cesdk); });
onDestroy(() => { if (cesdk) { cesdk.dispose(); } });</script>
<div bind:this={container} style="width: 100vw; height: 100vh;"></div>Step 5: Use the Component#
Import and use the PDF Template Import component in your application:
<script> import DesignEditor from './DesignEditor.svelte';</script>
<DesignEditor />Understanding the PDF Importer#
The PDF importer parses PDF documents and converts them to editable CE.SDK scenes. It supports:
- Page Preservation: Preserves the original page structure, positioning, and rotation
- Text Blocks: Converts text runs into editable CE.SDK text blocks; falls back to vector outlines when a font cannot be resolved
- Vector Paths: Imports SVG path data from the PDF as vector path blocks
- Embedded Images: Extracts JPEG and PNG images and places them as graphic blocks
- Colors and Gradients: Reproduces solid colors, linear and radial gradients, plus RGB, CMYK, and Separation spot colors
Import Result Structure#
interface PdfImportResult { imageUrl: string; // Object URL for preview image sceneArchiveUrl: string; // Object URL for CE.SDK scene archive messages: LogMessage[]; // Import warnings and info messages fileName: string; // Original file name}Handling Import Messages#
The importer logs messages for elements it couldn’t fully convert or features not supported:
const result = await importPdfFile(pdfBlob, 'document.pdf');
// Check for any import warningsresult.messages.forEach((msg) => { if (msg.type === 'warning') { console.warn(`Import warning: ${msg.message}`); }});Set Up a Scene#
CE.SDK offers multiple ways to load content into the editor. PDFs are imported with a headless engine and then loaded into the editor as a scene archive:
import { importPdfFile } from './imgly/plugins/pdf-importer';
// 1. Fetch a PDF from any URL or from the file pickerconst blob = await fetch('https://example.com/document.pdf').then((r) => r.blob());
// 2. Parse the PDF in a headless engine and capture the resulting scene archiveconst result = await importPdfFile(blob, 'document.pdf', { baseURL: '/assets' });
// 3. Load the archive into the editorawait cesdk.loadFromArchiveURL(result.sceneArchiveUrl);
// Or: create a blank design canvasawait cesdk.actions.run('scene.create');
// Or: load from an existing CE.SDK scene archiveawait cesdk.loadFromArchiveURL('https://example.com/template.zip');Customize Assets#
The editor uses asset source plugins to provide built-in libraries for templates, stickers, shapes, and fonts. The starter kit includes a curated selection—customize what’s included based on your needs.
Asset sources are added via plugins in src/index.ts. Enable or disable individual sources:
import { FiltersAssetSource, StickerAssetSource, TextAssetSource, VectorShapeAssetSource, EffectsAssetSource, // ...} from '@cesdk/cesdk-js/plugins';
// Add only the sources you needawait cesdk.addPlugin(new FiltersAssetSource());await cesdk.addPlugin(new StickerAssetSource());await cesdk.addPlugin(new TextAssetSource());await cesdk.addPlugin(new VectorShapeAssetSource());await cesdk.addPlugin(new EffectsAssetSource());// ...For production deployments, self-hosting assets is required—the IMG.LY CDN is intended for development only. See Serve Assets for downloading assets, configuring baseURL, and excluding unused sources to optimize load times.
Configure Actions#
Actions are functions that handle user interactions like exporting designs, saving scenes, and importing files. CE.SDK provides built-in actions that you can run directly or override with custom implementations.
Key built-in actions:
exportDesign– Export the current design to PNG, JPEG, PDF, or other formatssaveScene– Save the scene as a JSON string for later editingimportScene– Import a previously saved scene (supports.sceneand.cesdkformats)exportScene– Export the scene as a JSON file or.cesdkarchive with all assetsuploadFile– Handle file uploads with progress tracking
Use cesdk.actions.run() to execute any action:
// Run a built-in actionawait cesdk.actions.run('exportDesign', { mimeType: 'image/png' });Import from File Picker#
// Let users open PDF files from their devicecesdk.actions.register('importImage', async () => { const blobURL = await cesdk.utils.loadFile({ accept: '.pdf,application/pdf', returnType: 'objectURL' }); const blob = await fetch(blobURL).then((r) => r.blob()); URL.revokeObjectURL(blobURL);
const result = await importPdfFile(blob, 'document.pdf'); await cesdk.loadFromArchiveURL(result.sceneArchiveUrl);});Export and Save#
// Register export action that downloads the edited designcesdk.actions.register('exportDesign', async (exportOptions) => { const { blobs, options } = await cesdk.utils.export(exportOptions); await cesdk.utils.downloadFile(blobs[0], options.mimeType);});Customize (Optional)#
Theming#
CE.SDK supports light and dark themes out of the box, plus automatic system preference detection. Switch between themes programmatically:
// 'light' | 'dark' | 'system' | (() => 'light' | 'dark')cesdk.ui.setTheme('dark');See Theming for custom color schemes, CSS variables, and advanced styling options.
Localization#
Customize UI labels and add support for multiple languages. The i18n system supports translation keys for all UI elements:
// Override specific labelscesdk.i18n.setTranslations({ en: { 'actions.export.image': 'Download Design', 'common.cancel': 'Cancel', 'common.apply': 'Apply' }});
// Set the active localecesdk.i18n.setLocale('en');See Localization for supported languages, translation key reference, and right-to-left language support.
UI Layout#

Customize the editor interface by modifying the dock, inspector bar, navigation bar, and canvas menu. CE.SDK provides Order APIs to control which components appear and in what sequence.
// Get current navigation bar componentsconst navOrder = cesdk.ui.getNavigationBarOrder();
// Add a custom button to the navigation barcesdk.ui.insertNavigationBarOrderComponent( 'ly.img.spacer', { id: 'my-custom-action' }, 'after');See Dock, Inspector Bar, Navigation Bar, Canvas Menu, and Canvas for detailed layout customization options.
Settings & Features#
Fine-tune editor behavior through settings and features.
Settings configure core engine behavior—rendering, input handling, and history management:
cesdk.engine.editor.setSettingBool('page/dimOutOfPageAreas', true);cesdk.engine.editor.setSettingBool('mouse/enableZoomControl', true);cesdk.engine.editor.setSettingBool('features/undoHistory', true);Features toggle which editing tools and panels appear in the UI:
// Toggle editor featurescesdk.feature.enable('ly.img.crop', true);cesdk.feature.enable('ly.img.filter', true);cesdk.feature.enable('ly.img.adjustment', true);See Settings and Features for the complete reference.
Key Capabilities#
The PDF Template Import starter kit enables professional document editing workflows.
PDF File Import
Import PDF documents directly into the editor with text, vector paths, images, and gradients preserved.
Page Preservation
Maintain the original page structure, positioning, and rotation from the source PDF.
Text Editing
Edit imported text with comprehensive typography controls and font management.
Vector Paths
Preserve and edit vector paths, embedded images, and graphic elements from PDF documents.
Export Options
Export edited designs to PNG, JPEG, PDF, or save as CE.SDK scene files.
Print & Design Workflows
Build document editing systems with RGB, CMYK, and spot color support for print and design workflows.
Troubleshooting#
Editor doesn’t load#
- Check the container element exists: Ensure your container element is in the DOM before calling
create() - Verify the baseURL: Assets must be accessible from the CDN or your self-hosted location
- Check console errors: Look for CORS or network errors in browser developer tools
PDF file does not import correctly#
- Check the file format: Ensure the file is a valid PDF (version 1.4+)
- Check file size: Large files may take longer to process
- Check console errors: Look for parsing or memory errors
- Review import messages: Check the
messagesarray in the import result for warnings
Assets don’t appear#
- Check network requests: Open DevTools Network tab and look for failed requests to
cdn.img.ly - Self-host assets for production: See Serve Assets to host assets on your infrastructure
Watermark appears in production#
- Add your license key: Set the
licenseproperty in your configuration - Sign up for a trial: Get a free trial license at img.ly/forms/free-trial
Next Steps#
- Configuration – Complete list of initialization options
- Serve Assets – Self-host engine assets for production
- Actions – Build custom export and save workflows
- Import from PowerPoint – Import PowerPoint presentations
- Import from Photoshop – Import Adobe Photoshop templates
- Import from InDesign – Import Adobe InDesign templates