CE.SDK can include assets from third-party libraries accessible via API. Search and browse images from an Airtable spreadsheet in the editor.

Prerequisites#
Before you begin, make sure you have the following:
- Node.js v20+ and npm installed locally – Download Node.js
- Airtable API Key – Get your API key from your Airtable account settings
- A supported browser – Chrome 114+, Edge 114+, Firefox 115+, Safari 15.6+
See Browser Support for the full list.
Get Started#
Run the Airtable Image Editor starter kit directly with Vite.
Step 1: Clone the Starter Kit#
git clone https://github.com/imgly/starterkit-airtable-asset-source-react-web.git
cd starterkit-airtable-asset-source-react-webgit clone https://github.com/imgly/starterkit-airtable-asset-source-react-web.git
cd starterkit-airtable-asset-source-react-webnpx degit imgly/starterkit-airtable-asset-source-react-web my-project
cd my-projectnpx degit imgly/starterkit-airtable-asset-source-react-web my-project
cd my-projectStep 2: Configure Airtable API Key#
Copy the example environment file and add your Airtable API key:
cp .env.example .envEdit .env and add your VITE_AIRTABLE_API_KEY#cp .env.example .envEdit .env and add your VITE_AIRTABLE_API_KEY#Get your API key from your Airtable account settings.
Step 3: Install Dependencies#
npm installnpm installpnpm installpnpm installyarn installyarn installStep 4: 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.73.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipcurl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.73.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipStep 5: Run the Development Server#
npm run devnpm run devpnpm devpnpm devyarn devyarn devOpen http://localhost:5173 in your browser. Click “Airtable” in the dock to search and browse your Airtable images.
Get Started#
Integrate the Airtable Image Editor into an existing vanilla JavaScript/TypeScript project. This adds the editor configuration and Airtable asset source 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-airtable-asset-source-react-web.git
cp -r starterkit-airtable-asset-source-react-web/src/imgly ./src/imgly
rm -rf starterkit-airtable-asset-source-react-webgit clone https://github.com/imgly/starterkit-airtable-asset-source-react-web.git
cp -r starterkit-airtable-asset-source-react-web/src/imgly ./src/imgly
rm -rf starterkit-airtable-asset-source-react-webnpx degit imgly/starterkit-airtable-asset-source-react-web/src/imgly ./src/imglynpx degit imgly/starterkit-airtable-asset-source-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/ └── airtable.tsStep 2: Install Dependencies#
Install the required packages for the editor:
Core Editor#
Install the Creative Editor SDK:
npm install @cesdk/cesdk-jsnpm install @cesdk/cesdk-jspnpm add @cesdk/cesdk-jspnpm add @cesdk/cesdk-jsyarn add @cesdk/cesdk-jsyarn add @cesdk/cesdk-jsAirtable Integration#
Install the Airtable JavaScript SDK:
npm install airtablenpm install airtablepnpm add airtablepnpm add airtableyarn add airtableyarn add airtableStep 3: Configure Airtable API Key#
Set your Airtable API key in one of two ways:
Environment Variable (Recommended)
# In your .env fileVITE_AIRTABLE_API_KEY=your_api_key_hereProgrammatically
await initAirtableImageEditor(cesdk, { airtableApiKey: 'your_api_key_here'});Step 4: 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.73.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipcurl -O https://cdn.img.ly/packages/imgly/cesdk-js/1.73.0/imgly-assets.zip
unzip imgly-assets.zip -d public/
rm imgly-assets.zipStep 5: Add a Container Element#
Add a container element to your HTML where the editor will be mounted:
<div id="cesdk_container" style="width: 100%; height: 100vh;"></div>Step 6: Initialize the Editor#
Import and call the initialization function from your entry point:
import CreativeEditorSDK from '@cesdk/cesdk-js';import { initAirtableImageEditor } from './imgly';
// Get your API key from your Airtable account settingsconst AIRTABLE_API_KEY = 'YOUR_AIRTABLE_API_KEY';
const config = { baseURL: '/assets'};
CreativeEditorSDK.create('#cesdk_container', config) .then(async (cesdk) => { await initAirtableImageEditor(cesdk, { airtableApiKey: AIRTABLE_API_KEY }); }) .catch((error) => { console.error('Failed to initialize CE.SDK:', error); });Using Airtable#
The editor integrates Airtable as a custom image source, replacing the default image library.
Browsing Images#
- Click the “Airtable” button in the dock (left sidebar)
- The Airtable library opens showing images from your database
- Click any image to add it to your design
Searching Images#
- Open the Airtable library
- Use the search bar at the top of the panel
- Type your search query and press Enter
- Browse results and click to add images
Replacing Images#
- Select an existing image in your design
- Click “Replace” in the inspector
- The Airtable library opens automatically
- Select a new image to replace the current one
Set Up a Scene#
CE.SDK offers multiple ways to load content into the editor. Choose the method that matches your use case:
// Create a blank design canvas - starts with an empty design sceneawait cesdk.actions.run('scene.create');
// Load from a template archive - restores a previously saved projectawait cesdk.loadFromArchiveURL('https://example.com/template.zip');
// Load from an image URL - creates a new scene with the imageawait cesdk.createFromImage('https://example.com/image.jpg');
// Load from a scene file - restores a scene from JSONawait cesdk.loadFromURL('https://example.com/scene.json');The createDesignScene() method is ideal for design workflows, as it creates a blank canvas ready for content.
Customize the Airtable Integration#
The Airtable asset source plugin can be customized by modifying src/imgly/plugins/airtable.ts:
export class AirtableAssetSourcePlugin implements EditorPlugin { name = 'cesdk-airtable-asset-source'; version = CreativeEditorSDK.version;
private options: AirtableAssetSourcePluginOptions;
constructor(options: AirtableAssetSourcePluginOptions = {}) { this.options = options; }
async initialize({ cesdk }: EditorPluginContext): Promise<void> { // Use API key from options const apiKey = this.options.apiKey ?? ''; const databaseId = this.options.databaseId ?? 'appHAZoD6Qj3teOmr';
// Create and add the asset source const airtableAssetSource = createAirtableAssetSource(apiKey, databaseId); cesdk.engine.asset.addSource(airtableAssetSource);
// Configure dock to show Airtable instead of default images const currentDockOrder = cesdk.ui.getDockOrder(); cesdk.ui.setDockOrder( currentDockOrder.map((component) => { if (component.key === 'ly.img.image') { return { id: 'ly.img.assetLibrary.dock', key: 'airtable', label: 'libraries.airtable.label', entries: ['airtable'] }; } return component; }) ); }}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 images from their devicecesdk.actions.register('importImage', async () => { const blobURL = await cesdk.utils.loadFile({ accept: 'image/*', returnType: 'objectURL' }); await cesdk.createFromImage(blobURL);});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);});Upload to Your Backend#
// Override the built-in exportDesign action to send to your servercesdk.actions.register('exportDesign', async (exportOptions) => { const { blobs } = await cesdk.utils.export(exportOptions);
const formData = new FormData(); formData.append('design', blobs[0], 'design.png');
const response = await fetch('/api/upload', { method: 'POST', body: formData });
const { url } = await response.json(); console.log('Uploaded to:', url);});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: { 'libraries.airtable.label': 'My Images', 'actions.export.image': 'Download Design', 'common.cancel': 'Cancel', 'common.apply': 'Apply' }});
// Add a new languagecesdk.i18n.setTranslations({ de: { 'libraries.airtable.label': 'Meine Bilder', 'actions.export.image': 'Design herunterladen' }});
// Set the active localecesdk.i18n.setLocale('de');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');
// Rearrange dock itemscesdk.ui.setDockOrder([ 'ly.img.assetLibrary.dock', 'ly.img.separator', 'my-custom-dock-item']);See Dock, Inspector Bar, Navigation Bar, Canvas Menu, and Canvas for detailed layout customization options.
Custom Components#
Build custom UI components using the builder system and integrate them in the editor. Custom components receive reactive state updates and can interact with the engine API.
// Register a custom componentcesdk.ui.registerComponent('my-custom-button', ({ builder, engine }) => { const selectedBlocks = engine.block.findAllSelected();
builder.Button('apply-effect', { label: 'Apply Effect', isDisabled: selectedBlocks.length === 0, onClick: () => { // Apply custom logic to selected blocks } });});
// Add the component to the navigation barcesdk.ui.insertNavigationBarOrderComponent( 'ly.img.spacer', 'my-custom-button', 'after');Custom components automatically re-render when the engine state they depend on changes—no manual subscription management required.
See Register New Component for the complete builder API and component patterns.
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.
Explore Plugins#
CE.SDK has a rich plugin ecosystem that extends the editor with powerful capabilities. Plugins can add new features, integrate third-party services, or customize editor behavior.
Background Removal#
Add AI-powered background removal that runs entirely client-side. The background removal plugin processes images directly in the browser without sending data to external servers.
import BackgroundRemovalPlugin from '@imgly/plugin-background-removal';
// Add background removal capabilityawait cesdk.addPlugin(BackgroundRemovalPlugin());See Background Removal for setup instructions and configuration options.
Print Ready PDF#
Export print-ready PDF/X-3 files with CMYK color profiles for professional printing workflows.
import PrintReadyPDFPlugin from '@imgly/plugin-print-ready-pdf';
// Add print-ready PDF export capabilityawait cesdk.addPlugin(PrintReadyPDFPlugin());See Print Ready PDF for setup instructions and configuration options.
AI Integration#
Extend the editor with generative AI capabilities for text-to-image generation, image enhancement, and intelligent editing features. CE.SDK integrates with various AI providers.
import AIPlugin from '@imgly/plugin-ai-generation';
// Configure AI generationawait cesdk.addPlugin(AIPlugin({ provider: 'your-ai-provider', apiKey: 'your-api-key'}));See AI Integration for provider setup and supported AI features.
Key Capabilities#
The Airtable Image Editor includes custom Airtable image integration plus full design editing capabilities.
Airtable Integration
Browse and search images stored in your Airtable database. Add images to your designs with one click.
Professional Filters
Apply color grading with LUT filters, duotone effects, and customizable image adjustments.
Text & Typography
Add styled text with comprehensive typography controls, fonts, and visual effects.
Design Templates
Start from pre-built templates or create designs from scratch with a full-featured canvas.
Privacy-First
All processing happens locally in the browser. Images are fetched directly from Airtable.
Export Options
Export to multiple formats including PNG, JPEG, and PDF with quality and size controls.
Troubleshooting#
”Please provide your Airtable API key” alert#
- Set your API key: Add
VITE_AIRTABLE_API_KEYto your.envfile or pass it toinitAirtableImageEditor() - Get your key: Get your API key from your Airtable account settings
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
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
Airtable images don’t load#
- Verify your API key: Make sure your Airtable API key is valid
- Check database permissions: Ensure your API key has access to the database
- Check network requests: Look for 401 or 403 errors in the Network tab
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#
- Asset Source Plugins – Build your own asset integrations
- Configuration – Complete list of initialization options
- Serve Assets – Self-host engine assets for production
- Actions – Build custom export and save workflows
- Theming – Customize colors and appearance
- Localization – Add translations and language support