1.0.0 ⢠Published 6 months ago
@aivue/image-caption v1.0.0
@aivue/image-caption
š¼ļø AI-powered image captioning for Vue.js applications using OpenAI Vision API
Generate intelligent, contextual captions for images using GPT-4 Vision, the most advanced computer vision model available. Perfect for accessibility, content management, social media, and AI-powered applications.
⨠Features
- š¤ GPT-4 Vision - Most advanced image understanding AI
- šÆ Easy Integration - Drop-in Vue component with minimal setup
- š Simple Authentication - Just add your OpenAI API key
- š± Drag & Drop Upload - Intuitive file upload with preview
- š URL Support - Caption images from URLs
- š Batch Processing - Process multiple images at once
- š History Tracking - Keep track of generated captions
- š¾ Export Data - Export captions as JSON or CSV
- šØ Beautiful UI - Modern, responsive design
- š§ TypeScript Support - Full type definitions included
- š± Mobile Friendly - Works great on all devices
š Quick Start
Installation
npm install @aivue/image-captionBasic Usage
<template>
<div>
<AiImageCaption
:api-key="openaiApiKey"
@caption-generated="onCaptionGenerated"
/>
</div>
</template>
<script setup>
import { AiImageCaption } from '@aivue/image-caption';
import '@aivue/image-caption/dist/image-caption.css';
const openaiApiKey = import.meta.env.VITE_OPENAI_API_KEY;
const onCaptionGenerated = (result) => {
console.log('Generated caption:', result.caption);
};
</script>Environment Variables
Set your API key in environment variables:
# .env
VITE_OPENAI_API_KEY=your-openai-api-keyš API Reference
Component Props
| Prop | Type | Default | Description |
|---|---|---|---|
apiKey | string | '' | OpenAI API key |
model | string | 'gpt-4o' | AI model to use |
autoCaption | boolean | false | Auto-generate caption on image upload |
maxHistorySize | number | 20 | Maximum number of captions to keep in history |
Component Events
| Event | Payload | Description |
|---|---|---|
caption-generated | ImageCaptionResult | Fired when caption is successfully generated |
caption-error | Error | Fired when caption generation fails |
image-uploaded | ImageUploadEvent | Fired when image is uploaded |
image-removed | void | Fired when image is removed |
Composable Usage
<script setup>
import { useImageCaption } from '@aivue/image-caption';
const {
generateCaption,
uploadImage,
isProcessing,
result,
error,
history
} = useImageCaption({
config: {
apiKey: import.meta.env.VITE_OPENAI_API_KEY,
model: 'gpt-4o'
}
});
// Generate caption for uploaded file
const handleFileUpload = async (file) => {
try {
await uploadImage(file);
const result = await generateCaption(file);
console.log('Caption:', result.caption);
} catch (error) {
console.error('Failed:', error);
}
};
</script>šÆ Available Models
| Model | ID | Description | Best For |
|---|---|---|---|
| GPT-4o | gpt-4o | Latest and most capable vision model | General use, highest quality |
| GPT-4o Mini | gpt-4o-mini | Faster and more cost-effective | High volume, cost-sensitive apps |
| GPT-4 Turbo | gpt-4-turbo | High-intelligence vision model | Detailed analysis, complex scenes |
š§ Configuration Options
interface ImageCaptionConfig {
apiKey?: string; // OpenAI API key
model?: string; // Model ID to use ('gpt-4o', 'gpt-4o-mini', 'gpt-4-turbo')
}
interface ImageCaptionOptions {
model?: string; // Override model for this request
prompt?: string; // Custom prompt for caption generation
detail?: 'low' | 'high' | 'auto'; // Image analysis detail level
maxTokens?: number; // Maximum response tokens (300)
temperature?: number; // Creativity level (0.7)
}šØ Styling
The component comes with beautiful default styles, but you can customize them:
/* Override default styles */
.ai-image-caption {
--primary-color: #your-color;
--border-radius: 12px;
--spacing: 16px;
}
/* Custom upload area */
.upload-area {
border: 2px dashed #your-color;
background: #your-background;
}
/* Custom button styles */
.generate-btn {
background: linear-gradient(135deg, #your-gradient);
}š Advanced Usage
Batch Processing
<script setup>
import { useImageCaption } from '@aivue/image-caption';
const { generateBatchCaptions } = useImageCaption();
const processBatch = async (imageFiles) => {
const result = await generateBatchCaptions({
images: imageFiles,
options: {
model: 'gpt-4o',
prompt: 'Describe this image in detail for accessibility purposes.',
detail: 'high'
}
});
console.log(`Processed ${result.successCount} images`);
console.log('Results:', result.results);
};
</script>Custom Image Processing
<script setup>
import { useImageCaption, resizeImageFile } from '@aivue/image-caption';
const { generateCaption } = useImageCaption();
const processLargeImage = async (file) => {
// Resize large images for faster processing
const resizedFile = await resizeImageFile(file, {
maxWidth: 800,
maxHeight: 600,
quality: 0.8
});
const result = await generateCaption(resizedFile);
return result;
};
</script>Export History
<script setup>
import { useImageCaption } from '@aivue/image-caption';
const { exportHistory, history } = useImageCaption();
const downloadHistory = () => {
const jsonData = exportHistory('json');
const blob = new Blob([jsonData], { type: 'application/json' });
const url = URL.createObjectURL(blob);
const a = document.createElement('a');
a.href = url;
a.download = 'image-captions.json';
a.click();
URL.revokeObjectURL(url);
};
</script>š Getting Your API Key
- Go to OpenAI Platform
- Sign up for an account
- Go to API Keys
- Create a new secret key
- Copy your key (starts with "sk-") and use it as your API key
Pricing:
- GPT-4o: $5.00 / 1M input tokens, $15.00 / 1M output tokens
- GPT-4o Mini: $0.15 / 1M input tokens, $0.60 / 1M output tokens
- GPT-4 Turbo: $10.00 / 1M input tokens, $30.00 / 1M output tokens
š Examples
Accessibility Enhancement
<template>
<div>
<img :src="imageUrl" :alt="altText" />
<AiImageCaption
:api-key="apiKey"
@caption-generated="updateAltText"
/>
</div>
</template>
<script setup>
const altText = ref('');
const updateAltText = (result) => {
altText.value = result.caption;
};
</script>Social Media Integration
<template>
<div class="social-post">
<AiImageCaption
:api-key="apiKey"
:auto-caption="true"
@caption-generated="suggestHashtags"
/>
<textarea v-model="postText" placeholder="Write your post..."></textarea>
</div>
</template>
<script setup>
const postText = ref('');
const suggestHashtags = (result) => {
const hashtags = generateHashtags(result.caption);
postText.value += `\n\n${hashtags}`;
};
</script>š¤ Contributing
We welcome contributions! Please see our Contributing Guide for details.
š License
MIT License - see LICENSE for details.
š Links
Made with ā¤ļø by reachbrt
1.0.0
6 months ago