Search Docs
Loading...
Skip to content

QR Code Editor for Vue

Easily generate and customize QR codes within CE.SDK.

QR Code Editor starter kit showing QR code generation interface

10 mins
estimated time
Download
StackBlitz
GitHub

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#

Create a new Vue application with QR Code Editor integration.

Step 1: Create a New Project#

Terminal
npm create vue@latest your-project-name
cd your-project-name
npm create vue@latest your-project-name
cd your-project-name

Step 2: Clone the Starter Kit#

Clone the starter kit and copy the editor configuration to your project:

Terminal
git clone https://github.com/imgly/starterkit-qr-code-editor-ts-web.git
cp -r starterkit-qr-code-editor-ts-web/src/imgly ./src/imgly
rm -rf starterkit-qr-code-editor-ts-web
git clone https://github.com/imgly/starterkit-qr-code-editor-ts-web.git
cp -r starterkit-qr-code-editor-ts-web/src/imgly ./src/imgly
rm -rf starterkit-qr-code-editor-ts-web

Step 3: Install Dependencies#

Core Editor#

Terminal
npm install @cesdk/cesdk-js
npm install @cesdk/cesdk-js

QR Code Plugin#

Terminal
npm install @imgly/plugin-qr-code-web
npm install @imgly/plugin-qr-code-web

Step 4: Download Assets#

Terminal
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.zip
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.zip

Step 5: Create the Editor Component#

Create src/components/QRCodeEditor.vue:

<script setup lang="ts">
import { onMounted, onUnmounted, ref } from 'vue';
import CreativeEditorSDK from '@cesdk/cesdk-js';
import { initQRCodeEditor } from '../imgly';
const containerRef = ref<HTMLDivElement | null>(null);
let cesdk: CreativeEditorSDK | null = null;
onMounted(async () => {
if (containerRef.value) {
cesdk = await CreativeEditorSDK.create(containerRef.value, {
baseURL: '/assets',
});
await initQRCodeEditor(cesdk);
}
});
onUnmounted(() => {
cesdk?.dispose();
});
</script>
<template>
<div ref="containerRef" style="width: 100%; height: 100vh;"></div>
</template>

Step 6: Use the Component#

Use the component in App.vue:

<script setup lang="ts">
import QRCodeEditor from './components/QRCodeEditor.vue';
</script>
<template>
<QRCodeEditor />
</template>

Using QR Code Generation#

The editor provides two ways to generate QR codes:

Via Dock Panel#

  1. Click the “QR Code” button in the dock (left sidebar)
  2. The QR Code panel opens with generation options
  3. Enter your URL or text content
  4. Customize colors and size
  5. Click “Generate” to add the QR code to your design

Via Canvas Menu#

  1. Right-click on the canvas
  2. Select “Generate QR Code” from the context menu
  3. The QR Code panel opens for customization

Customize Assets#

The QR Code 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/imgly/index.ts. Enable or disable individual sources:

src/imgly/index.ts
import {
FiltersAssetSource,
StickerAssetSource,
TextAssetSource,
VectorShapeAssetSource,
EffectsAssetSource,
// ...
} from '@cesdk/cesdk-js/plugins';
// Add only the sources you need
await 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 formats
  • saveScene – Save the scene as a JSON string for later editing
  • importScene – Import a previously saved scene (supports .scene and .cesdk formats)
  • exportScene – Export the scene as a JSON file or .cesdk archive with all assets
  • uploadFile – Handle file uploads with progress tracking

Use cesdk.actions.run() to execute any action:

// Run a built-in action
await cesdk.actions.run('exportDesign', { mimeType: 'image/png' });

Export and Save#

src/imgly/config/actions.ts
// Register export action that downloads the edited design
cesdk.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:

src/imgly/config/settings.ts
// '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:

src/imgly/config/i18n.ts
// Override specific labels
cesdk.i18n.setTranslations({
en: {
'actions.export.image': 'Download Design',
'common.cancel': 'Cancel',
'common.apply': 'Apply'
}
});
// Add a new language
cesdk.i18n.setTranslations({
de: {
'actions.export.image': 'Design herunterladen'
}
});
// Set the active locale
cesdk.i18n.setLocale('de');

See Localization for supported languages, translation key reference, and right-to-left language support.

UI Layout#

CE.SDK Editor UI Areas

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.

src/imgly/config/ui/navigationBar.ts
// Get current navigation bar components
const navOrder = cesdk.ui.getNavigationBarOrder();
// Add a custom button to the navigation bar
cesdk.ui.insertNavigationBarOrderComponent(
'ly.img.spacer',
{ id: 'my-custom-action' },
'after'
);
// Rearrange dock items
cesdk.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.


Key Capabilities#

QR Code Generation

QR Code Generation

Generate customizable QR codes with custom colors, sizes, and content. Add them to any design with a single click.

Professional Filters

Professional Filters

Apply color grading with LUT filters, duotone effects, and customizable image adjustments.

Text & Typography

Text & Typography

Add styled text with comprehensive typography controls, fonts, and visual effects.

Asset Libraries

Asset Libraries

Access built-in collections of templates, stickers, shapes, and graphics, plus import custom assets.

Privacy-First

Privacy-First

All processing happens locally in the browser. No data is sent to external servers.

Export Options

Export Options

Export to multiple formats including PNG, JPEG, and PDF with quality and size controls.



Troubleshooting#

Editor doesn’t load#

  • Check the container ref exists: Ensure the ref is properly bound before initialization
  • Verify the baseURL: Assets must be accessible from your self-hosted location

QR code panel doesn’t open#

  • Check plugin installation: Ensure @imgly/plugin-qr-code-web is installed
  • Verify plugin setup: Check that setupQRCodePlugin(cesdk) is called during initialization

Watermark appears in production#

  • Add your license key: Set the license property 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
  • Theming – Customize colors and appearance