Introducing Socket Firewall: Free, Proactive Protection for Your Software Supply Chain.Learn More
Socket
Book a DemoInstallSign in
Socket

@imgly/plugin-ai-text-generation-web

Package Overview
Dependencies
Maintainers
12
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@imgly/plugin-ai-text-generation-web

AI text generation plugin for the CE.SDK editor

latest
Source
npmnpm
Version
0.2.8
Version published
Weekly downloads
662
65.5%
Maintainers
12
Weekly downloads
 
Created
Source

IMG.LY AI Text Generation for Web

A plugin for integrating AI text generation capabilities into CreativeEditor SDK.

Overview

The @imgly/plugin-ai-text-generation-web package enables users to generate and transform text using AI directly within CreativeEditor SDK. This plugin provides text generation capabilities through AI models like Anthropic Claude.

Features include:

  • Text-to-text transformations
  • Quick AI actions for text blocks
  • Multiple transformation options:
    • Improve writing
    • Fix spelling and grammar
    • Make text shorter or longer
    • Change tone (professional, casual, friendly, etc.)
    • Translate to various languages
    • Custom text transformation with prompts
  • Seamless integration with CreativeEditor SDK

Installation

npm install @imgly/plugin-ai-text-generation-web

Usage

Basic Configuration

To use the plugin, import it and configure it with your preferred provider(s):

Single Provider

import CreativeEditorSDK from '@cesdk/cesdk-js';
import TextGeneration from '@imgly/plugin-ai-text-generation-web';
import Anthropic from '@imgly/plugin-ai-text-generation-web/anthropic';

// Initialize CreativeEditor SDK
CreativeEditorSDK.create(domElement, {
    license: 'your-license-key'
    // Other configuration options...
}).then(async (cesdk) => {
    // Add the text generation plugin
    cesdk.addPlugin(
        TextGeneration({
            provider: Anthropic.AnthropicProvider({
                proxyUrl: 'http://your-proxy-server.com/api/proxy',
                model: 'claude-3-7-sonnet-20250219', // Optional model selection (this is also the default)
                headers: {
                    'x-custom-header': 'value',
                    'x-client-version': '1.0.0'
                },
                // Optional: Configure default property values
                properties: {
                    temperature: { default: 0.7 },
                    max_tokens: { default: 500 }
                }
            }),

            // Optional configuration
            debug: false
        })
    );

    // Set canvas menu order to display AI text actions
    cesdk.ui.setCanvasMenuOrder([
        'ly.img.ai.text.canvasMenu',
        ...cesdk.ui.getCanvasMenuOrder()
    ]);
});

Multiple Providers

You can configure multiple providers, and users will see a selection box to choose between them:

import CreativeEditorSDK from '@cesdk/cesdk-js';
import TextGeneration from '@imgly/plugin-ai-text-generation-web';
import Anthropic from '@imgly/plugin-ai-text-generation-web/anthropic';

// Initialize CreativeEditor SDK
CreativeEditorSDK.create(domElement, {
    license: 'your-license-key'
    // Other configuration options...
}).then(async (cesdk) => {
    // Add the text generation plugin with multiple providers
    cesdk.addPlugin(
        TextGeneration({
            provider: [
                Anthropic.AnthropicProvider({
                    proxyUrl: 'http://your-proxy-server.com/api/proxy',
                    model: 'claude-3-7-sonnet-20250219', // Optional model selection (this is also the default)
                    headers: {
                        'x-custom-header': 'value',
                        'x-client-version': '1.0.0'
                    }
                }),
                // Add more providers here as they become available
                // OtherProvider.SomeModel({
                //     proxyUrl: 'http://your-proxy-server.com/api/proxy',
                //     headers: {
                //         'x-api-key': 'your-key',
                //         'x-source': 'cesdk'
                //     }
                // })
            ],

            // Optional configuration
            debug: false
        })
    );

    // Set canvas menu order to display AI text actions
    cesdk.ui.setCanvasMenuOrder([
        'ly.img.ai.text.canvasMenu',
        ...cesdk.ui.getCanvasMenuOrder()
    ]);
});

Providers

The plugin currently includes the following providers:

Anthropic Claude

A versatile text generation model that handles various text transformations:

