A comprehensive and feature-rich React Native library for seamless Kore.ai chatbot integration
- ✨ Features
- 🚀 Quick Start
- 📦 Installation
- 🎯 Basic Usage
- 🎨 Customization
- 📚 API Reference
- 🛠️ Advanced Configuration
- 🔐 Permissions Setup
- 📱 Examples
- 🤝 Contributing
- 📄 License
- 💬 Support
|
|
Get up and running in minutes:
import React from 'react';
import { View } from 'react-native';
import KoreChat, { BotConfigModel } from 'rn-kore-bot-sdk-v77';
const App = () => {
const botConfig: BotConfigModel = {
botId: 'your-bot-id',
chatBotName: 'Assistant',
serverUrl: 'https://your.server.url',
brandingAPIUrl: 'https://your.branding.url',
};
return (
<View style={{ flex: 1 }}>
<KoreChat
botConfig={botConfig}
onListItemClick={(item) => console.log('📋 Item clicked:', item)}
onHeaderActionsClick={(action) => console.log('⚡ Action:', action)}
/>
</View>
);
};
export default App;
npm install rn-kore-bot-sdk-v77
# or
yarn add rn-kore-bot-sdk-v77
📱 Core Dependencies (Click to expand)
npm install \
"@react-native-community/checkbox@^0.5.20" \
"@react-native-picker/picker@^2.11.1" \
"@react-native-voice/voice@^3.2.4" \
"@react-native-community/datetimepicker@^8.4.2" \
"@react-native-community/netinfo@^11.4.1" \
"react-native-device-info@^14.0.4" \
"react-native-document-picker@^9.3.1" \
"react-native-fast-image@^8.6.3" \
"react-native-fs@^2.20.0" \
"react-native-gesture-handler@^2.26.0" \
"react-native-gifted-charts@^1.4.63" \
"react-native-image-picker@^8.2.1" \
"react-native-modal@^14.0.0-rc.1" \
"react-native-modal-datetime-picker@^18.0.0" \
"react-native-reanimated@^3.18.0" \
"react-native-reanimated-carousel@^4.0.2" \
"react-native-svg@^15.12.0" \
"react-native-tts@^4.1.1" \
"react-native-uuid@^2.0.3" \
"react-native-video@^6.15.0"
📋 Sample App Dependencies (Optional)
npm install \
"@react-native-async-storage/async-storage@^2.2.0" \
"@react-native-clipboard/clipboard@^1.16.2" \
"@react-navigation/elements@^2.5.2" \
"@react-navigation/stack@^7.4.2" \
"react-native-bootsplash@^6.3.9" \
"react-native-orientation-locker@^1.7.0" \
"react-native-permissions@^5.4.1" \
"react-native-safe-area-context@^5.5.2" \
"react-native-screens@^4.11.1"
🍎 iOS Setup
cd ios && pod install && cd ..
Add to ios/YourProject/Info.plist
:
<key>NSMicrophoneUsageDescription</key>
<string>This app needs microphone access for voice messages</string>
<key>NSSpeechRecognitionUsageDescription</key>
<string>This app uses speech recognition for voice-to-text</string>
<key>NSPhotoLibraryUsageDescription</key>
<string>This app needs photo library access for attachments</string>
<key>NSCameraUsageDescription</key>
<string>This app needs camera access for photos</string>
🤖 Android Setup
Add to android/app/src/main/AndroidManifest.xml
:
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CAMERA" />
import React from 'react';
import { SafeAreaView, StatusBar } from 'react-native';
import KoreChat, { BotConfigModel, ThemeProvider } from 'rn-kore-bot-sdk-v77';
const App = () => {
const botConfig: BotConfigModel = {
botId: 'st-12345678-1234-1234-1234-123456789012',
chatBotName: 'My Assistant',
serverUrl: 'https://bots.kore.ai',
brandingAPIUrl: 'https://bots.kore.ai',
customerId: 'your-customer-id',
clientId: 'your-client-id',
clientSecret: 'your-client-secret',
identity: 'your-user-identity',
isAnonymous: false,
isPlatform: true,
};
return (
<SafeAreaView style={{ flex: 1, backgroundColor: '#f5f5f5' }}>
<StatusBar barStyle="dark-content" backgroundColor="#ffffff" />
<KoreChat
botConfig={botConfig}
onListItemClick={handleListItemClick}
onHeaderActionsClick={handleHeaderAction}
/>
</SafeAreaView>
);
};
const handleListItemClick = (item: any) => {
console.log('📋 List item selected:', item);
};
const handleHeaderAction = (action: any) => {
console.log('⚡ Header action triggered:', action);
};
export default App;
import { ThemeProvider } from 'rn-kore-bot-sdk-v77';
const customTheme = {
primaryColor: '#007AFF',
secondaryColor: '#5856D6',
backgroundColor: '#F2F2F7',
textColor: '#000000',
borderColor: '#C7C7CC',
// Add more theme properties
};
const App = () => (
<ThemeProvider theme={customTheme}>
<KoreChat botConfig={botConfig} />
</ThemeProvider>
);
import { CustomTemplate } from 'rn-kore-bot-sdk-v77';
const MyCustomButton = new CustomTemplate({
templateType: 'custom-button',
render: (data, onAction) => (
<TouchableOpacity
style={styles.customButton}
onPress={() => onAction(data.action)}
>
<Text>{data.title}</Text>
</TouchableOpacity>
),
});
<KoreChat
botConfig={botConfig}
templateInjection={new Map([
['custom-button', MyCustomButton]
])}
/>
Prop | Type | Required | Description |
---|---|---|---|
botConfig |
BotConfigModel |
✅ | Bot configuration object |
onListItemClick |
(item: any) => void |
❌ | Callback for list item interactions |
onHeaderActionsClick |
(action: any) => void |
❌ | Callback for header action buttons |
templateInjection |
Map<string, CustomTemplate> |
❌ | Custom template injection map |
themeConfig |
ThemeConfig |
❌ | Custom theme configuration |
interface BotConfigModel {
// Required fields
botId: string; // Bot identifier
chatBotName: string; // Display name for the bot
serverUrl: string; // Server URL (without trailing slash)
brandingAPIUrl: string; // Branding API URL (without trailing slash)
// Authentication
customerId?: string; // Customer identifier
clientId?: string; // OAuth client ID
clientSecret?: string; // OAuth client secret
identity?: string; // User identity
// Configuration
isAnonymous?: boolean; // Anonymous user mode
isPlatform?: boolean; // Platform integration mode
enableHistory?: boolean; // Chat history feature
allowAttachments?: boolean; // File attachment feature
}
The library implements graceful degradation for native modules:
// ✅ Automatic fallback when modules are unavailable
// ⚠️ Logs appropriate warnings for missing features
// 🔄 Continues functioning with reduced capabilities
import { BotException } from 'rn-kore-bot-sdk-v77';
try {
// Bot operations
} catch (error) {
if (error instanceof BotException) {
console.log('Bot error:', error.message);
}
}
The SDK includes voice recognition and text-to-speech capabilities:
Status | Description | Action Required |
---|---|---|
✅ Granted | Voice features available | None |
Voice button hidden | Check app settings | |
🔄 Not Requested | Will prompt on first use | None |
🔧 Common Voice Problems
Problem: "Microphone permission denied" Solution:
- Check Info.plist/AndroidManifest.xml permissions
- Reset app permissions in device settings
- Reinstall app to re-trigger permission prompts
Problem: Voice button not appearing Solution:
- Verify
@react-native-voice/voice
installation - Check native module linking
- Rebuild project after adding permissions
// ✅ Success logs
"Voice module loaded successfully"
"Microphone permission granted"
// ⚠️ Warning logs
"Voice module not available"
"Microphone permission denied"
"Permissions module not available"
Explore the complete implementation in the /SampleApp
directory:
cd SampleApp
npm install
npx react-native run-ios # or run-android
-
SampleApp/src/config/BotConfig.tsx
- Configuration setup -
SampleApp/src/screens/Home/index.tsx
- Integration example -
SampleApp/src/customTemplates/
- Custom template examples
We welcome contributions! Please see our Contributing Guidelines for details.
git clone https://github.com/your-repo/react-native-kore-bot-sdk.git
cd react-native-kore-bot-sdk
npm install
npm run test # Run tests
npm run lint # Lint code
npm run build # Build library
npm run example # Run example app
This project is licensed under the MIT License - see the LICENSE file for details.
Found a bug? Open an issue Have a question? Start a discussion Need enterprise support? Contact Kore.ai