provider: Anthropic.AnthropicProvider({
    proxyUrl: 'http://your-proxy-server.com/api/proxy',

    // Optional model selection (this is also the default)
    model: 'claude-3-7-sonnet-20250219',

    // Optional custom headers for API requests
    headers: {
        'x-custom-header': 'value',
        'x-client-version': '1.0.0',
        'x-request-source': 'cesdk-plugin'
    },

    // Optional: Configure default property values
    properties: {
        temperature: { default: 0.7 },    // Creativity level (0.0-1.0)
        max_tokens: { default: 500 }      // Maximum response length
    },

    // Optional debug mode
    debug: false
});

Default Model: If no model is specified, the provider uses 'claude-3-7-sonnet-20250219' by default.

Key features:

  • High-quality text transformations
  • Multiple transformation types
  • Supports various languages
  • Natural, human-like outputs
  • Custom headers support for API requests
  • Configurable model selection (Claude 3.5 Sonnet, Claude 3.7 Sonnet, etc.)
  • Default model: Claude 3.7 Sonnet (2025-02-19)

Custom Translations:

cesdk.i18n.setTranslations({
  en: {
    'ly.img.plugin-ai-text-generation-web.anthropic.property.prompt': 'Enter your text transformation request',
    'ly.img.plugin-ai-text-generation-web.anthropic.property.temperature': 'Claude Creativity Level',
    'ly.img.plugin-ai-text-generation-web.anthropic.property.maxTokens': 'Claude Response Length'
  }
});

OpenAI GPT

A powerful text generation model that handles various text transformations:

provider: OpenAIText.OpenAIProvider({
    proxyUrl: 'http://your-proxy-server.com/api/proxy',

    // Optional model selection (this is also the default)
    model: 'gpt-4o-mini',

    // Optional custom headers for API requests
    headers: {
        'x-custom-header': 'value',
        'x-client-version': '1.0.0',
        'x-request-source': 'cesdk-plugin'
    },

    // Optional: Configure default property values
    properties: {
        temperature: { default: 0.7 },    // Creativity level (0.0-2.0)
        max_tokens: { default: 500 },     // Maximum response length
        top_p: { default: 1.0 }          // Nucleus sampling (0.0-1.0)
    },

    // Optional debug mode
    debug: false
});

Default Model: If no model is specified, the provider uses 'gpt-4o-mini' by default.

Key features:

  • High-quality text transformations
  • Multiple transformation types
  • Supports various languages
  • Natural, human-like outputs
  • Custom headers support for API requests
  • Configurable model selection (GPT-4o, GPT-4o-mini, GPT-3.5-turbo, etc.)
  • Default model: GPT-4o-mini

Custom Translations:

cesdk.i18n.setTranslations({
  en: {
    'ly.img.plugin-ai-text-generation-web.openai.property.prompt': 'Enter your text transformation request',
    'ly.img.plugin-ai-text-generation-web.openai.property.temperature': 'GPT Creativity Level',
    'ly.img.plugin-ai-text-generation-web.openai.property.maxTokens': 'GPT Response Length'
  }
});

Feature Control

You can control various aspects of the text generation plugin using the Feature API:

// Disable provider selection dropdown
cesdk.feature.enable('ly.img.plugin-ai-text-generation-web.providerSelect', false);

// Disable all quick actions
cesdk.feature.enable('ly.img.plugin-ai-text-generation-web.quickAction', false);

// Disable specific quick actions
cesdk.feature.enable('ly.img.plugin-ai-text-generation-web.quickAction.improve', false);
cesdk.feature.enable('ly.img.plugin-ai-text-generation-web.quickAction.translate', false);
cesdk.feature.enable('ly.img.plugin-ai-text-generation-web.quickAction.changeTone', false);

For more information about Feature API and available feature flags, see the @imgly/plugin-ai-generation-web documentation.

Customizing Labels and Translations

You can customize all labels and text in the AI text generation interface using the translation system. This allows you to provide better labels for your users in any language.

Translation Key Structure

The system checks for translations in this order (highest to lowest priority):

  • Provider-specific: ly.img.plugin-ai-text-generation-web.${provider}.property.${field} - Override labels for a specific AI provider
  • Generic: ly.img.plugin-ai-generation-web.property.${field} - Override labels for all AI plugins

Basic Example

// Customize labels for your AI text generation interface
cesdk.i18n.setTranslations({
  en: {
    // Generic labels (applies to ALL AI plugins)
    'ly.img.plugin-ai-generation-web.property.prompt': 'Describe what you want to create',
    'ly.img.plugin-ai-generation-web.property.temperature': 'Creativity Level',
    'ly.img.plugin-ai-generation-web.property.maxTokens': 'Maximum Response Length',

    // Provider-specific for Anthropic
    'ly.img.plugin-ai-text-generation-web.anthropic.property.prompt': 'Enter your text transformation prompt',
    'ly.img.plugin-ai-text-generation-web.anthropic.property.temperature': 'Response Creativity',
    'ly.img.plugin-ai-text-generation-web.anthropic.property.maxTokens': 'Max Response Length',

    // Provider-specific for OpenAI
    'ly.img.plugin-ai-text-generation-web.openai.property.prompt': 'Describe your text transformation',
    'ly.img.plugin-ai-text-generation-web.openai.property.temperature': 'Creativity Setting',
    'ly.img.plugin-ai-text-generation-web.openai.property.maxTokens': 'Response Limit'
  }
});

QuickAction Translations

Text QuickActions (like "Improve Writing", "Fix Grammar", etc.) use their own translation keys with provider-specific overrides:

cesdk.i18n.setTranslations({
  en: {
    // Provider-specific translations (highest priority)
    'ly.img.plugin-ai-text-generation-web.anthropic.quickAction.improve': 'Improve with Claude',
    'ly.img.plugin-ai-text-generation-web.anthropic.quickAction.fix': 'Fix with Claude',
    'ly.img.plugin-ai-text-generation-web.openai.quickAction.translate': 'Translate with GPT',
    
    // Generic plugin translations
    'ly.img.plugin-ai-text-generation-web.quickAction.improve': 'Improve Writing',
    'ly.img.plugin-ai-text-generation-web.quickAction.fix': 'Fix Grammar',
    'ly.img.plugin-ai-text-generation-web.quickAction.shorter': 'Make Shorter',
    'ly.img.plugin-ai-text-generation-web.quickAction.longer': 'Make Longer',
    'ly.img.plugin-ai-text-generation-web.quickAction.changeTone': 'Change Tone',
    'ly.img.plugin-ai-text-generation-web.quickAction.translate': 'Translate',
    'ly.img.plugin-ai-text-generation-web.quickAction.changeTextTo': 'Transform Text...',
    
    // QuickAction input fields and buttons
    'ly.img.plugin-ai-text-generation-web.quickAction.changeTextTo.prompt': 'Transform Text...',
    'ly.img.plugin-ai-text-generation-web.quickAction.changeTextTo.prompt.placeholder': 'e.g. "Convert to bullet points"',
    'ly.img.plugin-ai-text-generation-web.quickAction.changeTextTo.apply': 'Transform',
    'ly.img.plugin-ai-text-generation-web.quickAction.translate.language': 'Target Language',
    'ly.img.plugin-ai-text-generation-web.quickAction.translate.apply': 'Translate'
  }
});

QuickAction Translation Priority:

  • Provider-specific: ly.img.plugin-ai-text-generation-web.${provider}.quickAction.${action}.${field}
  • Generic plugin: ly.img.plugin-ai-text-generation-web.quickAction.${action}.${field}

Translation Structure:

  • Base key (e.g., .quickAction.improve): Button text when QuickAction is collapsed
  • .prompt: Label for input field when expanded
  • .prompt.placeholder: Placeholder text for input field
  • .apply: Text for action/submit button
  • Additional fields like .language: Custom field labels

Configuration Options

The plugin accepts the following configuration options:

OptionTypeDescriptionDefault
providerProvider | Provider[]Provider(s) for text generation and transformation. When multiple providers are provided, users can select between themrequired
debugbooleanEnable debug loggingfalse
middlewareFunction[]Array of middleware functions for the generationundefined

Middleware Configuration

The middleware option allows you to add pre-processing and post-processing capabilities to the generation process:

import TextGeneration from '@imgly/plugin-ai-text-generation-web';
import Anthropic from '@imgly/plugin-ai-text-generation-web/anthropic';
import OpenAIText from '@imgly/plugin-ai-text-generation-web/open-ai';
import { loggingMiddleware, rateLimitMiddleware } from '@imgly/plugin-ai-generation-web';

// Create middleware functions
const logging = loggingMiddleware();
const rateLimit = rateLimitMiddleware({
  maxRequests: 20,
  timeWindowMs: 60000, // 1 minute
  onRateLimitExceeded: (input, options, info) => {
    console.log(`Text generation rate limit exceeded: ${info.currentCount}/${info.maxRequests}`);
    return false; // Reject request
  }
});

// Create custom middleware
const customMiddleware = async (input, options, next) => {
  console.log('Before generation:', input);
  
  // Add custom fields or modify the input
  const modifiedInput = {
    ...input,
    customField: 'custom value'
  };
  
  // Call the next middleware or generation function
  const result = await next(modifiedInput, options);
  
  console.log('After generation:', result);
  
  // You can also modify the result before returning it
  return result;
};

// Apply middleware to plugin
cesdk.addPlugin(
  TextGeneration({
    provider: Anthropic.AnthropicProvider({
      proxyUrl: 'http://your-proxy-server.com/api/proxy'
    }),
    middleware: [logging, rateLimit, customMiddleware] // Apply middleware in order
  })
);

Built-in middleware options:

  • loggingMiddleware: Logs generation requests and responses
  • rateLimitMiddleware: Limits the number of generation requests in a time window

You can also create custom middleware functions to meet your specific needs.

Using a Proxy

For security reasons, you must use a proxy server to handle API requests to Anthropic. The proxy URL is required when configuring providers:

provider: Anthropic.AnthropicProvider({
    proxyUrl: 'http://your-proxy-server.com/api/proxy',
    headers: {
        'x-custom-header': 'value',
        'x-client-version': '1.0.0'
    }
});

Your proxy server should:

  • Receive requests from the client
  • Add the necessary authentication (API key) to the requests
  • Forward requests to the AI provider API (Anthropic, OpenAI, etc.)
  • Return responses to the client

The headers option allows you to include custom HTTP headers in all API requests. This is useful for:

  • Adding custom client identification headers
  • Including version information
  • Passing through metadata required by your API
  • Adding correlation IDs for request tracing

Never expose your API keys in client-side code.

API Reference

Main Plugin

TextGeneration(options: PluginConfiguration): EditorPlugin

Creates and returns a plugin that can be added to CreativeEditor SDK.

Plugin Configuration

interface PluginConfiguration {
    // Provider(s) for text generation and transformation
    provider: (context: {
        cesdk: CreativeEditorSDK;
    }) => Promise<Provider<'text', any, any> | Provider<'text', any, any>[]>;

    // Enable debug logging
    debug?: boolean;
}

Anthropic Provider Configuration

Anthropic.AnthropicProvider(config: {
  proxyUrl: string;
  model?: string;
  headers?: Record<string, string>;
  debug?: boolean;
})

OpenAI Provider Configuration

OpenAIText.OpenAIProvider(config: {
  proxyUrl: string;
  model?: string;
  headers?: Record<string, string>;
  debug?: boolean;
})

UI Integration

The plugin automatically registers the following UI components:

  • Quick Actions: Canvas menu items for text transformations

Canvas Menu Integration

The plugin automatically registers quick actions for text transformation. Here are the available quick actions:

Available Quick Actions

  • ly.img.improve: Improve writing quality

    • Input: { prompt: string }
  • ly.img.fix: Fix spelling and grammar

    • Input: { prompt: string }
  • ly.img.shorter: Make text shorter

    • Input: { prompt: string }
  • ly.img.longer: Make text longer

    • Input: { prompt: string }
  • ly.img.changeTone: Change the tone of the text

    • Input: { prompt: string, type: string }
  • ly.img.translate: Translate text to different languages

    • Input: { prompt: string, language: string }
  • ly.img.changeTextTo: Change text to a different format or style

    • Input: { prompt: string, customPrompt: string }

Provider Quick Action Support

Providers declare which quick actions they support through their configuration:

const myTextProvider = {
    // ... other provider config
    input: {
        // ... panel config
        quickActions: {
            supported: {
                'ly.img.improve': {
                    mapInput: (quickActionInput) => ({
                        prompt: quickActionInput.prompt
                    })
                },
                'ly.img.fix': {
                    mapInput: (quickActionInput) => ({
                        prompt: quickActionInput.prompt
                    })
                },
                'ly.img.changeTone': {
                    mapInput: (quickActionInput) => ({
                        prompt: quickActionInput.prompt,
                        tone: quickActionInput.type
                    })
                }
                // Add more supported quick actions as needed
            }
        }
    }
};

To add the AI text menu to your canvas menu, use:

cesdk.ui.setCanvasMenuOrder([
    'ly.img.ai.text.canvasMenu',
    ...cesdk.ui.getCanvasMenuOrder()
]);

Translations

For customization and localization, see the translations.json file which contains provider-specific translation keys for text generation interfaces.

License

This plugin is part of the IMG.LY plugin ecosystem for CreativeEditor SDK. Please refer to the license terms in the package.

Keywords

CE.SDK

FAQs

Package last updated on 29 Sep 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts